RabbitMQ 进阶- 阿里云服务器部署RabbitMQ集群
如果RabbitMQ集群只有一个broker节点,那么该节点的失效将导致整个服务临时性的不可用,并且可能会导致message的丢失(尤其是在非持久化message存储于非持久化queue中的时候)。可以将所有message都设置为持久化,并且使用持久化的queue,但是这样仍然无法避免由于缓存导致的问题:因为message在发送之后和被写入磁盘并执行fsync之间存在一个虽然短暂但是会产生问题的时间窗。通过publisher的confirm机制能够确保客户端知道哪些message已经存入磁盘,尽管如此,一般不希望遇到因单点故障导致服务不可用。
如果RabbitMQ集群是由多个broker节点构成的,那么从服务的整体可用性上来讲,该集群对于单点失效是有弹性的,但是同时也需要注意:尽管exchange和binding能够在单点失效问题上幸免于难,但是queue和其上持有的message却不行,这是因为queue及其内容仅仅存储于单个节点之上,所以一个节点的失效表现为其对应的queue不可用。
为了提高程序的吞吐量,保持消息的可靠性,一台机器挂了后,RabbitMQ能够正常生产,消费消息。
rabbitmq有三种模式:单机模式,普通集群模式,镜像集群模式
Demo级别的,一般只是本机测试玩玩而已,生产环境下不会用的。
在多台机器上启动多个rabbitmq实例,每个机器启动一个。
但是你创建的queue,只会放在一个rabbtimq实例上,但是每个实例都同步queue的元数据(存放含queue数据的真正实例位置)。消费的时候,实际上如果连接到了另外一个实例,那么那个实例会从queue所在实例上拉取数据过来。
示意图
这种方式确实很麻烦,也不怎么好,没做到所谓的分布式,就是个普通集群。
普通集群的方式,确实达到了消息的高可用,但没办法保证可靠性,没做到分布式,简而言之,只是一个普通的集群。
这种模式,才是所谓的rabbitmq的高可用模式,跟普通集群模式不一样的是,你创建的queue,无论元数据还是queue里的消息都会存在于多个实例上,然后每次你写消息到queue的时候,都会自动把消息到多个实例的queue里进行消息同步。
上图中每个节点有一个queue,生产者生产完毕数据后投递到指定交换机的队列,交换机的队列进行消息同步。
每个节点queue都有一个完整的rabbitmq节点,所以这种方式叫做镜像集群
好处: 任何一个节点宕机后,其它节点不受影响,正常使用
坏处:
确保机器中安装了Docker,若未安装,可看:云原生Docker入门 – 阿里云服务器Linux环境下安装Docker
查看拉取的镜像
成功运行
设置节点1
浏览器输入 您的ip地址:15673
再次测试即可成功~
File —> New —> Project —> Maven —> 直接Next 进入下一步创建普通的Maven工程即可
创建一个默认的Maven聚合工程,将src文件夹删除,该工程就是一个Maven聚合工程
引入依赖如下:
在项目内,新建一个Moudle,rabbitmq-order-producer 默认Maven工程,下一步即可
在项目内,新建一个Moudle,rabbitmq-order-cousumer 默认Maven工程,下一步即可
Maven聚合工程创建完成图
Maven依赖图
自行手写MainApplication即可
创建完成!
编写完成!
启动消费者
交换机
=
15674
15675
成功消费数据!
已成功同步消息~
要在阿里云服务器上搭建 PHP 环境,可以按照以下步骤进行操作:
登录阿里云服务器管理控制台,选择需要搭建 PHP 环境的服务器实例。
打开“管理控制台”>“系统工具”>“环境配置工具”,选择“安装 PHP”。
在弹出的“环境安装”窗口中,选择 PHP 版本的选择,点击“安装”按钮。
等待安装完成后,打开浏览器,输入服务器 IP 地址或域名,确认服务器是否成功连接。
在弹出的“连接成功”窗口中,点击“获取证书”,获取服务器的 SSL 证书。
回到阿里云控制台,选择“管理控制台”>“系统工具”>“环境配置工具”,选择“配置 PHP 环境”。
在弹出的“环境配置”窗口中,选择“SSL 证书”选项卡,点击“更新证书”按钮,将 SSL 证书文件上传到服务器。
等待证书更新完成后,关闭“环境配置”窗口。
现在,您可以在浏览器中输入服务器 IP 地址或域名,确认服务器是否成功连接 PHP 环境。
以上是在阿里云服务器上搭建 PHP 环境的基本步骤。需要注意的是,在操作过程中可能会出现一些问题,例如证书错误、配置错误等,需要仔细排查问题并尝试解决。
7站VPS导航为您回答
选购VPS上www7zhannet
添加"homepage" :" http://xxxcom/ " #解决部署到服务器后刷新页面出错的问题
加basename属性(c1为子目录名)
添加homepage行(后面加上子目录c1!)
新建c1子目录,把build文件夹里的内容上传到子目录文件夹中
重点:root和location
Docker部署WEB 应用时,本地可以成功打开测试页,在公网上(阿里云服务器)却不能打开。
1、环境:阿里云服务器
2、CentOS7系统
3、Docker成功部署
这里前提docker 已经成功部署啦,现有有一个简单的测试案例,在docker上部署一个应用从而访问web。
接下来让我们尝试使用 docker 构建一个 web 应用程序。
我们将在docker容器中运行一个 Python Flask 应用来运行一个web应用。
通过 -p 参数来设置一样的端口:
docker ps 查看正在运行的容器
容器内部的 5000 端口映射到我们本地主机的 5000 端口上。
这时我们可以通过浏览器访问WEB应用
访问失败
指定外网端口为5000,
1 本地测试能否打开测试页
本地没有问题。
2 浏览器中访问
在任意一台电脑上输入公网IP+端口号 (此端口号为运行WEB应用时指定的端口号5000) 如我的阿里云公网IP为123111111 此时在任意一台有网络的浏览器地址栏输入公网IP:http://123111111:5000 应该会出现测试页
但现在出现如下图所示:
显示打不开
查啦大量资料,以前曾经也解决过,一定弄明白自已购买的地区后,再去设置安全组的配置规则。
1 登录阿里云管理控制台
2找到云服务器ECS-概览
3 点击云服务器ECS,这个是我购买的类型,其他类型的就不清楚啦。
4 点击本安全组后,再次点击配置规则:
5 手动添加端口5000
6 最后保存,再从浏览器地址栏输入公网IP加端口号3344成功显示测试页如图:
1,APP应用需要什么样的云服务器?
为了帮助大家了解如何使用阿里云云服务器及相关应用,阿里云的移动云团队开发了一个简单的APP应用:移动云相册,其中使用了ECS主要用作部署云相册的API服务(信息调用、列表调用)和缩略图处理,因为这个应用服务端使用了JAVA语言开发,因此在上面安装tomcat来部署应用。
具体部署
1)远程登录:
第一次购买ECS后,会把该ECS服务器的root账号、密码发送购买者的邮箱,然后购买者可以通过远程登录到ECS服务器,具体远程登录可以参考如下:
Windows:http://helpaliyuncom/manualspm=51763835185164lLZzn&helpId=59
Linux:http://helpaliyuncom/manualspm=51763835185164lLZzn&helpId=59
2)安装web环境
根据自己应用特点选择安装相关web服务器tomcat或者jetty,阿里云提供了一条龙安装部署脚本,为开发者提供了更多的方便,请参考如下链接:http://helpaliyuncom/manualspm=0000RGeYy4&helpId=129
3)打包应用
将web源码下载到本地,使用命令mvnpackage打成war包。如果不是maven工程,可以用类似ant打成war包。
4)上传war包
Linux下面可以使用sftp上传war包,上传war包到指定目录后进行解压,具体使用方式参考:http://helpaliyuncom/manualspm=0000PnfpSL&helpId=1848
5)启动web服务
将tomcat或jetty服务启动
6)配置反向代理、绑定域名
具体配置信息参考:http://helpaliyuncom/manualspm=0000Ti7iuA&helpId=532, http://helpaliyuncom/manualspm=0000MKbFj1&helpId=65
2,APP应用如何把存到云存储服务器中?
类APP应用的架构核心在于大量小文件的存储与访问,在文件数量较多的情况下将文件直接存储在硬盘上将极大影响应用的访问效率。阿里云存储服务OSS对海量小文件的存储及管理具有很大优势,不从服务端下载,减少了服务端压力。阿里云的OSS的备份机制也保证了文件的存储安全,其存储容量可以无限扩展,每秒请求数超过50000次,多线BGP网络确保全国各地访问流畅。
使用阿里云OSS步骤:
1)登录阿里云官网(aliyuncom)开通OSS
2)获取KEY及密钥
3)下载SDK
(JAVA版下载地址为:http://bbsaliyuncom/jobphpaction=download&aid=38817
帮助手册: http://aliyun_portal_storageossaliyuncscom/oss_api/oss_javahtml/indexhtml )
4)开始APP开发
很简单吧,下面是一个使用阿里云的OSS上传的代码样例:
StringupLoadURI = OSSClientgenerateUploadUrl(ConstantsSERVER_URLGENERATE_URL,fileName, null);
int status =OSSClientuploadFile(upLoadURI, path);
3,APP上云后如何使用云数据库?
为了帮助大家了解如何使用阿里云云服务器及相关应用,阿里云的移动云团队开发了一个简单的APP应用:移动云相册,其中使用了RDS中提供的MYSQL服务,数据库中主要存储了用户上传的信息,包括原图、缩略图的信息及存储地址,通过WEB端API向客户端提供数据调用。
使用阿里云RDS和使用本地数据库基本上没有区别,使用样例如下:
1)创建数据库实例
使用阿里云账号购买RDS后,可以创建数据库实例。
2)创建数据库以及管理账号
创建数据库名称以及管理账号,用于应用程序调用数据库连接。
3)访问数据库:
创建完数据库(test)后,在数据库test里添加账户:test、密码:test,可以在RDS控制台查看到数据库相关信息,从中能够得到数据库的外网地址如:xxxxmysqlrdsaliyuncscom,可以使用应用程序连接数据库,javajdbc连接数据库示例代码如下:
String url = “jdbc:mysql://xxxxmysqlrdsaliyun:3306/test”;
String username = “test” ;
String password = “test” ;
try{
Connection con = DriverManagergetConnection(url ,username , password ) ;
}catch(SQLException e){
eprintStackTrace() ; //需要对异常做处理
}
0条评论