设为首页 收藏本站
查看: 1720|回复: 6

[经验分享] nginx 负载均衡 + Rsync+inotify-tools 同步 +Mysql (master-master-salve)

[复制链接]

尚未签到

发表于 2013-5-17 08:54:09 | 显示全部楼层 |阅读模式

配置 nginx  负载均衡 + Rsync+inotify-tools 同步 +Mysql (master-master-salve)

安装环境:

操作系统:Centos 5.4  X64

应用软件: Nginx 1.2.7  php 5.3.22 Mysql Rsync 2.6.8   inotify-tools-3.14


主机A 192.168.1.21 Lnmp  Nginx 主web1  Mysql-master    rsync+inotify  

主机A 192.168.1.21 LNMP  Nginx web2    Mysql-master    rsync

主机A 192.168.1.21 Lnmp  Nginx web3    Mysql-slave     rsync


(我这里是测试环境所以机器都是服务都是mysql跟web没分开了)


Nginx 做负载均衡

Rsync+inotify  做数据时时同步

Mysql 5.5 master-master-slave 数据库时时同步



1 :配置负载均衡


安装lnmp 我这里就不说了


现在开始配置nginx的负载均衡


我们选中主机A做入口机器来做分流所以在主机A 的nginx配置文件加入

(注意这个要加入到Http { }下面,当然你也可以写成独立的文件,再在nginx.conf里面包进来也可以)


配置服务器列表:


(这里注视下:

nginx 的 upstream目前支持 4 种方式的分配

1)、轮询(默认)

     每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

2)、weight

     指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。

2)、ip_hash

     每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。  

3)、fair(第三方)

     按后端服务器的响应时间来分配请求,响应时间短的优先分配。  

4)、url_hash(第三方)


upstream lrm {


       server 192.168.1.22:80 weight=6;

       server 192.168.1.21:80 backup;

       server 192.168.1.23:80 down;

       #ip_hash;

       }


