mysql-mmm安装,测试

platform: rhel 5.6
software: mysql-mmm-2.2.1.tar.gz
         mysql-5.1.59.tar.gz
//文档后面部分直接参考    《MMM Installation Guide 》
                            //作者:andy.feng
                            //网名:FH.CN

mysql-mmm architecture:


确定IP
mysql-a                     
192.168.56.101       master1    mysql-server-id=1

mysql-b    
192.168.56.103        master2    mysql-server-id=2    

mysql-slave
192.168.56.105        slave    mysql-server-id=3

mysql-monitor
192.168.56.99        mmm_mon    

虚拟IP
192.168.56.200        writer    
192.168.56.201        reader
192.168.56.203        reader
192.168.56.205        reader

//install mysql
#tar xf mysql-5.1.59.tar.gz
#cd  mysql-5.1.59
#useradd mysql -s /sbin/nologin
#mkdir -p /data/mysql_db
#./configure prefix=/usr/local/mysql localstatedir=/data/mysql_db --with-extra-charsets=utf8,gb2312,gbk �Cwith―pthread enable-thread-safe-client && make && make install

cp /root/mysql-5.1.59/support-files/my-large.cnf         /etc/my.cnf
vi /etc/my.cnf //issue the “server-id”
db1 修改 my.cnf,确定有以下内容

server-id = 1
\\修改系统启动默
log-bin=mysql-bin
binlog_format=ROW
log-slave-updates
sync_binlog=1
auto_increment_increment=2
auto_increment_offset=1
example:

[mysqld]
server-id = 1
skip-locking
log-bin=mysql-bin
binlog_format=ROW
log-slave-updates
sync_binlog=1
auto_increment_increment=2
auto_increment_offset=1


db2 修改 my.cnf,确定有以下内容
server-id = 2
log-bin=mysql-bin
binlog_format=ROW
log-slave-updates
sync_binlog=1
auto_increment_increment=2
auto_increment_offset=2

db3 修改 my.cnf,确定有以下内容
server-id = 3
log-bin=mysql-bin
log-slave-updates

db4 修改 my.cnf,确定有以下内容
server-id = 4
log-bin=mysql-bin
log-slave-updates
    
chown mysql: /usr/local/mysql �CR
/usr/local/mysql/bin/mysql_install_db �Cuser=mysql&
/usr/local/mysql/bin/mysqld_safe �Cuser=mysql&


配置msyql 双主并测试
mysql-server:
grant replication super,slave on *.* to <trust-name>@<trust-mysql-server-ip> identified by '<password>';

slave-mysql-server:
change master to
master_host='<master-ip>' ,
master_user='<trust-name>' ,
master_password='<password>'
master_log_file='<master-log-file-name>' ,
master_log_pos=<position>;

slave start;
show slave status\G
    Slave_IO_Running: Yes
    Slave_SQL_Running: Yes

安装mysql-mmm
1.    安装mysql-mmm-agent
2.    agent机器上要安装iproute 包,
3.    如果手工编译的 MYSQL,一定要把加载 MYSQL 的 LIB
        # ECHO "/USR/LOCAL/MYSQL/LIB/MYSQL/" >> /ETC/LD.SO.CONF
        #LDCONFIG


4.    安装perl库文件(cpan),cpan 分两种安装方式,一种是在线安装, 如下面所示;另一种是手动安装,手动安装需要根据安装模块 search.cpan.org 上 下载下来,然后再安装。
4.1        在 agent机器上都安装如下 perl 库(mysql-agent 需求的 perl 库)
有些 perl 库,特别是红色的三个库系统默认应该是有的,可以通过以下方法查看是否,安装,如果安装,就不必要安装,因为
安装这三个库比较麻烦,特别 DBD::mysql,需要下载软件手工编译
确认是否安装一下模块:
#find /usr/lib/perl5/ -name mysql.pm (rhel默认没有,需要手动安装DBD-mysql)
#find /usr/lib/perl5/ -name stat.pm
#find /usr/lib/perl5/ -name Basename.pm
红色的应该是系统自带的:
DBI and DBD::mysql (如果没有,这个要先装)
在 PERL MAKEFILE.PL 的时候,一定要指定你定制的一些 MYSQL 的信息
#PERL MAKEFILE.PL --MYSQL_CONFIG=/USR/LOCAL/MYSQL/BIN/MYSQL_CONFIG --WITH- MYSQL=/USR/LOCAL/MYSQL/
一定要 MAKE TEST,通过了再 MAKE INSTALL
File::Basename
File::stat
File::Temp
Net::Ping (放在最后安装)
Algorithm::Diff
Class::Singleton
Log::Log4perl
Log::Dispatch (需要安装ExtUtils-MakeMaker,Params-Validate,Sys-Syslog)

