mysql配置主从数据库
1.目的
1.1 实现数据备份
1.2 项目访问时可以实现读写分离,提高访问和操作数据的速度<读写分离好处>
2.背景
这次的主从配置主要实现主库数据的改变可以实现同步到从库中;
此次试验的主库为liunx<ubuntu4.8.2> 下mysql 5.6.19,从库为windows10 下mysql 5.6.24;
3.准备知识
3.1 在liunx下mysql的配置文件为:
/etc/mysql/my.conf
3.2 在windows下mysql的配置文件为:
mysqlpath/my.ini
3.3 在不同的系统环境下,配置的文件的路径和后缀名是不同的;
3.4 在liunx系统环境下,mysql 服务的启动关闭重启的命令如下:
sudo start mysql; //启动服务
sudo stop mysql; //关闭服务
sudo restart mysql; //重启

3.5 每次修改配置文件,需要重启服务再查看结果
4. 配置主从数据库
4.1 打开3306端口,可以允许远程访问主库端口;
a.首先查看端口是否打开
netstat -an|grep 3306

上图是打开的情况下的数据展示,如果没有打开会出现 127.0.0.1 的数据;如果没有打开,则需要到 /etc/mysql/my.conf 中将bind-address = 127.0.0.1 注销
#bind-address = 127.0.0.1 //注销示例
bind-address = 127.0.0.1
重启服务查看端口是否打开;
b.设置远程可以访问mysql数据库的权限
进入主库使用sql命令设置权限,如下:
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| cmdb |
| mysql |
| performance_schema |
| test |
+--------------------+
rows in set (0.00 sec) mysql> use mysql;
Database changed
mysql> update user set host='%' where user='root';
ERROR 1062 (23000): Duplicate entry '%-root' for key 'PRIMARY' //虽然报错,但实际更新成功;
// 备选 mysql>grant all privileges on *.* to 'root'@'%' identified by 'xxxxxx';
打开另一个终端,执行如下命令:
[root@zhoujietest ~]#mysql -u root mysql>delete from user where user=''; mysql>flush privileges; #刷新权限 mysql>\q
重启服务,执行如下命令查看权限赋予情况:
mysql>mysql -u root -p
mysql>use mysql;
mysql>selsct user,host from user;
可得到如下数据:

host中%表示可以远程使用root账号访问;
4.2 配置mysql主从配置文件
主库:192.168.0.175
从库:192.168.0.170
a.主库配置 </etc/mysql/my.conf>
*添加的配置必须在[mysqld]范围内,不然无法启动服务
[mysqld]
log-bin=mysql-bin
server-id=1
binlog-do-db = cmdb //需要同步的数据库
#binlog-ignore-db = nodb //不需要同步的数据库
修改后重启服务,查看主库设置情况,如下:
mysql> show master status;
+---------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+---------------+----------+--------------+------------------+
| binlog.000001 | 1304 | cmdb | |
+---------------+----------+--------------+------------------+
row in set (0.00 sec)
b.从库配置i<mysqlpath/my.ini>
设置配置文件:
[mysqld]
server-id=2 //服务器id,区别于主库的server-id
master-host=192.168.0.175 //主库ip
master-user=rep1 //5.5-
master-password=test123456 //5.5-
master-port=3306 //5.5-
replicate-do-db=cmdb //5.5-
......
配置文件除server-id外,mysql 5.5+ 版本需要在命令行中设置其余属性:
mysql> CHANGE MASTER TO
-> MASTER_HOST='master_host_name',
-> MASTER_USER='replication_user_name',
-> MASTER_PASSWORD='replication_password',
-> MASTER_LOG_FILE='recorded_log_file_name',//数据需要同show master status 中的数据一致
-> MASTER_LOG_POS=recorded_log_position;//数据需要同show master status 中的数据一致
启动slave进程
mysql> start slave;
Query OK, 0 rows affected (0.04 sec)
查看slave的状态,如果下面两项值为YES,则表示配置正确:
Slave_IO_Running: Yes Slave_SQL_Running: Yes