(注视:

down 表示单前的server暂时不参与负载

weight  默认为1.weight越大,负载的权重就越大。

max_fails :允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误

fail_timeout:max_fails 次失败后,暂停的时间。

backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。


建立虚拟主机来做代理来完成负载的目的:


  server

       {

    listen       80;            

    server_name www.lrm.com ;


  location / {


       proxy_pass    http://lrm ;    #使用定义的服务器列表

       proxy_set_header Host $host;  #一下都是设置一些代理的参数,可有可无

       proxy_set_header X-Real-IP $remote_addr;

       proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;


     }


就这样配置完成重启nginx就OK 了



2:配置文件同步

首先都要安装rsync 服务 ,在主节点A上安装rsync 加inotify-tools

yum -y install rsync


下载安装inotify-tools

wget https://github.com/downloads/rvo ... y-tools-3.14.tar.gz

tar zxvf inotify-tools-3.14.tar.gz

cd inotify-tools

./configure && make && make install


做好链接ln -sv /usr/local/lib/libinotify* /usr/lib/ 如果是64位系统 ln -sv /usr/local/lib/libinotify* /usr/lib64

要不然启动会报这个错误“/usr/local/bin/inotifywait: error while loading shared libraries: libinotifytools.so.0”


在主机B C 上配置rsync

建立rsyncd.conf 配置文件  

cat /etc/rsyncd.conf

uid = www                             #指定该模块传输文件时守护进程应该具有的uid

gid = www                             #指定该模块传输文件时守护进程应该具有的gid

use chroot = no

hosts allow =192.168.1.22 192.168.1.23 192.168.1.21   #充许任何主机连接

max connections = 10                 #客户端最大连接数,默认0(没限制)

pid file = /var/run/rsyncd.pid        #运行进程的ID写到哪里   

lock file = /var/run/rsync.lock       #lock记录文件

log file = /var/log/rsyncd.log        #日志记录文件

[lrm]   # 这里是认证的模块名,在client端需要指定

path =/usr/local/nginx/html/         # 需要做备份的目录

comment = dwg file

ignore errors                         # 可以忽略一些无关的IO错误

read only = no                       #no客户端可上传文件,yes只读

list = false

auth users = fdw                      # 认证的用户名,如果没有这行,则表明是匿名

secrets file = /etc/server.pas       # 指定认证口令文件位置


建立认证密码文件

cat /etc/server.pas

fdw:123456


chmod 600 /etc/server.pas


启动服务 rsync --daemon


然后在主机A 上建立 密码文件

cat /etc/server.pas

123456


chmod 600  /etc/server.pas


启动服务 rsync --daemon


然后在主接点 A 上创建监控脚本

监控/usr/local/nginx/html/目录的  modify,delete,create,attrib 情况有这些情况就直接推送到22 23服务器上去

cat /root/rsync.sh  

#!/bin/bash

src=/usr/local/nginx/html/


/usr/local/bin/inotifywait -mrq --timefmt '%d/%m/%y/%H:%M' --format '%T %w %f' -e modify,delete,create,attrib $src | while read file

do

rsync -vzrtopg --delete --progress --password-file=/etc/server.pas $src fdw@192.168.1.22::lrm

rsync -vzrtopg --delete --progress --password-file=/etc/server.pas $src fdw@192.168.1.23::lrm

done

(注视:

-m 是保持一直监听

-r 是递归查看目录

-q 是打印出事件

--timefmt 是指定时间的输出格式

--format 指定文件变化的详细信息

-e create,move,delete,modify,attrib 是指 “监听 创建 移动 删除 写入 权限” 事件


然后运行


nohup ./rsync.sh &


配置完成,可以是时时在A 上创建 删除文件 看服务器B C 会不会时时同步了,当然这个是单项的时时同步,根据自己需求去做双向的吧。


3:配置mysql 的master-master-slave  mysql为5.5


备注: 主机A 为master  主机B 为master 主机C 为slave


在主机A上添加 授权slave的帐号



GRANT REPLICATION SLAVE ON *.* TO ‘backup@192.168.1.22‘ IDENTIFIED BY ‘123456’;


GRANT REPLICATION SLAVE ON *.* TO ‘backup@192.168.1.23‘ IDENTIFIED BY ‘123456’;



在A 上设置要同步的数据库和不同步的数据库

在my.cnf 上添加

log-bin=mysql-bin  #必须开启的二进制日志

server-id = 1      #主ID

log-bin=/var/log/mysql/updatelog #日志文件路径

binlog-do-db=test  #要同步的数据库  

binlog-do-db=lrm   #要同步的数据库  

binlog-ignore-db=mysql #不要同步的数据库

#replicate-do-db=test  #这些是当slave的时候要添加的要复制的数据库

#replicate-do-db=lrm   #这些是当slave的时候要添加的要复制的数据库

#replicate-ignore-db=mysql  #这些是当slave的时候要添加的不要复制的数据库

expire_logs_days = 7   #保存日志的天数

slave-skip-errors = 1062 #跳过错误


然后重启mysql

在查看

mysql> show master status;

+------------------+----------+--------------+------------------+

| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+------------------+----------+--------------+------------------+

| updatelog.000001 |  107| test,lrm     | mysql            |

+------------------+----------+--------------+------------------+

1 row in set (0.00 sec)

(然后现在就不要动他了)


再在主机B  C 上添加

#log-bin=mysql-bin  #必须开启的二进制日志

server-id = 2      #主ID

log-bin=/var/log/mysql/updatelog #日志文件路径

#binlog-do-db=test  #要同步的数据库  当master的时候要开启的

#binlog-do-db=lrm   #要同步的数据库  当master的时候要开启的

#binlog-ignore-db=mysql #不要同步的数据库 当master的时候要开启的

replicate-do-db=test  #这些是当slave的时候要添加的要复制的数据库

replicate-do-db=lrm   #这些是当slave的时候要添加的要复制的数据库

replicate-ignore-db=mysql  #这些是当slave的时候要添加的不要复制的数据库

expire_logs_days = 7   #保存日志的天数

slave-skip-errors = 1062 #跳过错误


然后重启mysql

进入控制台

mysql>change master to master_host='192.168.1.21',master_user='rsync',master_password='123456',master_log_file='updatelog.000001',master_log_pos=107;

mysql> slave start

mysql> show slave status\G

*************************** 1. row ***************************

              Slave_IO_State: Waiting for master to send event

                 Master_Host: 192.168.1.21

                 Master_User: rsync

                 Master_Port: 3306

               Connect_Retry: 60

             Master_Log_File: updatelog.000001

         Read_Master_Log_Pos: 107

              Relay_Log_File: mysqld-relay-bin.000001

               Relay_Log_Pos: 107

       Relay_Master_Log_File: updatelog.000001

           Slave_IO_Running: Yes

           Slave_SQL_Running: Yes

             Replicate_Do_DB: test,lrm

         Replicate_Ignore_DB: mysql

          Replicate_Do_Table:

      Replicate_Ignore_Table:

     Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table:

                  Last_Errno: 0

                  Last_Error:

                Skip_Counter: 0

         Exec_Master_Log_Pos: 107

             Relay_Log_Space: 107

             Until_Condition: None

              Until_Log_File:

               Until_Log_Pos: 0

          Master_SSL_Allowed: No

          Master_SSL_CA_File:

          Master_SSL_CA_Path:

             Master_SSL_Cert:

           Master_SSL_Cipher:

              Master_SSL_Key:

       Seconds_Behind_Master: 0

Master_SSL_Verify_Server_Cert: No

               Last_IO_Errno: 0

               Last_IO_Error:

              Last_SQL_Errno: 0

              Last_SQL_Error:

Replicate_Ignore_Server_Ids:

            Master_Server_Id: 1

1 row in set (0.00 sec)


看到这两个

Slave_IO_Running: Yes

Slave_SQL_Running: Yes


说明同步完成。


然后再来做主机B跟主机A互为master

在主机B上创建同步帐号


GRANT REPLICATION SLAVE ON *.* TO ‘backup@192.168.1.21‘ IDENTIFIED BY ‘123456’;



在主机A的my.cnf上添加

#replicate-do-db=test  #这些是当slave的时候要添加的要复制的数据库

#replicate-do-db=lrm   #这些是当slave的时候要添加的要复制的数据库

#replicate-ignore-db=mysql  #这些是当slave的时候要添加的不要复制的数据库

重启

在主机B的my.cnf上添加

#binlog-do-db=test  #要同步的数据库  当master的时候要开启的

#binlog-do-db=lrm   #要同步的数据库  当master的时候要开启的

#binlog-ignore-db=mysql #不要同步的数据库 当master的时候要开启的

重启

在主机B查看mysql> show master status;  

+------------------+----------+--------------+------------------+

| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+------------------+----------+--------------+------------------+

| updatelog.000004 |      107 | test,lrm     | mysql            |

+------------------+----------+--------------+------------------+

1 row in set (0.00 sec)

然后在主机A 上做

mysql>change master to master_host='192.168.1.22',master_user='rsync',master_password='123456',master_log_file='updatelog.000004',master_log_pos=107;

mysql> slave start

mysql> show slave status\G

*************************** 1. row ***************************

              Slave_IO_State: Waiting for master to send event

                 Master_Host: 192.168.1.22

                 Master_User: rsync

                 Master_Port: 3306

               Connect_Retry: 60

             Master_Log_File: updatelog.000004

         Read_Master_Log_Pos: 107

              Relay_Log_File: mysqld-relay-bin.000004

               Relay_Log_Pos: 107

       Relay_Master_Log_File: updatelog.000004

           Slave_IO_Running: Yes

           Slave_SQL_Running: Yes

             Replicate_Do_DB: test,lrm

         Replicate_Ignore_DB: mysql

          Replicate_Do_Table:

      Replicate_Ignore_Table:

     Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table:

                  Last_Errno: 0

                  Last_Error:

                Skip_Counter: 0

         Exec_Master_Log_Pos: 107

             Relay_Log_Space: 107

             Until_Condition: None

              Until_Log_File:

               Until_Log_Pos: 0

          Master_SSL_Allowed: No

          Master_SSL_CA_File:

          Master_SSL_CA_Path:

             Master_SSL_Cert:

           Master_SSL_Cipher:

              Master_SSL_Key:

       Seconds_Behind_Master: 0

Master_SSL_Verify_Server_Cert: No

               Last_IO_Errno: 0

               Last_IO_Error:

              Last_SQL_Errno: 0

              Last_SQL_Error:

Replicate_Ignore_Server_Ids:

            Master_Server_Id: 1

1 row in set (0.00 sec)

看到这两个

Slave_IO_Running: Yes

Slave_SQL_Running: Yes


说明同步完成。现在可以操作任意两个master的数据库三台在数据库的数据都是一样的。


到此配置 nginx  负载均衡 + Rsync+inotify-tools 同步 +Mysql (master-master-salve) 完成,如果有不对的地方还请提出谢谢。

这里发现个问题就是我以前用mysql 5.1的时候在做同步的时候配置文里面是要填写 主服务器的IP 帐号 密码等的的。在mysql5.5 只要第一次在控制台输入就OK 了,本人重启也试过了没问题。




运维网声明 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-5985-1-1.html 上篇帖子: 玩转Nginx - Nginx + Proxy Cache 快速搭建 下篇帖子: Nginx使用webbench进行压力测试

尚未签到

发表于 2013-5-19 16:36:59 | 显示全部楼层
月经不仅仅是女人的痛苦,也是男人的痛苦。

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

累计签到:1 天
连续签到:1 天
发表于 2013-5-22 07:29:40 | 显示全部楼层
下雨了,别忘了打伞,湿身是小,淋病就麻烦啦*^_^*

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

尚未签到

发表于 2013-5-26 12:20:17 | 显示全部楼层
昨天,系花对我笑了一下,乐得我晚上直数羊,一只羊,两只羊,三只羊……

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

尚未签到

发表于 2013-5-30 20:37:17 | 显示全部楼层
与时俱进,你我共赴高潮!

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

尚未签到

发表于 2013-6-2 03:32:37 | 显示全部楼层
我是个凑数的。。。

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

尚未签到

发表于 2013-6-2 07:00:06 | 显示全部楼层
站的更高,尿的更远。

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

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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