Mail:Send (需要安装 TimeDate,Pod::Escapes,Pod-Simple,ExtUtils-CBuilder,ExtUtils- Par***S,Test-Harness,Compress-Raw-Zlib,Compress-Raw-Bzip2,IO- Compress,Package-Constants,IO-Zlib,Text-Diff,Archive-Tar,podlators,Pod- Readme,ExtUtils-Install,Module::Metadata,Test-Simple,Perl-OSType,Module- Build,Test::Pod,MailTools)

Proc::Daemon
Thread::Queue(在 rhel5.6 版本中,需要先装 threads,再装 threads-shared,再装 threads-queue;依据提示 安装版本,否则后面到 mysql-mmm-monitor 无法启动)

Time::HiRes

=========================================================
Algorithm-Diff-1.1902.tar.gz     ExtUtils-Par***S-2.21.tar.gz  Module-Metadata-1.000002.tar.gz  podlators-2.3.1.tar.gz              Test-Simple-0.96.tar.gz
Archive-Tar-1.50.tar.gz          File-Stat-0.01.tar.gz         mysql-5.1.59.tar.gz              Pod-Readme-0.10.tar.gz              Text-Diff-0.35.tar.gz
Class-Singleton-1.4.tar.gz       File-Temp-0.22.tar.gz         mysql-mmm-2.2.1.tar.gz           Pod-Simple-3.08.tar.gz              Thread-Queue-2.11.tar.gz
Compress-Raw-Bzip2-2.017.tar.gz  IO-1.24.tar.gz                Net-ARP-1.0.6.tgz                Proc-Daemon-0.14.tar.gz             threads-1.71.tar.gz
Compress-Raw-Zlib-2.017.tar.gz   IO-Compress-2.017.tar.gz      Net-Ping-2.36.tar.gz             shell.sh                            threads-shared-1.27.tar.gz
DBD-mysql-4.020.tar.gz           IO-Interface-1.05.tar.gz      Package-Constants-0.02.tar.gz    Socket-1.95.tar.gz                  TimeDate-1.20.tar.gz
Devel-Symdump-2.07.tar.gz        IO-Zlib-1.09.tar.gz           Params-Validate-0.24.tar.gz      Sys-Syslog-0.25.tar.gz              Time-HiRes-1.9724.tar.gz
ExtUtils-CBuilder-0.27.tar.gz    Log-Dispatch-2.27.tar.gz      perl-DBI-1.52-2.el5.i386.rpm     Test-Harness-3.16.tar.gz
ExtUtils-Constant-0.16.tar.gz    Log-Log4perl-1.34.tar.gz      Perl-OSType-1.000.tar.gz         Test-Pod-1.44.tar.gz
ExtUtils-Install-1.54.tar.gz     MailTools-2.08.tar.gz         Pod-Coverage-0.20.tar.gz         Test-Pod-Coverage-1.08.tar.gz
ExtUtils-MakeMaker-6.62.tar.gz   Module-Build-0.3800.tar.gz    Pod-Escapes-1.04.tar.gz          Test-Portability-Files-0.05.tar.gz
=========================================================

5.    安装mysql-mmm
5.1 tar xf mysql-mmm.<version>.tar.gz
5.2 make install

6.    启动mysql-mmm-agent(是否能正常运行,能运行后,再关闭)
    /etc/init.d/mysql-mmm-agent    start

安装脚本:
#! /bin/bash
pathname="/usr/lib/perl5/site_perl/5.8.8/i386-linux-thread-multi/DBD"
cpanpath=/root/cpan
echo "/usr/local/mysql/lib/mysql/" >> /etc/ld.so.conf
ldconfig
file1="DBD-mysql-4.020.tar.gz"
file2="perl-DBI-1.52-2.el5.i386.rpm"
ls $cpanpath > /root/file
while read i
do
        file3=$(rpm -qa perl-DBI |awk -F "1" '{print $1}')
        if [ "$file3" != "perl-DBI-" ]
        then
                rpm -ivh $cpanpath/$i
                sleep 2
                
        else
                if [ -d $pathname ]
                then
                        tar xf $cpanpath/$i -C /tmp && cd /tmp/$(echo $i |awk -F ".tar" '{print $1}')

                        perl Makefile.PL && make test && make install
                        mv $cpanpath/$i /root
                else
                        if [ "$i" = "$file1" ]
                        then
                                tar xf $cpanpath/$i -C /tmp && cd /tmp/$(echo $i |awk -F ".tar" '{print $1}')
                                perl Makefile.PL --mysql_config=/usr/local/mysql/bin/mysql_config --with-mysql=/usr/local/mysql && make test && make install  && mv $cpanpath/$i /root
                                continue
                        fi
                fi
        fi

