Chinaunix首页 | 论坛 | 博客
  • 博客访问: 349462
  • 博文数量: 93
  • 博客积分: 2322
  • 博客等级: 大尉
  • 技术积分: 1600
  • 用 户 组: 普通用户
  • 注册时间: 2012-08-27 10:23
文章分类

全部博文(93)

文章存档

2018年(12)

2012年(81)

分类: LINUX

2012-08-28 15:07:33

[MySQL集群架构] mysql主主+lvs

测试机2台,分别为A,B,系统均为AS4。A的IP:192.168.17.21,B的IP:192.168.17.53。

1:安装mysql。

分别在A,B上执行

[root@data1 ~]# cd /home

[root@data1 ~]# tar zxvfmysql-5.1.32.tar.gz

[root@data1 ~]# cd mysql-5.1.32

[root@data1 ~]# ./configure --prefix=/usr/local/mysql--with-extra-charsets=all --enable-thread-safe-client --with-plugin-partition

[root@data1 ~]# make

[root@data1 ~]# make install

[root@data1 ~]#/usr/local/mysql/bin/mysql_install_db --user=mysql

[root@data1 ~]# cp support-files/my-medium.cnf/etc/my.cnf

[root@data1 ~]# cd /usr/local/mysql/

[root@data1 ~]# chown -R root .

[root@data1 ~]# chown -R mysql var

[root@data1 ~]# chgrp -R mysql .

[root@data1 ~]#/usr/local/mysql/bin/mysqld_safe --user=mysql &

[root@data1 ~]# /usr/local/mysql/bin/mysqladmin-uroot password newpasswd

复制代码

2:A,B互为主从

AB上分别添加复制用户,方便起见,用root测试。

 

mysql> GRANT ALL PRIVILEGES ON *.* TO[email=root@]root@"%[/email]" IDENTIFIED BY"newpasswd"  WITH GRANT OPTION;

mysql> flush privileges;

 

A上,修改my.cnf文件,[mysqld]下添加:

.

.

.

auto-increment-increment = 2

auto-increment-offset = 2

server-id = 10

log-error = /usr/local/mysql/var/data1.err

log-bin =/usr/local/mysql/var/mysql-master-bin.log

binlog-do-db = db1

binlog-do-db = db2

binlog-do-db = db3

server-id = 2

master-host = 192.168.17.21

master-user = root

master-password = newpasswd

master-port = 3306

master-connect-retry=60

replicate-do-db=db1

replicate-do-db=db2

replicate-do-db=db3

log-bin=/usr/local/mysql/var/mysql-slave-bin.log

复制代码

B上,修改my.cnf文件,[mysqld]下添加:

auto-increment-increment = 2

auto-increment-offset = 1

server-id = 1

log-error = /usr/local/mysql/var/data2.err

log-bin =/usr/local/mysql/var/mysql-master-bin.log

binlog-do-db = db1

binlog-do-db = db2

binlog-do-db = db3

server-id = 20

master-host = 192.168.17.21

master-user = root

master-password = newpasswd

master-port = 3306

master-connect-retry=60

replicate-do-db=db1

replicate-do-db=db2

replicate-do-db=db3

log-bin=/usr/local/mysql/var/mysql-slave-bin.log

复制代码

A,B上重新启动mysql。

[root@data1 ~]#mysqladmin -uroot-pnewpasswd shutdown

[root@data1~]#/usr/local/mysql/bin/mysqld_safe &

A上进入mysql,并查看master状态

[root@data1 ~]# mysql -uroot -pnewpasswd

mysql> show master status;

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

| File                   | Position |Binlog_Do_DB                   |Binlog_Ignore_DB |

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

| mysql-slave-bin.000018 | 44305519 |db1,db2,db3                    |                  |

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

进入B,设置B为A的从。

[root@data2 ~]# mysql -uroot -pnewpasswd

mysql>slave stop;

mysql>change master to 

mysql>master_host='192.168.17.21',

