一、实验环境部署

主服务器 192.168.18.42 端口3306  ==》 从服务器 192.168.18.44 端口 3306

主服务器 192.168.18.43 端口3306  ==》 从服务器 192.168.18.44 端口 3307

##数据库,已经安装mysql服务,安装部分略。从服务器上的多个mysql实例,请看另一篇帖子《用mysql_multi 实现一台机器跑多台mysql 》

二、部署服务器

1.在两台主服务器上赋予从机权限,有多台丛机,就执行多次(我们这里两台主库使用统一帐号密码)。

mysql> grant replication slave on *.* to 'backup'@'192.168.18.44' identified by '123456';

Query OK, 0 rows affected (0.00 sec)

2.在主服务器上配置my.cnf

vi /etc/my.cnf

server-id = 1

log-bin = mysql-bin  #保证binlog可读

read-only = 0  #主机,读写都可以

#binlog-do-db = test   #需要备份数据,多个写多行,不写全部都备份

binlog-ignore-db = mysql #不需要备份的数据库,多个写多行

编辑后重启数据库 # service mysqld restart

3.配置从库服务器的my.cnf

vi /etc/my.cnf

[mysqld_multi]

mysqld = /mysql/bin/mysqld_safe

mysqladmin = /mysql/bin/mysqladmin

[mysqld1]

port    = 3306

socket  = /tmp/mysql3306.sock

pid-file = /data/mysql/data1/mysql3306.pid

datadir = /data/mysql/data1

skip-name-resolve

log-bin = mysql-bin-3306

log_slave_updates

expire_logs_days = 7

log-error = /data/mysql/data1/mysql3306.err

log_slow_queries = mysql3306-slow.log

long_query_time = 3

query_cache_size = 64M

query_cache_limit = 2M

slave-net-timeout = 10

server-id = 2                     #server id 不要与主库的重复

master-host = 192.168.18.42        #对应主库的 ip地址

master-user = backup               # slave 帐号

master-password = 123456           # 密码

master-port = 3306                 #主库端口

replicate-ignore-db=mysql           #跳过不备份的库

master-info-file = master.1842.info

master-connect-retry = 10

relay-log = relay-bin-1842          #中继日志

relay-log-index = relay-bin-1842

relay-log-info-file = relay-log-1842.info

default-character-set=gbk

innodb_data_home_dir = /data/mysql/data1

innodb_data_file_path = ibdata1:50M:autoextend

innodb_log_group_home_dir = /data/mysql/data1

innodb_buffer_pool_size = 3072M

innodb_file_per_table

innodb_open_files = 800

#innodb_flush_method = O_DIRECT

innodb_flush_method = O_DSYNC

skip-locking

key_buffer = 32M

max_allowed_packet = 16M

table_cache = 1024

sort_buffer_size = 8M

net_buffer_length = 8M

read_buffer_size = 2M

read_rnd_buffer_size = 8M

myisam_sort_buffer_size = 32M

max_connections = 100

read_only

wait_timeout=288000

interactive_timeout=288000

log-bin-trust-function-creators=1

replicate-ignore-db = test

replicate-ignore-table = mysql.columns_priv

replicate-ignore-table = mysql.host

replicate-ignore-table = mysql.db

replicate-ignore-table = mysql.procs_priv

replicate-ignore-table = mysql.tables_priv

replicate-ignore-table = mysql.user

[mysqld2]

port    = 3307

socket  = /tmp/mysql3307.sock

pid-file = /data/mysql/data2/mysql3307.pid

datadir = /data/mysql/data2

skip-name-resolve

log-bin = mysql-bin-3307

log_slave_updates

expire_logs_days = 7

log-error = /data/mysql/data1/mysql3307.err

log_slow_queries = mysql3307-slow.log

long_query_time = 3

query_cache_size = 64M

query_cache_limit = 2M

slave-net-timeout = 10

server-id = 2                     #server id 不要与主库的重复

master-host = 192.168.18.43        #对应主库的 ip地址

master-user = backup               # slave 帐号

master-password = 123456           # 密码

master-port = 3306                 #主库端口

replicate-ignore-db=mysql           #跳过不备份的库

master-info-file = master.1843.info

master-connect-retry = 10

relay-log = relay-bin-1843

relay-log-index = relay-bin-1843

relay-log-info-file = relay-log-1843.info

default-character-set=gbk

innodb_data_home_dir = /data/mysql/data2

