数据库

 首页 > 数据库 > mariadb > MySQL服务器主从复制和读写分离设置方法

MySQL服务器主从复制和读写分离设置方法

分享到:
【字体:
导读:
         摘要:1,mysql的配置mysql的配置我就不多说了,看我另一篇文章CentOS5.x,6.0编译安装Nginx1.2.3+MySQL5.5.15+PHP5.3.6我是再这个环境下做测试的,我是配置了1台。利用VMwareWorkstation拷贝出来多台服务器的,所以环境绝对一样。2,场景描述主数据库服务器...

MySQL服务器主从复制和读写分离设置方法
1,mysql的配置
mysql的配置我就不多说了,看我 另一篇文章 

CentOS 5.x,6.0编译安装Nginx1.2.3+MySQL5.5.15+PHP5.3.6 我是再这个环境下做测试的,我是配置了1台。利用VMware Workstation拷贝出来多台服务器的,所以环境绝对一样。

2,场景描述
主数据库服务器:192.168.10.130
从数据库服务器:192.168.10.131

3 ,配置主服务器
修改从服务器的配置文件,my.cnf 不一定路径和我一样哦,注意修改

vi etc/my.cnf
确定 server-id = 1,并确保这个ID没有被别的MySQL服务所使用。 启动mysql服务(192.168.10.130)

/etc/init.d/mysqld  start
通过命令行登录管理MySQL服务器 mysql -uroot -p
授权给从数据库服务器192.168.10.131 mysql> GRANT REPLICATION SLAVE ON *.* to 'rep1'@'192.168.10.131' identified by '123';
查询主数据库状态 Mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000005 | 261 | | |
+------------------+----------+--------------+------------------+
记录下 FILE (mysql-bin.000005) 及 Position(261) 的值,在后面进行从服务器操作的时候需要用到。

4,配置从服务器
修改从服务器的配置文件,my.cnf 不一定路径和我一样哦,注意修改 vi etc/my.cnf
将 server-id = 1修改为 server-id = 2,并确保这个ID没有被别的MySQL服务所使用。 启动mysql服务

/opt/mysql/init.d/mysql start
通过命令行登录管理MySQL服务器 mysql -uroot -p
执行同步SQL语句 mysql> change master to
master_host=’192.168.10.130’,
master_user=’rep1’,
master_password=’123’,
master_log_file=’mysql-bin.000005’,
master_log_pos=261;

注意上面的数据要和主服务器一样,否则同步会失败!
 
正确执行后启动Slave同步进程

mysql> start slave;
主从同步检查 mysql> show slave statusG
其中Slave_IO_Running 与 Slave_SQL_Running 的值都必须为YES,才表明状态正常。 如果不是,请检查上面是否那一步骤有问题!可以留言给我。。。如果都YES 可以进入下一步操作

5,第一次同步主从服务器数据
锁定主服务器mysql:
mysql> FLUSH TABLES WITH READ LOCK;
锁定从服务器mysql: mysql> FLUSH TABLES WITH READ LOCK;
将主服务器的数据文件(整个/opt/mysql/data目录)复制到从服务器,建议通过tar归档压缩后再传到从服务器解压覆盖。 开启主服务器mysql:
mysql> UNLOCK TABLES;
开启从服务器mysql: mysql> UNLOCK TABLES;

6,测试是否同步 在主服务器上操作:
 mysql> create database first_db;
 mysql> use first_db;
 mysql> create table first_tb(id int(3),name char(10));
 mysql> INSERT INTO `first_tb` VALUES ('1', '1');
在从服务器上查看.... mysql> show databases;
=============================
+--------------------+
| Database |
+--------------------+
| information_schema |
| first_db |
| mysql |
| performance_schema |
| test |
+--------------------+
5 rows in set (0.01 sec)
=============================
数据已经同步过来了。现在只要在主服务器上有任何操作,都会自动同步到从服务器来。

MySQL服务器主从复制和读写分离设置方法
分享到:
ArchLinux下从MySQL迁移到MariaDB
ArchLinux下从MySQL迁移到MariaDB 于是我决定把我的所有服务器从 MySQL 迁移到 MariaDB. 对 Arch 用户来说很简单,照着官方新闻里面的来就是了: systemctl stop mysqld  pacman -S mariadb libmariadbclient mariadb-clients  systemctl start mysqld  mysql_upgrade -p  而对于 openSUSE 就更傻...
从MySQL数据库迁移至MariaDB
从MySQL数据库迁移至MariaDB 本世纪最大的MySQL叛逃期已经开始,以openSUSE ,fedora,arch为代表的发行版已经转为使用MariaDB作为默认数据库选项取代MySQL。由于本人也不是很喜欢oracle在MySQL上面的态度,所以今天把MySQL卸载了。整个过程基本无痛,也没什么需要特别设置的,兼容性还是不错的。安装步骤如下 ...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……