c.将主库已有数据复制到从库
ca.命令复制
主库:
mysql>flush tables with read lock;//停止主库的数据更新操作
打开新的终端:
[root@zhoujietest ~]# mysqldump -uroot -ptest123 cmdb > cmdb.sql //生成主数据库的备份(导出数据库)
[root@zhoujietest ~]# scp cmdb.sql root@192.168.0.170:/root/ //将备份文件传到从库
mysql>unlock tables;//主库解锁
从库:
mysql>slave stop;//停止从库slave
mysql> create database cmdb default charset utf8;//新建数据库cmdb
[root@ops-dev ~]# mysql -uroot -ptest123 cmdb<cmdb.sql //导入数据
mysql> show databases;//查看从库已有该数据库和数据
+--------------------+
| Database |
+--------------------+
| information_schema |
| cmdb |
| mysql |
| performance_schema |
| test |
+--------------------+
cb.使用工具<Navicat>直接从主库复制到从库中
d.主库数据更改后,从库自动更新。
5. 后续问题
从库修改数据后,会导致从库同步主库出错,无法同步到主库的数据;
解决方案:重新配置从库数据,重新导入数据,重启服务。
6.项目配置读写分离
移步:http://www.cnblogs.com/springlight/p/5905720.html
参考资料:
1.http://www.cnblogs.com/zhoujie/p/mysql1.html
2.http://dev.mysql.com/doc/refman/5.6/en/replication-howto.html
3.http://www.linuxdiyf.com/linux/15206.html
4.http://www.cnblogs.com/linjiqin/p/5270938.html
能力有限,文档可能存在不当之处,各位指正。
mysql配置主从数据库的更多相关文章
- MYSQL配置主从同步
MYSQL配置主从同步 mysql主服务器配置 vim /etc/my.cnf [mysqld] datadir=/var/lib/mysql socket=/var/lib/mysql/mysql. ...
- Mysql的主从数据库没有同步的解决办法
Mysql的主从数据库没有同步的解决办法 今天发现Mysql的主从数据库没有同步 先上Master库: mysql>show processlist; 查看下进程是否Sleep太多.发现很正常. ...
- 解决Mysql的主从数据库没有同步的两种方法
今天发现Mysql的主从数据库没有同步 先上Master库: mysql>show processlist; 查看下进程是否Sleep太多.发现很正常.show master status; ...
- windows与linux中的mysql配置主从
最近在给学生讲解数据库的主从配置,由于学生电脑里面装的虚拟机是linux的,但是本机的系统是windows的,所以需要用windows中的mysql与linux中的mysql进行主从配置.下面说一下主 ...
- Mysql配置主从同步的基本步骤
# 配置主从同步的基本步骤 #总结为如下的步骤: # .在主服务器上,必须开启二进制日志机制和配置一个独立的ID # .在每一个从服务器上,配置一个唯一的ID,创建一个用来专门复制主服务器数据的账号 ...
- MySql配置主从模式 Last_IO_Error: Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work.
今天在学习MyCat环境搭建的时候,在配置MySql的主从模式,发现slave在配置完毕后,配置的内容全部正确的情况下,报错了? Last_IO_Error: Fatal error: The sla ...
- Mysql配置 主从同步
目录 一.准备 二.操作 主数据库操作 从服务器操作 一.准备 1.主从数据库版本最好一致 2.主从数据库内数据保持一致,若不一致,可将从库中所有数据删除,并将主库全部数据导入进去 主数据库:182. ...
- MySQL配置主从分离
主服务器 192.168.176.110 从服务器 192.168.176.120 主数据库操作(ip:192.168.176.110) 配置MySQL主服务器的配置文件 [root@localho ...
- mysql服务器主从数据库同步配置(转)
<a href=""></a> <p>首先需要在同一个局域网内的两台机器(当然也可以用一台机器虚拟两台机器出来),都安装上mysql服务.< ...
随机推荐
- C# Excel嵌入到Winform
本文讲的这个技术是把Excel表格嵌入到自己开发程序的Form窗体中进行操作,给客户一个不用切换窗口的操作界面,似乎更好.这在VC中用OLE技术很容易实现,但是在C#中方法就不一样啦.下面将就此进行阐 ...
- 玩Mega8 智能充电器-12. 终于实现-dV检测(转)
源:http://blog.chinaunix.net/uid-10701701-id-91873.html 2010.1.3 5:30终于补齐了. 电池充电的-dv 的检测系列图片请移步: http ...
- spider JAVA如何判断网页编码 (转载)
原文链接 http://www.cnblogs.com/nanxin/archive/2013/03/27/2984320.html 前言 最近做一个搜索项目,需要爬取很多网站获取需要的信息.在爬取网 ...
- Intellij idea生成Hibernate实体类
反向生成基于注解的Hibernate实体类 1. 为项目添加Hibernate支持 2. 在IDE右边找到database,然后按照步骤添加数据. 3. 保存后.在主面板左侧有persistence, ...
- base库--- 一个应用JS
1 /** * Created by Administrator on 2014/6/3 0003. */ $(function () { //个人中心下拉 $('.js-hd-right').hov ...
- 之一 select模型
// select.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <WinSock2.h> #include ...
- 关于easyUI的datagrid的编辑功能时的问题
编辑时,如果form中包含了id输入域,会发送一个{id,id}这样的字符串到服务端,因为javascript的function edit(){}逻辑中,已经拿到Id提交了.所以,编辑和添加功能共用的 ...
- JAVA基础-多态
多态 polymophism: 动态绑定, 迟绑定, 指在执行期间(java), 而不是编译期间(javac), 判断所引用对象的实际类型, 根据实际类型调用响应的方法. 3个条件: 1. 继承 2. ...
- chromium high cpu usage
ctrl + esc 列出哪个进程占用了cpu,可以杀掉. --purge-memory-button可以在上边弹出的窗口上显示一个按钮,据说能释放内存.
- -linux删除大量文件----rm,rsync
要在linux下删除海量文件,比如有数十万个文件,此时常用的rm -rf * 就会等待时间很长.这时我们可以使用rsync快速删除大量文件. 1.建立一个空目录 mkdir -p /tmp/rsync ...