Mysql数据库读写分离配置
环境模拟
实现读写分离 减轻数据库的负荷
主服务器 master 10.0.0.12
从服务器 slave 10.0.0.66
配置主服务器: 在10.0.0.12服务器操作 创建数据库 create database mydemo;
1.修改配置文件
vi /etc/my.cnf 在[mysqld] 后面添加下面的代码
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
sync_binlog=1binlog-do-db=mydemo #设置需要同步的数据库名binlog_ignore_db=mysql #不需要同步的数据库 如果有多个不需要同步则依次列出# binlog_ignore_db=xxxx 保存退出 :wq 2. 重新启动mysql 服务器 service mysqld restart 3.进入mysql平台 设置需要同步的用户账号 create user '用户名'@'从服务器ip地址' identified by '密码' create user 'eduask'@'10.0.0.66' identified by 'test123' #创建一个从服务器用户同步到主服务器 4. 给slave 用户赋权限 grant all on *.* to 'eduask'@'10.0.0.%' identified by 'test123' grant replication slave on *.* to 'eduask'@'10.0.0.66' identified by 'test123' 允许从服务器用户远程登录 5.刷新授权表 flush privileges 6.给数据库创建测试数据库 create table userinfo( uid int primary key auto_increment, uname char(30) not null, upwd char(30) not null ); insert into userinfo (`uid`,`uname`,`upwd`) values(null,'aaa','test123') 7.退出系统 \q exit ------------从服务器配置完成后再操作----------- 8. 导出主服务器数据库 传递到从服务器 /usr/local/web/mysql/bin/mysqldump -uroot -ptest123 数据库名 > /home/数据库名.sql scp 从哪里 到哪里 scp /home/数据库名.sql root@10.0.0.66:/home [提示: 如果系统提示你是否远程传输 yes] 系统会提示你输入密码: test123 9.重新启动主服务器 service mysqld stop service mysqld start 10. 进入mysql 平台 /usr/local/web/mysql/bin/mysql -uroot -ptest123 11.查询主服务器状体 master show master status; 运行后mysql 会显示一个当前master 的服务器日志状况表,我们需要记住两个字段的值 file: mysql-bin.000006 #这是需要同步的master 的二进制文件 position:519-----------------------------------------------------------------------------------------------------------------------配置从服务器 (在 10.0.0.66) 1.进入mysql 平台 /usr/local/web/mysql/bin/mysql -uroot -ptest123 2.创建数据库 create database mydemo; eixt 3.导入master 的数据库 /usr/local/web/mysql/bin/mysql -uroot -ptest123 数据库名 < /home/数据库名.sql 4.配置从服务器mysql 配置文件 vi /etc/my.cnf 找到 server-id=1 改成 2 (注意:server-id 必须要比master 的大 关键是不能重复) 在 [mysqld] 后面添加 replicate-do-db=mydemo #配置需要同步的数据库名 保存文件 :wq 5.重启mysqld service mysqld restart 6.以root用户登录mysql 平台 /usr/local/web/mysql/bin/mysql -uroot -ptest123 stop slave; change master to master_host='10.0.0.12', #master ip master_user='eduask', #master 用户名 master_password='test123', #master 密码 master_port=3306, #master 端口 master_log_file='mysql-bin.000006', #master 需要同步的二进制 master_log_pos=519, #master pos master_connect_retry=60; #连接master 的时间 7.启动slave start slave; 8. 查看是否连接同步成功 show slave status\G; 如果 SLAVE_IO_running yes slave_sql_running yes 这两个参数都为 yes 则表示成功 否则失败----------------------------------------------------------------------------------------------------------------------测试主从数据库同步 1.进入主服务器 /usr/local/web/mysql/bin/mysql -uroot -ptest123 use mydemo; insert into userinfo(uid,uname,upwd) values(nuull,'111','222'); 2. 进入从服务器 /usr/local/web/mysql/bin/mysql -uroot -ptest123 use mydemo; select * from userinfo; 如果从服务器中有master 的数据 成功 |
Mysql数据库读写分离配置的更多相关文章
- (转)Mysql数据库读写分离配置
环境模拟 实现读写分离 减轻数据库的负荷 主服务器 master 10.0.0.12从服务器 slave 10.0.0.66 ------------------------------------- ...
- yii2的数据库读写分离配置
简介 数据库读写分离是在网站遇到性能瓶颈的时候最先考虑优化的步骤,那么yii2是如何做数据库读写分离的呢?本节教程来给大家普及一下yii2的数据库读写分离配置. 两个服务器的数据同步是读写分离的前提条 ...
- MySQL数据库读写分离、读负载均衡方案选择
MySQL数据库读写分离.读负载均衡方案选择 一.MySQL Cluster外键所关联的记录在别的分片节点中性能很差对需要进行分片的表需要修改引擎Innodb为NDB因此MySQL Cluster不适 ...
- 170301、使用Spring AOP实现MySQL数据库读写分离案例分析
使用Spring AOP实现MySQL数据库读写分离案例分析 原创 2016-12-29 徐刘根 Java后端技术 一.前言 分布式环境下数据库的读写分离策略是解决数据库读写性能瓶颈的一个关键解决方案 ...
- Linux安装Mycat1.6.7.4并实现Mysql数据库读写分离简单配置
1. Mycat简介 一个彻底开源的,面向企业应用开发的大数据库集群 支持事务.ACID.可以替代MySQL的加强版数据库 一个可以视为MySQL集群的企业级数据库,用来替代昂贵的Oracle集群 一 ...
- 161220、使用Spring AOP实现MySQL数据库读写分离案例分析
一.前言 分布式环境下数据库的读写分离策略是解决数据库读写性能瓶颈的一个关键解决方案,更是最大限度了提高了应用中读取 (Read)数据的速度和并发量. 在进行数据库读写分离的时候,我们首先要进行数据库 ...
- Mysql数据库读写分离Amoeba
1.理解读写分离的原理 随着一个网站的业务不断扩展,数据不断增加,数据库的压力也会越来越大,对数据库或者SQL的基本优化可能达不到最终的效果,我们可以采用读写分离的策略来改变现状.读写分离现在被大量应 ...
- Mycat实现Mysql数据库读写分离
Linux和Windows环境下搭建Mycat数据读写分离 前提需要:1.服务器装有JVM虚拟机,就是JDK.2.两个Mysql数据库已经实现主从复制,参考:https://www.cnblogs.c ...
- 使用Spring AOP实现MySQL数据库读写分离案例分析
一.前言 分布式环境下数据库的读写分离策略是解决数据库读写性能瓶颈的一个关键解决方案,更是最大限度了提高了应用中读取 (Read)数据的速度和并发量. 在进行数据库读写分离的时候,我们首先要进行数据库 ...
随机推荐
- ArcGIS API for Silverlight 调用GP服务准备---GP模型建立、发布、测试
原文:ArcGIS API for Silverlight 调用GP服务准备---GP模型建立.发布.测试 第一篇.GP降雨量等值线建模.发布及测试 在水利.气象等行业中,要在WebGIS中实现空间分 ...
- Emiller's Advanced Topics In Nginx Module Development
Emiller的Nginx模块开发指南 By Evan Miller DRAFT: August 13, 2009 (changes) 翻译:Kongch @2010年1月5日 0:04am -- 2 ...
- iOS 增加UIButton按钮的可点击区域
在很多时候,按钮可能看起来那么大,但是在它周围进行点击时,都能够触发事件,是因为它的可点击区域比我们看到的button要大. 在使用AutoLayout的时候,我们处理的是按钮的image属性,所以这 ...
- css 清除浮动(转)
转自http://hi.baidu.com/kongcheng2012/item/2b1250d4452e802538f6f705 为什么浮动这么难? 因为浮动会使当前标签产生向上浮的效果,同时会影响 ...
- TTL和CMOS
reprint from:http://blog.csdn.net/hemeinvyiqiluoben/article/details/9253249 TTL和COMS电平匹配以及电平转换的方法 一. ...
- css3背景色渐变
<style> .test { width: 200px; height: 200px; background: -moz-linear-gradient(top, #8fa1ff, #3 ...
- Linux命令行–初识Linux shell
shell及脚本简介 GNU/Linux shell 是个交互工具,它为用户提供了启动程序.管理文件系统上的文件以及管理运行在Linux系统上的进程的途径 . shell的核心是命令行提示符 它是s ...
- RANSAC随机一致性采样算法学习体会
The RANSAC algorithm is a learning technique to estimate parameters of a model by random sampling of ...
- bootstrap ace treeview树表
html部分 <div class="widget-main padding-8" style="height:400px;overflow-y: scroll;& ...
- 开篇呀,恭喜恭喜,是个好开头-----关于sort()排序
感觉自己活了半辈子从来没写过博客,这可是头一回,而且不是记事是为了学习,先恭喜恭喜自己,有一个很好的开端,不管能不能半途而废,反正是想着为了学习做点什么. 之前有很多东西需要搬过来,循序渐进吧,反正也 ...