mysql>master_user='root',

mysql>master_password='newpasswd',

mysql>master_port=3308,

mysql>master_log_file='mysql-slave-bin.000018',

mysql>master_log_pos=44305519;

mysql>slave start;

mysql> show master status;

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

| File                   | Position |Binlog_Do_DB                   |Binlog_Ignore_DB |

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

| mysql-slave-bin.000010 | 42354594 |db1,db2,db3                    |                  |

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

1 row in set (0.00 sec)

进入A:

mysql>slave stop;

mysql>change master to 

mysql>master_host='192.168.17.53',

mysql>master_user='root',

mysql>master_password='newpasswd',

mysql>master_port=3308,

mysql>master_log_file='mysql-slave-bin.000010',

mysql>master_log_pos=42354594;

mysql>slave start;

复制代码

3:安装LVS

A上虚拟一个网卡,IP地址为192.168.17.88,即VIP。

[root@data1 ~] touch /etc/sysconfig/network-scripts/ifcfg-eth0:1

[root@data1 ~] vi/etc/sysconfig/network-scripts/ifcfg-eth0:1

 

 

DEVICE=eth0:1

BOOTPROTO=none

HWADDR=

ONBOOT=yes

TYPE=Ethernet

IPADDR=192.168.17.88

NETMASK=255.255.255.0

USERCTL=no

IPV6INIT=no

PEERDNS=no

复制代码

[root@data1 ~] ifup eth0:1

AB上分别执行lvs.sh,内容为:

#!/bin/bash 

#description : start realserver  

VIP=203.110.169.25

/sbin/ifconfig lo:0 $VIP broadcast $VIPnetmask 255.255.255.255 up 

/sbin/route add -host $VIP dev lo:0 

echo "1">/proc/sys/net/ipv4/conf/lo/arp_ignore 

echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce

echo "1">/proc/sys/net/ipv4/conf/all/arp_ignore 

echo "2">/proc/sys/net/ipv4/conf/all/arp_announce 

sysctl -p

复制代码

A,B上分别安装ipvsadm和piranha:

[root@data1 ~] cd /home/lvs

[root@data1 lvs]# rpm -ivhipvsadm-1.24-6.1.i386.rpm

[root@data1 lvs]# rpm -ivhpiranha-0.8.2-1.i386.rpm

[root@data1 lvs]#/usr/sbin/piranha-passwd  

New Password:  

Verify: 

Updating password for user piranha 

[root@data1 lvs]# service piranha-guirestart 

Shutting down piranha-gui: [  OK  ] 

Starting piranha-gui: [  OK  ] 

[root@data1 lvs]# chkconfig piranha-gui on

复制代码

登陆A的piranha进行配置,。

把A的/etc/sysconfig/ha/lvs.cf复制到B上。

具体配置如下:

serial_no = 14

primary = 192.168.17.21

service = lvs

backup_active = 1

backup = 192.168.17.53

heartbeat = 1

heartbeat_port = 539

keepalive = 6

deadtime = 18

network = direct

debug_level = NONE

monitor_links = 0

virtual mysql {

     active = 1

     address = 192.168.17.88 eth0:1

     vip_nmask = 255.255.255.0

     port = 3306

     use_regex = 0

     load_monitor = none

     scheduler = wlc

     protocol = tcp

     timeout = 6

     reentry = 15

     quiesce_server = 0

     server 21 {

         address = 192.168.17.21

         active = 1

         weight = 1

     }

     server 53 {

          address = 192.168.17.53

         active = 1

         weight = 1

     }

}

复制代码

AB上分别执行:

[root@data1 lvs]# service pulse start

至此,over。

 

测试了几天,进行了大量的数据库操作,至今没有报错。

方法虽然很简单,但是感觉蛮实用。

测试到月底,如果可行就开始上线。

阅读(1252) | 评论(0) | 转发(0) |
0

上一篇:XEN虚拟机复制

下一篇:centos_rhcs

给主人留下些什么吧!~~