innodb_data_file_path = ibdata1:50M:autoextend

innodb_log_group_home_dir = /data/mysql/data2

innodb_buffer_pool_size = 3072M

innodb_file_per_table

innodb_open_files = 800

#innodb_flush_method = O_DIRECT

innodb_flush_method = O_DSYNC

skip-locking

key_buffer = 32M

max_allowed_packet = 16M

table_cache = 1024

sort_buffer_size = 8M

net_buffer_length = 8M

read_buffer_size = 2M

read_rnd_buffer_size = 8M

myisam_sort_buffer_size = 32M

max_connections = 100

read_only

wait_timeout=288000

interactive_timeout=288000

log-bin-trust-function-creators=1

replicate-ignore-db = test

replicate-ignore-table = mysql.columns_priv

replicate-ignore-table = mysql.host

replicate-ignore-table = mysql.db

replicate-ignore-table = mysql.procs_priv

replicate-ignore-table = mysql.tables_priv

replicate-ignore-table = mysql.user

# 因为图方便就把参数全部抓出来了 对主从有用的也就标注的几个

4.配置完成后重启大从服务器

[root@localhost data1]# mysqld_multi --config-file=/etc/my.cnf --user=root --password=123456 report 1,2

Reporting MySQL servers

MySQL server from group: mysqld1 is running

MySQL server from group: mysqld2 is running

5.在从库上进行chang master ;

1).在date1上

mysql -uroot -p -S /tmp/mysql3306.sock

mysql> stop slave;

Query OK, 0 rows affected (0.00 sec)

mysql> CHANGE MASTER TO

-> MASTER_HOST='192.168.18.43',

-> MASTER_PORT=3306,

-> MASTER_USER='backup',

-> MASTER_PASSWORD='123456'

Query OK, 0 rows affected (0.05 sec)

mysql> start slave;

Query OK, 0 rows affected (0.00 sec)

2)。在date2上

mysql -uroot -p -S /tmp/mysql3307.sock

mysql> stop slave;

Query OK, 0 rows affected (0.00 sec)

mysql> CHANGE MASTER TO

-> MASTER_HOST='192.168.18.42',

-> MASTER_PORT=3306,

-> MASTER_USER='backup',

-> MASTER_PASSWORD='123456'

Query OK, 0 rows affected (0.05 sec)

mysql> start slave;

Query OK, 0 rows affected (0.00 sec)

三、验证:

1.在大从服务器上

show slave status\G;

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

2.在主库创建数据库(18.43上)

mysql> create database haifengtest;

Query OK, 1 row affected (0.00 sec)

mysql> show databases;

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

| Database           |

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

| information_schema |

| haifengtest        |

| mysql              |

| test               |

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

4 rows in set (0.00 sec)

从库查看 (mysql3307.sock上)

mysql> show databases;

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

| Database           |

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

| information_schema |

| haifengtest        |

| mysql              |

| test               |

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

4 rows in set (0.00 sec)

四、一种常见的问题。

在show slave status\G;时发现下面的问题,(因为我事先在从上创建了该库)

Relay_Master_Log_File: mysql-bin.000005

Slave_IO_Running: Yes

Slave_SQL_Running: No

Replicate_Do_DB:

Replicate_Ignore_DB: mysql

Replicate_Do_Table:

Replicate_Ignore_Table:

Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table:

Last_Errno: 1007

Last_Error: Error 'Can't create database 'haifengtest'; database exists' on query. Default database: 'haifengtest'. Query: 'create database haifengtest'

如果Replication在Slave上出现上面错误而停止,一般都期望Slave能忽略这个错误,继续进行同步,而不是重新启动Slave。

这时可以使用 SQL_SLAVE_SKIP_COUNTER

mysql> SET GLOBAL SQL_SLAVE_SKIP_COUNTER = 1;

Query OK, 0 rows affected (0.00 sec)

mysql> start slave;

Query OK, 0 rows affected (0.00 sec)

在验证一次

show slave status\G;

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

ok 搞定。。。。