done < /root/file

for j in `ls /root/cpan`
do
         tar xf $cpanpath/$j -C /tmp && cd /tmp/$(echo $j |awk -F ".tar" '{print $1}')
         perl Makefile.PL && make test && make install
         mv $cpanpath/$j /root
done

tar xf /root/mysql-mmm* -C /tmp && cd /tmp/mysql-mmm* && make install
rm -rf /root/file



配 置 MYSQL-MMM-AGENTD
添加 agentd 使用的 mysql 用户,db1,db2,db3 都要添加
db1,db2,db3:
mysql>grant super,replication client,process on *.* to 'mmm_agent'@'192.168.56.101' identified by 'mmm_agent';
mysql>grant super,replication client,process on *.* to 'mmm_agent'@'192.168.56.103' identified by 'mmm_agent';
mysql>grant super,replication client,process on *.* to 'mmm_agent'@'192.168.56.105' identified by 'mmm_agent';
mysql>grant super,replication client,process on *.* to 'mmm_agent'@'192.168.56.99' identified by 'mmm_agent';


修改mysql-mmm配置文件
db1:
# cat /etc/mysql-mmm/mmm_agent.conf    
include mmm_common.conf
this db1
# cat /etc/mysql-mmm/mmm_common.conf
active_master_role      writer


<host default>
        cluster_interface                       eth0        

        pid_path                                /var/run/mmm_agentd.pid
        bin_path                                /usr/lib/mysql-mmm/

        replication_user                        slave
        replication_password                    123456

        agent_user                              mmm_agent
        agent_password                          123456

      
</host>

<host db1>
        ip                                      192.168.56.101
        mode                                    master
        peer                                    db2
</host>

<host db2>
        ip                                      192.168.56.103
        mode                                    master
        peer                                    db1
</host>

<host db3>
        ip                                      192.168.56.105
        mode                                    slave
</host>


<role writer>
        hosts                                   db1, db2
        ips                                     192.168.56.200
        mode                                    exclusive
</role>

<role reader>
        hosts                                   db1, db2,db3
        ips                                     192.168.56.201,192.168.56.203,192.168.56.205
        mode                                    balanced
</role>

将db1的/etc/mysql-mmm/mmm_common.conf文件拷贝到db2,db3,db4相同的位置,拷贝方法自定义

db2:
# cat /etc/mysql-mmm/mmm_agent.conf
include mmm_common.conf
this db2
db3:
# cat /etc/mysql-mmm/mmm_agent.conf     
include mmm_common.conf
this db3

启动MYSQL-mmm_agent
db1,db2,db3:
# /etc/init.d/mysql-mmm-agent start
Daemon bin: '/usr/sbin/mmm_agentd'
Daemon pid: '/var/run/mmm_agentd.pid'
Starting MMM Agent daemon... Ok

# /etc/init.d/mysql-mmm-agent status
Daemon bin: '/usr/sbin/mmm_agentd'
Daemon pid: '/var/run/mmm_agentd.pid'
Checking MMM Agent process: running.

[root@(155/15)~]# ps aux | grep mmm
root     26758  0.0  0.1  11524  6912 ?        S    14:52   0:00 mmm_agentd
root     26759  0.0  0.1  11568  7088 ?        S    14:52   0:00 mmm_agentd
root     26798  0.0  0.0   3920   672 pts/1    S+   14:55   0:00 grep mmm
[root@(155/15)~]# netstat -tulnp | grep mmm
tcp        0      0 192.168.56.101:9989              0.0.0.0:*                   LISTEN      26759/mmm_agentd

[root@(155/15)~]# /etc/init.d/mysql-mmm-agent --help
Daemon bin: '/usr/sbin/mmm_agentd'
Daemon pid: '/var/run/mmm_agentd.pid'
Usage: /etc/init.d/mysql-mmm-agent {start|stop|restart|status}

Note:如果不能启动,可以查看/var/log/mysql-mmm/mmm_agentd.log 文件的提示,或者启动时候的报错,最大的可能是perl对应模块没有安装成功,成功安装对应的模块就可以解决问题了。


配置MYSQL-MMM-monitor
创建mmm-monitor使用的mysql用户,在db1,db2,db3上
db1,db2,db3:
mysql>grant replication client on *.* to 'mmm_monitor'@'192.168.56.99' identified by '123456';

