HA专题: corosync+pacemaker实现nginx高可用

HA专题: corosync+pacemaker实现nginx高可用

前言

这几天都会学习高可用集群, 也会将其中的一些实验写出来分享给大家, 这个专题估计会写5篇左右, p.s: 写博客很累的

实验介绍

这次的实验比较简单, 在CentOS7使用corosync+pacemaker实现两个节点的nginx高可用

实验拓扑

Alt textblob.png

实验环境

主机 IP 功用
node1.anyisalin.com 172.16.1.2 web服务, HA节点
node2.anyisalin.com 172.16.1.3 web服务, HA节点
nfs.anyisalin.com 172.16.1.4 提供nfs服务,网站页面文件

注意: 本文实验中所有主机SElinux和iptables都是关闭的

实验步骤

准备工作

高可用集群必须保证所有节点主机互信, 主机名解析一致, 时间同步

配置hosts文件同步
Alt textblob.png

配置互信
Alt text

Alt textblob.png

blob.png


时间同步
Alt textblob.png

安装HA集群组件

在RH系6.4之后就可以通过RedHat提供的pcs来进行对集群”全生命周期”的管理, 我们这里先通过pcs安装集群并自动生成配置文件

[root@node1 ~]# yum install pcs -y #node1安装pcs
[root@node1 ~]# ssh node2.anyisalin.com 'yum install pcs -y '  #node2安装pcs
[root@node1 ~]# echo passwd | passwd --stdin hacluster #设置hacluster用户密码
[root@node1 ~]# ssh node2.anyisalin.com "echo passwd | passwd --stdin hacluster" #为node2设置hacluster密码
[root@node1 ~]# systemctl start pcsd ; ssh node2.anyisalin.com "systemctl start pcsd" #启动pcsd

[root@node1 ~]# pcs cluster auth node1.anyisalin.com node2.anyisalin.com -u hacluster #进行认证
Password: 
node1.anyisalin.com: Authorized
node2.anyisalin.com: Authorized

[root@node1 ~]# pcs cluster setup --name mycluster node1.anyisalin.com node2.anyisalin.com #安装集群
[root@node1 ~]# pcs cluster start --all #启动集群

安装nginx和配置nfs

安装nginx

[root@node1 ~]# yum install nginx -y       注意: 需epel源
[root@node1 ~]# ssh node2.anyisalin.com "yum install nginx -y " 
[root@node1 ~]# systemctl enable nginx    #由于systemd的特性, 需将nginx设置开机自动启动
[root@node1 ~]# ssh node2.anyisalin.com "systemctl enable nginx" 

配置nfs
[root@nfs ~]# mkdir /www/htdocs -pv
[root@nfs ~]# echo "<h1>This is NFS on 172.16.1.4</h1>" > /www/htdocs/index.html #创建网页文件
[root@nfs ~]# vim /etc/exports
/www/htdocs    172.16.1.0/24(ro)

[root@nfs ~]# systemctl start rpcbind.service 
[root@nfs ~]# systemctl start nfs-server.service  #启动nfs-server

测试nfs
[root@node1 ~]# mount -t nfs 172.16.1.4:/www/htdocs /usr/share/nginx/html/  #挂载成功
[root@node1 ~]# df
Filesystem              1K-blocks    Used Available Use% Mounted on
172.16.1.4:/www/htdocs   52403200 1134336  51268864   3% /usr/share/nginx/html

[root@node1 ~]# umount /usr/share/nginx/html/

使用crmsh配置集群资源

pcs用来安装集群还可以, 但是配置集群资源, 我用了一次再也不想用了, 实在是不好用, 个人比较喜欢crmsh来配置集群, crmsh大家可以自行去下载, 安装时可能需要epel源 中的一些软件

[root@node1 ~]# yum install crmsh-2.1.4-1.1.x86_64.rpm  #安装crmsh 我们的rpm包是自行下载的


配置资源
[root@node1 ~]# crm configure
crm(live)configure# primitive webip ocf:heartbeat:IPaddr params ip=172.16.1.8
crm(live)configure# primitive nginx systemd:nginx

crm(live)configure# primitive webstore ocf:heartbeat:Filesystem params device="172.16.1.4:/www/htdocs" directory="/usr/share/nginx/html" fstype="nfs" op start timeout=60s op stop timeout=60s op monitor interval=20s timeout=40s

定义资源组
crm(live)configure# group webservice webip webstore nginx
crm(live)configure# verify
crm(live)configure# property stonith-enabled=false
crm(live)configure# commit

测试

Alt textblob.png

blob.png

blob.png

blob.png

Alt text

Alt text

总结

本文简单演示HA集群的简单实现, 非常的简单. HA最重要的是它的原理, 我以前写过一篇HA原理的博客, 大家可以看看

作者水平很低, 如果有错误及时指出, 如果你觉得本文写的好请点一波赞~(≧▽≦)/~
作者: AnyISaIln QQ: 1449472454
感谢: MageEdu

原创文章,作者:Net18-AnyISalIn,如若转载,请注明出处:http://www.178linux.com/14614

(0)
Net18-AnyISalInNet18-AnyISalIn
上一篇 2016-04-10 20:40
下一篇 2016-04-11 11:38

相关推荐

  • 利用keepalived实现主/从和主/主模式的高性能负载均衡集群

    要求: 1、使用nginx的反向代理功能实现负载均衡 2、keepalived实现高可用        第一组的虚拟地址为172.16.1.100             D设备的优先级高        第二组的虚拟地址为172.16.1.110             E设备的优先级高 3、分别实现主/从和主/主两种配置 集群拓扑:       第一种:主…

    2017-06-25
  • 22期网络班+第一周作业+深圳+王金宝

    1、描述计算机的组成及其功能? 答: 显示器和主机,显示器就不说了 主机里又有,主板,又叫主机板(mainboard)、系统板(systembourd)和母板(motherboard);它安装在机箱内,是微机最基本的也是最重要的部件之一。主板一般为矩形电路板,上面安装了组成计算机的主要电路系统,一般有BIOS芯片、I/O控制芯片、键盘和面板控制开关 接口、指…

    Linux干货 2016-08-13
  • 描述计算机的组成及其功能

    CPU:计算器,控制器,寄存器内存输入输出设备

    Linux干货 2016-08-15
  • 第一周博客作业

       本文介紹計算机的组成及其功能 、Linux各版本的联系与区别、Linux的哲学思想、Linux系统上命令的使用格式及介绍部分命令、如何在Linux系统上获取帮助信息以及Linux发行版的基础目录名称以及规定。 一、计算机的组成及其功能 1)什么是计算机? 想了解计算机的组成,首先得了解计算机的含义。计算机其实是:接收用户输入指令与数…

    Linux干货 2016-12-04
  • FHS-文件系统层级结构标准

    文件系统层级结构标准(FHS:Filesystem Hierarchy Standard) 文件系统层次结构标准(英语:Filesystem Hierarchy Standard,FHS)定义了Linux操作系统中的主要目录及目录内容。当前的版本是2.3,在2004年1月29日公布。多数Linux发行版遵从FHS标准并且声明其自身政策以维护FHS的要求。然而…

    Linux干货 2016-10-16
  • Linux 文件系统权限

    一、简述权限  文件系统的权限管理机制的建立,约束了用户对数据的操作。 1、对系统安全而言  管理员的操作权限非常大,足以破坏系统,权限机制将管理员与普通用户之间区分开,防止系统被随意破坏。 2、对用户而言  Linux是一个多用户的操作系统,不同用户间为了防止其他人破坏数据或访问数据,文件系统的权限管理是非常必要的。 二、文件…

    Linux干货 2016-08-04