mysql主库从库在同一台服务器_MySQL数据库的主从配置(多主对一从)相关推荐

  1. mysql主库从库在同一台服务器_mysql数据库从一台服务器迁移到另一台服务器上...

    一.应用场景 由于要把测试服务器上的数据库迁移到正式服务器上,因此需要做数据库的迁移.这里记录一下. 二.数据库迁移 1.新建数据库test create database test; 1 2.进入数 ...

  2. mysql主库从库在同一台服务器_MySQL_MySQL 数据库两台主机同步实战(linux),当一个从服务器连接到主服务 - phpStudy...

    MySQL 数据库两台主机同步实战(linux) 当一个从服务器连接到主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置.从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器 ...

  3. mysql主库从库在同一台服务器_通过两种方式增加从库——不停止mysql服务

    一般在线增加从库有两种方式,一种是通过mysqldump备份主库,恢复到从库,mysqldump是逻辑备份,数据量大时,备份速度会很慢,锁表的时间也会很长.另一种是通过xtrabackup工具备份主库 ...

  4. mysql同步到另一台服务器_mysql数据库从一台服务器迁移到另一台服务器上

    一.应用场景 由于要把测试服务器上的数据库迁移到正式服务器上,因此需要做数据库的迁移.这里记录一下. 二.数据库迁移 1.新建数据库test create database test; 1 2.进入数 ...

  5. 电脑上怎么配置mysql数据库服务器_Mysql数据库服务器安装与配置详解教程

    一.Mysql的安装 首先,看看自己电脑里是否安装了Mysql软件rpm -qa | grep mysql 如果没有安装,则放入光盘:rpm -ivh mysql-server-*.rpm(如果不能直 ...

  6. 将mysql数据库拷贝到另一台机器_mysql数据库迁移到另一台电脑上

    解决办法 mysql要转换到另一台机器上面,最重要的要考虑以下几个问题 1.数据库使用什么存储引擎,如果是myisam的话,可以把data目录复制移走.但如果是innodb的话,千万不要用这种方法,会 ...

  7. mysql同步到另一台服务器_mysql两台服务器主从同步

    A服务器: host 192.168.1.101 port 3306 B服务器: host 192.168.1.102 port 3306 1,授权用户: A服务器 mysql>grant re ...

  8. 服务器多出mysql帐户_在一台服务器构建多mysql 服务

    作者博客:http://windychan.cublog.cn/ 欢迎转载,但务必在转载时注明出处.[/align] ***************************************** ...

  9. linux将mysql导出表数据导入另一台服务器_远程linux服务器mysql数据库导入和导出.sql文件...

    今天对需要将服务器上的数据库放到本地环境,之前没怎么这么操作过,ORZ,弱鸡,这篇帖子不错,收藏了!!! 远程linux服务器mysql数据库导入和导出.sql文件 大部分情况本地开发环境为windo ...

最新文章

  1. 轻松解决Windows7声卡驱动不全问题
  2. 高斯旋转热源与双椭球热源_电力分公司:多措并举保证供暖质量效益双提升
  3. 我的世界之史蒂夫生存记
  4. mysql创建非聚集索引_一文看懂聚集索引和非聚集索引的区别
  5. [JOYOI] 1124 花店橱窗
  6. 高通软件发布版本简称
  7. Chrome调试模拟iPhone6时body显示980*1742
  8. 测试一下你对IP地址的掌握水平(网管面试时会用到)
  9. c语言 socket 报文解析,C语言实现Socket简单通信
  10. Voovan网络编程介绍
  11. scheme中文编程
  12. Windows下安装Redies
  13. https 双向认证基本配置学习
  14. 磁珠 符号_磁珠。标有FB的应该是磁珠!
  15. html怎么做向下的图标,用CSS和Bootstrap图标制作上下跳动的指示箭头动画效果
  16. 立创eda学习笔记三十:布局传递
  17. 瑞红淘宝商城旗舰店开张 正式进军B2C市场
  18. 对软件测试团队“核心价值”的思考(来自 李云)
  19. 蓝桥杯2015年第六届真题-穿越雷区
  20. Java输入一个月份判断春夏秋冬季节中switch与if使用

热门文章

  1. jquery 获取键值对中最大值_jquery属性的操作
  2. linux将一个文件的内容复制到另一个新的文件
  3. duilib环境配置以及简单入门介绍
  4. 单反相机内部光线反射原理
  5. Struts2之Crud综合实例
  6. hive函数大全:11大类、109个函数
  7. VisualStudio 的 Spy++ —— 窗口、消息 的 查看分析利器
  8. 王爽 汇编语言第三版 第10章 call 和 ret 指令 以及 子程序设计
  9. CompletableFuture详解~thenCombine
  10. mysql root mysqld_MySQL how to run mysqld as root