在实际使用中可以简化用户,让复制,agent,monitor使用同一个用户,注意权限就可以行了。下面配置monitor
db4:
# cat /etc/mysql-mmm/mmm_mon.conf
include mmm_common.conf

<monitor>
        ip                                      10.1.1.12
        pid_path                                /var/run/mmm_mond.pid
        bin_path                                /usr/lib/mysql-mmm/
        status_path                             /var/lib/misc/mmm_mond.status
        ping_ips                                192.168.56.105, 192.168.56.103, 192.168.56.101
</monitor>

<host default>
        monitor_user                    mmm_monitor
        monitor_password                mmm_monitor
</host>

debug 0

启动MYSQL-MMM-monitor
# /etc/init.d/mysql-mmm-monitor start
Daemon bin: '/usr/sbin/mmm_mond'
Daemon pid: '/var/run/mmm_mond.pid'
Starting MMM Monitor daemon: Ok

[root@(140/12)~]# /etc/init.d/mysql-mmm-monitor --help
Daemon bin: '/usr/sbin/mmm_mond'
Daemon pid: '/var/run/mmm_mond.pid'
Usage: /etc/init.d/mysql-mmm-monitor {start|stop|restart|status}

# ps aux | grep mmm
root      2737  0.0  0.2  13764  8892 ?        S    15:10   0:00 mmm_mond
root      2738  1.3  0.9 108480 39992 ?        Sl   15:10   0:00 mmm_mond
root      2745  0.4  0.1  10676  6668 ?        S    15:10   0:00 perl /usr/lib/mysql-mmm//monitor/checker ping_ip
root      2748  0.5  0.1  12860  7776 ?        S    15:10   0:00 perl /usr/lib/mysql-mmm//monitor/checker mysql
root      2750  0.4  0.1  10676  6668 ?        S    15:10   0:00 perl /usr/lib/mysql-mmm//monitor/checker ping
root      2752  0.5  0.1  12860  7824 ?        S    15:10   0:00 perl /usr/lib/mysql-mmm//monitor/checker rep_backlog
root      2754  0.5  0.1  12860  7820 ?        S    15:10   0:00 perl /usr/lib/mysql-mmm//monitor/checker rep_threads

管理MYSQL-MMM-monitor
查看mmm集群节点的状态:
db4:
# mmm_control mode
ACTIVE

# mmm_control show
  db1(192.168.56.101) master/AWAITING_RECOVERY. Roles:
  db2(192.168.56.103) master/AWAITING_RECOVERY. Roles:
  db3(192.168.56.105) slave/AWAITING_RECOVERY. Roles:
现在都处于AWATING_RECOVERY状态
我们将db1和db2两个master置于ONLINE状态
# mmm_control set_online db1
OK: State of 'db1' changed to ONLINE. Now you can wait some time and check its new roles!
# mmm_control set_online db2
OK: State of 'db2' changed to ONLINE. Now you can wait some time and check its new roles!
# mmm_control show
  db1(192.168.56.101) master/ONLINE. Roles: reader(192.168.56.203), writer(192.168.56.200)
  db2(192.168.56.103) master/ONLINE. Roles: reader(192.168.56.201), reader(192.168.56.205)
  db3(192.168.56.105) slave/AWAITING_RECOVERY. Roles:。
现在mysql-mmm两个master的模式已经搭建完成,我们对所有节点做一次检查:
# mmm_control checks all
db2  ping         [last change: 2011/05/18 15:10:15]  OK
db2  mysql        [last change: 2011/05/18 15:10:15]  OK
db2  rep_threads  [last change: 2011/05/18 15:10:15]  OK
db2  rep_backlog  [last change: 2011/05/18 15:10:15]  OK: Backlog is null
db3  ping         [last change: 2011/05/18 15:10:15]  OK
db3  mysql        [last change: 2011/05/18 15:10:15]  OK
db3  rep_threads  [last change: 2011/05/18 15:10:15]  ERROR: Replication is not set up
db3  rep_backlog  [last change: 2011/05/18 15:10:15]  ERROR: Replication is not set up
db1  ping         [last change: 2011/05/18 15:10:15]  OK
db1  mysql        [last change: 2011/05/18 15:10:15]  OK
db1  rep_threads  [last change: 2011/05/18 15:10:15]  OK
db1  rep_backlog  [last change: 2011/05/18 15:10:15]  OK: Backlog is null

db1db2已经正常了,只有db3复制是失败的,因为我们还没有配置,只要将db3作为slave加入其中,就完成两个master多个slave的架构。


你可能感兴趣的:(操作系统)