设为首页 收藏本站
查看: 1430|回复: 0

[经验分享] 基于heartbeatV2版本的ha-gui工具对httpd做高可用集群(2)

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-5-14 23:11:03 | 显示全部楼层 |阅读模式
一、对MariaDB做高可用集群
   1.环境规划
   我们通过192.168.1.231对外提供MariaDB提供服务,两个客户端的ip地址分别为192.168.1.200和192.168.1.201,在192.168.1.204上提供了nfs服务为两台数据库提供共享存储
   2.准备共享目录
/data 192.168.1.0/24(rw,no_root_squash)
   3.在创建用户使其能够uid相同  


[iyunv@php ~]# groupadd -r -g 306 mysql
[iyunv@php ~]# useradd -r -g mysql -u 306 mysql
   4.数据库初始化


[iyunv@node1 mysql]# groupadd -r -g 306 mysql
[iyunv@node1 mysql]# useradd -r -g mysql -u 306 mysql
[iyunv@node1 ~]# mount -t nfs 192.168.1.202:/data /mydata
[iyunv@node1 ~]# mkdir /mydata/{data,log}
[iyunv@node1 mysql]# chown mysql.mysql /mydata/ -R
[iyunv@node1 ~]# tar xf mariadb-10.0.10-linux-x86_64.tar.gz -C /usr/local/
[iyunv@node1 ~]# cd /usr/local/
[iyunv@node1 local]# ln -s mariadb-10.0.10-linux-x86_64 mysql
[iyunv@node1 local]# cd mysql/
[iyunv@node1 mysql]# chown mysql.root * -R
[iyunv@node1 mysql]# cp support-files/my-large.cnf /etc/my.cnf
并修改配置文件
thread_concurrency = 4
datadir=/mydata/data
log-bin=/mydata/logs/mysql-bin
innodb_file_per_table = ON
[iyunv@node1 mysql]# cp support-files/mysql.server /etc/init.d/mysqld
[iyunv@node1 mysql]# chmod +x /etc/init.d/mysqld
初始化数据库
[iyunv@node1 mysql]# scripts/mysql_install_db --user=mysql --datadir=/mydata/data/
    切记:现在就不需要在节点2上初始化数据了,节点2上的配置文件要跟节点1上保持一致
   5.配置权限


MariaDB[none]> grant all on *.* to 'wangfeng7399'@'192.168.1.231' identified by 'wangfeng7399';
MariaDB[none]> flush privileges;
   6.配置集群
     添加一个mariadbservice的组,用来存放关于mariadb定义的资源

wKioL1NSX5KBGNHBAAHyrlDNTRs542.jpg
wKiom1NSX7vRYLw7AALiRhhUsB8506.jpg
wKioL1NSX5LA9TpbAAKooKZc2wc965.jpg
wKiom1NSX7yT7u8pAAJcAHraRxM448.jpg
wKioL1NSX5Ohfc53AALor73G_Fk602.jpg
   7测试
   先创建一个数据库
wKiom1NSYCLgIHBFAABTsshLhpo860.jpg
   此处我们将node2节点关掉
wKioL1NSX_nik4kDAAJ0Ye3Zhro668.jpg
   在node1上登陆查看

wKiom1NSYCLCgbshAAMi7hzc0Gg215.jpg
   也可以看到我们创建的数据库
二、对LVS做高可用集群
   1.环境规划
我们通过192.168.1.232对外提供LVS提供服务,两台DS的地址分别为192.168.1.200和192.168.1.201,两个RealServer的ip地址分别为192.168.1.204和192.168.1.202
2.在RealServer上配置LVS的服务,两台的配置方法相同


[iyunv@php ~]# echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
[iyunv@php ~]# echo 1 > /proc/sys/net/ipv4/conf/eth0/arp_ignore
[iyunv@php ~]# echo 2 > /proc/sys/net/ipv4/conf/eth0/arp_announce
[iyunv@php ~]# echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
[iyunv@php ~]# ifconfig lo:0 192.168.1.232 netmask 255.255.255.255 broadcast 192.168.1.232 up
[iyunv@php ~]# route add -host 192.168.1.232 lo:0
启动httpd服务
[iyunv@php ~]# service httpd start
   3.在两台DS上安装基于lvs的rpm包,如果不安装官方给的文档,要自己书写配置文档,有点麻烦,ldirectord还会检测RealServer的健康状态


[iyunv@node1 ha]#  yum install -y heartbeat-ldirectord-2.1.4-12.el6.x86_64.rpm
最好是通过yum安装,这样可以解决依赖关系
chkconfig ldirectord off
关闭开机自启动
   4.准备配置文件
[iyunv@node1 ha]# cp /usr/share/doc/heartbeat-ldirectord-2.1.4/ldirectord.cf /etc/ha.d/
   5.修改配置文件


checktimeout=3  检查超时时间
checkinterval=1 每个多长时间检测一次心跳
fallback=127.0.0.1:80 如果都失败了,会转移到被本机的web服务上
autoreload=yes 配置文件会不会自动装载
logfile="/var/log/ldirectord.log" 日志文件
#logfile="local0" 或者使用syslog
#emailalert="admin@x.y.z"
#emailalertfreq=3600
#emailalertstatus=all
quiescent=yes 是否使用静默模式
virtual=192.168.1.232:80 定义VIP与端口
        real=192.168.1.204:80 gate RealServer的ip地址 gate表示DR
        real=192.168.1.202:80 gate
        fallback=127.0.0.1:80 gate 如果所有的检查失败,使用的页面
        service=http 基于那种方式做监控检查
        request=".health.html" 监控检查的文件
        receive="wangfeng7399" 检查的内容
        scheduler=rr 调度算法
        #persistent=600 定义持久连接时间
        netmask=255.255.255.255 定义子网掩码
       说明:定义时,只能virtual顶个写,其余的都要空一个制表符,要不会出现语法错误   
   6.在各Real Server上添加.health.html内容为wangfeng7399
   7.在DS上准备一个错误页面,内容为“维护时间”,并启动web服务
   8.配置服务


wKioL1NQHmjg0iXfAAIuVJR7SOI180.jpg
wKiom1NQHqPhZumuAALyIEtX1aI068.jpg
wKioL1NQHpbyV50EAALlsQypD5g507.jpg
   9.测试
     通过ipvsadm查看
wKiom1NQHsCRS_gXAAFHrOzGQQc882.jpg
   通过网页查看
wKioL1NQHpbAPFEiAADq0YWuDLo219.jpg
   我们将web1关掉,依次来模拟一台Real Server 坏掉
wKiom1NQHsCj17KEAAESgIP63g4873.jpg
我们将两台服务器都关掉
wKiom1NQH-7AJGyEAAF1yvTrPVo738.jpg
   通过web查看,为我们在DS上定义的页面
wKioL1NQHpeQRyfBAADk9Pzmy0k216.jpg
   我们启动其中任何一台,在查看
wKioL1NQIDyTL9kvAAEu74dp-IQ922.jpg
wKiom1NQIGXj7kowAADnzRLHB9Q484.jpg
   都不会再看到我们定义的维护页面
   大功告成,由于本人水平有限,可能会有错误,请各位大神批评指正



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-19174-1-1.html 上篇帖子: 基于heartbeatV2版本的ha-gui工具对httpd做高可用集群(1) 下篇帖子: Hadoop mr heartbeat rpc代码分析
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表