Apache双机热备
1 部署方案
1.1 方案设计
1.2 方案描述
如上图所示,我们要有三个可用的IP地址(切记不能与网络中其他机器IP重复),针对我使用的三个IP地址做如下说明:
10.16.252.10 //这个IP地址是心跳对外提供服务的IP地址,如果心跳检查绑定的应用程序的Apache,那这个地址就是外部访问Apache的地址;
10.16.252.6 //这个是主机(我用的是虚拟机)A的物理地址,绑定的网卡地址为eth0;
10.16.252.7 //这个是主机(我用的是虚拟机)B的物理地址,绑定的网卡地址为eth0;
为什么要强调绑定的网卡地址:应该心跳检查会通过绑定的网卡地址进行心跳信息的广播。
主机名说明:
主机(我用的是虚拟机)A的主机名:apache11
主机(我用的是虚拟机)B的主机名:apache12
在安装ubnutu的过程中会让你指定系统的主机名,可以随意指定的。如果安装的时候没有指定或是不知道主机名是什么,可以用linux命令:[uname –n]查看。也可以通过命令来修改主机名,ubnutu下主要修改/etc/hostname文件。
为什么强调主机名:因为在心跳组件heartbeat的配置过程中,需要指定主备节点的主机名。
2 环境配置
2.1 版本列表
功能模块 |
版本 |
下载 |
Apache |
Apache2.2.22 |
|
Heartbeat |
sudo apt-get install heartbeat |
|
Linux |
ubuntu-11.10-dvd-i386.iso |
|
VMware |
VMware-workstation-full-7.1.1-282343.exe |
说明: heartbeat心跳组件没有自己下载安装,而是采用ubnutu的apt-get 命令,这样的好处是它能够帮我们下载heartbeat所有依赖的主键,而且不需要我们去关注版本。
2.2 详细配置
2.2.1 具体配置
1) 编辑主机A的/etc/hosts文件
10.16.252.6 apache11 //主服务主机名
2) 编辑主机B的/etc/hosts文件
10.16.252.7 apache12 //备服务主机名
3) 在主机A和主机B上安装apache 并将apache设置为系统服务
例如:cp /usr/local/apache/bin/apachectl /etc/init.d/httpd chkconfig --add httpd chkconfig --level 2345 httpd on |
4) 在主机A和主机B上修改Apache端口,位置apache安装目录下的httpd.conf配置文件中
将Listen地址改为 虚拟IP:80, 我这里的虚拟IP为10.16.252.10 Listen 10.16.252.10:80 |
5) 在主机A和主机B上安装linux心跳组件heartbeat,在各自的linux命令窗口执行以下命令
sudo apt-get install heartbeat
6) 在主机A和主机B上对heartbeat做如下配置
描述:heartbeat的配置有3个文件,分别是authkeys, ha.cf 和 haresources,而且这3个文件必须放在/etc/ha.d/文件夹下,在完成第5步后,我们可以通过以下命令得到并放置这3个配置文件:
配置:
(一)配置authkeys文件注意:这个配置文件在主机A和主机B上的配置必须是相同的
该文件的原始内容如下:
|
将红色箭头所在行的#去掉,并将auth 1 该为 auth 3,修改后内容如下
|
这个配置文件的权限必须的0600,要执行以下命令修改权限
chmod 0600 authkeys
(二)配置haresources 注意:这个配置文件在主机A和主机B上的配置必须是相同的
|
(主节点名称) (集群对外公布IP地址) (需要高可用的服务(httpd)需要将这个服务配置为系统服务)
(三)配置ha.cf文件
|
以上这些属性在ha.cf文件中有的默认是打开的,有的默认是关闭的(即前面有#注释),找到这些配置属性,去掉对应属性前面的#号(默认打开则不做变动),注意node 属性要做变动,我这里有两台linux服务节点,所以配置了2个nodo属性,node配置规则:
node 服务主机名 如: node apache11 //服务主机名在前文及步骤1中都有强调说明,可使用 uname –n 查看当前系统的服务主机名
这对整个配置文件,在主机A和主机B上的其他属性的配置可以相同也可以不同,但node属性的配置必须相同。
在以上的属性配置中,有一个udpport 的端口配置,要注意主机A和主机B的防火墙是否对694端口做了限制,可以执行以下命名让防火墙开放该端口,或者禁掉防火墙。
sudo iptables -I INPUT 2 -p udp --dport 694 -j ACCEPT
7) 心跳测试
因为我们在haresources配置文件中配置的主节点名称是apache11,所以我们先后启动apache11(主机A)主服务和apache12(主机B)备服务两台机器上的heartbeat组件:
sudo /etc/init.d/heartbeat start
两个主机上的heartbeat都启动成功后,通过集群对外公布IP地址访问Apache服务:http://10.16.252.10:80
如果能够访问Apache主页,说明heartbeat已经将集群对外公布IP绑定到了Apache服务上了。
接下来停止主服务器(主机A)上的heartbeat组件:
sudo /etc/init.d/heartbeat stop
然后再次访问http://10.16.252.10:80,如果依然能够访问该地址,说明心跳组件监测到了主服务的dead状态,并将Apache托管给了备服务器并对外提供服务。
2.2.2 参考资料
1.http://barkingiguana.com/2008/06/24/high-availability-apache-on-ubuntu-804/
2.http://blog.csdn.net/kobeyan/article/details/7587926
3. https://docs.google.com/document/pub?id=1WXq86ZVm6YdLZ0BCG5EB9dKA6CTM3uoXOaIv8m-hbaM
4. http://blog.csdn.net/edward852/article/details/6043185
我主要是参考1、2两份资料进行测试部署的。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?