`
stevencage
  • 浏览: 10439 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

MySql主从复制实现

 
阅读更多

系统环境:

master:192.168.59.130  Ubuntu12.04  MySql 5.5.29

slave:192.168.59.131  Ubuntu12.04  MySql 5.5.29

一、安装Mysql

1.下载mysql-5.5.29-debian6.0-i686.deb安装包,并下载libaio-dev_0.3.109-3_i386.deb,libaio1_0.3.109-3_i386.deb两个依赖库

 

2.安装deb包

sudo dpkg -i mysql-5.5.29-debian6.0-i686.deb

sudo dpkg -i libaio1_0.3.109-3_i386.deb

sudo dpkg -i libaio-dev_0.3.109-3_i386.deb
MySQL server 被初始化在 /opt/mysql/server-5.5

 

3.配置MySql

新建用户组和用户

groupadd mysql
useradd -r -g mysql mysql

创建mysql目录链接并修改data权限
ln -s /opt/mysql/server-5.5 /usr/local/mysql
sudo mkdir /usr/local/mysql/data
sudo chown -R mysql. /usr/local/mysql/data

初始化数据库
sudo /usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
将mysqld的启动shell程序放到系统服务目录下
sudo cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
将 mysql 的配置文件放到系统配置/etc目录下,mysql在全局作用范围要使用该配置文件
sudo cp /usr/local/mysql/support-files/my-medium.cnf /etc/my.cnf

 

4.启动MySql

service mysql start
更改 mysql root 管理员密码
sudo /usr/local/mysql/bin/mysqladmin -u root password [你希望设置的密码]
测试是否可以登录 mysql
sudo /usr/local/mysql/bin/mysql -u root -p [可选数据库名称]

 

 

二、配置主从复制

1.master服务器(192.168.59.130)上的操作

启动mysql服务
service mysql start
通过命令行登录管理MySQL服务器
/usr/local/mysql/bin/mysql -uroot -p
授权给从数据库服务器192.168.59.131
mysql> GRANT REPLICATION SLAVE ON *.* to 'rep1'@'192.168.59.131' identified by ‘password’;
查询主数据库状态
Mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000002 | 644 | | |
+------------------+----------+--------------+------------------+
记录下 FILE 及 Position 的值,在后面进行从服务器操作的时候需要用到。

 

2.slave服务器(192.168.59.131)上的操作

修改从服务器的配置文件/etc/my.cnf
将 server-id = 1修改为 server-id = 10,并确保这个ID没有被别的MySQL服务所使用。

启动mysql服务
service mysql start

 

通过命令行登录管理MySQL服务器
/usr/local/mysql/bin/mysql -uroot -p

 

执行同步SQL语句
mysql> change master to
master_host=’192.168.59.130’,
master_user=’rep1’,
master_password=’password’,
master_log_file=’mysql-bin.000002’,
master_log_pos=644;

 

正确执行后启动Slave同步进程
mysql> start slave;

主从同步检查
mysql> show slave status\G

其中Slave_IO_Running 与 Slave_SQL_Running 的值都必须为YES,才表明状态正常。

 

3.验证主从复制效果

主服务器上的操作
在主服务器上创建数据库first_db
mysql> create database first_db;
Query Ok, 1 row affected (0.01 sec)

在主服务器上创建表first_tb
mysql> create table first_tb(id int(3),name char(10));
Query Ok, 1 row affected (0.00 sec)

在主服务器上的表first_tb中插入记录
mysql> insert into first_tb values (001,’myself’);
Query Ok, 1 row affected (0.00 sec)

在从服务器上查看
mysql> show databases;
=============================
+--------------------+
| Database |
+--------------------+
| information_schema |
| first_db |
| mysql |
| performance_schema |
| test |
+--------------------+
5 rows in set (0.01 sec)
=============================
数据库first_db已经自动生成

mysql> use first_db
Database chaged

mysql> show tables;
=============================
+--------------------+
| Tables_in_first_db |
+--------------------+
| first_tb |
+--------------------+
1 row in set (0.02 sec)
=============================
数据库表first_tb也已经自动创建

mysql> select * from first_tb;
=============================
+------+------+
| id | name |
+------+------+
| 1 | myself |
+------+------+
1 rows in set (0.00 sec)
=============================
记录也已经存在

由此,整个MySQL主从复制的过程就完成了。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics