MySQL优化---主从复制
主机所有写的数据都会生成二进制SQL日志执行文件,从机只需要将SQL日志执行文件获取到,然后进行数据同步即可
一、MySQL环境搭建(一主一从相同操作)
MySQL-master:192.168.33.135
MySQL-slave:192.168.33.136
1、 连接到虚拟机,在/usr/local下新建一个文件夹为mysql,将tar包上传到此目录当中
2、切换到/usr/local/mysql目录,进行拆包 tar -xvf MySQL-5.5.44-1.linux2.6.x86_64.rpm-bundle.tar

3、 安装mysql客户端
rpm -ivh MySQL-client-5.5.44-1.linux2.6.x86_64.rpm 此命令会报错

rpm -ivh MySQL-client-5.5.44-1.linux2.6.x86_64.rpm --nodeps

4、 安装服务端 rpm -ivh MySQL-server-5.5.44-1.linux2.6.x86_64.rpm --nodeps

安装服务端,如果当前虚拟机有mysql报错,出现版本冲突 yum remove mysql-libs 然后重新安装服务端

5、 检测是否安装客户端和服务器 rpm -qa|grep -i mysql
6、 启动mysql服务 service mysql start
停止服务:service mysql stop
重启服务:service mysql restart
7、 mysql默认安装完毕后是没有密码的 更改密码mysqladmin -uroot -p password '新密码'
8、 登陆mysql服务器 mysql -uroot -p
9、 SQLyog去连接虚拟机mysql
连接报1130错误,没有权限进行远程连接,更改权限为%

①登陆mysql服务器

②切换到mysql数据库下 use mysql;
③查询当前用户表中用户名和host信息,select user,host from user;
发现host为127.0.0.1代表只能本机使用root ,外界用不了
④更改权限,将host改为% update user set host='%' where user='root';
如果报ERROR 1062 (23000): Duplicate entry '%-root' for key 'PRIMARY’ 不用理会

⑤再次查看 权限已更改 select user,host from user;

⑥刷新权限 flush privileges;
⑦退出客户端,重启mysql service mysql restart

⑧使用SQLyog去连接

二、搭建主从复制
1、 配置节点信息
找到my.cnf配置文件,rpm方式安装在/etc下没有该文件,mysql默认启动的时候会加载/usr/share/mysql/my-medium.cnf,只需要将这个文件复制到/etc下改名为my.cnf即可
2、配置主节点
①执行 cp /usr/share/mysql/my-medium.cnf /etc/my.cnf

②编辑 vi /etc/my.cnf文件
server-id = 保证唯一,建议配置成ip地址第四位
log-bin=mysql-bin 为了让主机生成二进制SQL日志执行文件

③重启mysql服务器 service mysql restart
④查看当前server-id是否生效,使用sqlyog工具查看,如果返回值为0或者1代表是默认的 SHOW VARIABLES LIKE 'server_id'

⑤查看当前主服务器状态,如果看到的不是null代表成功~ SHOW MASTER STATUS

3、配置从节点
①执行 cp /usr/share/mysql/my-medium.cnf /etc/my.cnf

②编辑 vi /etc/my.cnf文件
server-id = 22
log-bin=mysql-bin
binlog_do_db=test

③重启mysql服务器 service mysql restart
④查看当前server-id是否生效,使用sqlyog工具查看,如果返回值为0或者1代表是默认的 SHOW VARIABLES LIKE 'server_id'

3、设置服务器读取权限
主服务器创建一个账号,将账号分配从服务器,从服务器拿到该账号然后才可以执行同步数据操作
GRANT REPLICATION SLAVE ON *.* TO 'zheng'@'%' IDENTIFIED BY 'zheng';

4、 从服务器执行同步
从服务器执行同步操作,使用主服务器生成的权限账号,将二进制文件同步
①设置同步
根据主服务器ip地址,生成的权限账号的用户名和密码以及二进制文件名称还有文件大小进行同步
CHANGE MASTER TO MASTER_HOST='192.168.33.135',MASTER_USER='zheng',MASTER_PASSWORD='zheng',MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=241;

②开启同步 START SLAVE

5、 mysql环境卸载
rpm -qa|grep -i mysql 查看安装情况

卸载命令:
rpm -e MySQL-server-版本号
rpm -e MySQL-client-版本号
查找mysql目录:find / -name mysql

删除 rm -rf xxx/mysql
MySQL优化---主从复制的更多相关文章
- 专题《一》mysql优化 ---------主从复制,读写
主从复制是mysql自带的功能,读写分离用第三方插件 主从复制作用:读写分离(mycat),数据备份,高可用,集群 原理:二进制sql执行文件-----insert,update,delete,cre ...
- MySQL优化聊两句
原文地址:http://www.cnblogs.com/verrion/p/mysql_optimised.html MySQL优化聊两句 MySQL不多介绍,今天聊两句该如何优化以及从哪些方面入手, ...
- 单表60亿记录等大数据场景的MySQL优化和运维之道
此文是根据杨尚刚在[QCON高可用架构群]中,针对MySQL在单表海量记录等场景下,业界广泛关注的MySQL问题的经验分享整理而成,转发请注明出处. 杨尚刚,美图公司数据库高级DBA,负责美图后端数据 ...
- 【转】单表60亿记录等大数据场景的MySQL优化和运维之道 | 高可用架构
此文是根据杨尚刚在[QCON高可用架构群]中,针对MySQL在单表海量记录等场景下,业界广泛关注的MySQL问题的经验分享整理而成,转发请注明出处. 杨尚刚,美图公司数据库高级DBA,负责美图后端数据 ...
- [转载] 单表60亿记录等大数据场景的MySQL优化和运维之道 | 高可用架构
原文: http://mp.weixin.qq.com/s?__biz=MzAwMDU1MTE1OQ==&mid=209406532&idx=1&sn=2e9b0cc02bdd ...
- 「mysql优化专题」高可用性、负载均衡的mysql集群解决方案(12)
一.为什么需要mysql集群? 一个庞大的分布式系统的性能瓶颈中,最脆弱的就是连接.连接有两个,一个是客户端与后端的连接,另一个是后端与数据库的连接.简单如图下两个蓝色框框(其实,这张图是我在悟空问答 ...
- MySQL优化面试
原则:尽量使用整型表示字符串 存储IP INET_ATON(str),address to number INET_NTOA(number),number to address MySQL内部的枚举类 ...
- MySQL优化十大技巧
转自:https://m.2cto.com/database/201701/557910.html MYSQL优化主要分为以下四大方面: 设计:存储引擎,字段类型,范式与逆范式 功能:索引,缓存,分区 ...
- mysql (主从复制)(proxy , Amoeba)
原址如下: http://heylinux.com/archives/1004.html Mysql作为目前世界上使用最广泛的免费数据库,相信所有从事系统运维的工程师都一定接触过.但在实际的生产环境中 ...
随机推荐
- nginx负载均衡动态自动更新(微博开源模块nginx-upsync-module使用)
这几天项目有个需求:负载要求能根据节点健康状态动态的增减.nginx自带的upstram已经很强大,而且基于Nginx Upstream配置动态更新已经有很多开源方案,大多数都是基于生成配置文件后进行 ...
- python报错:not supported between instances of 'str' and 'int'
not supported between instances of 'str' and 'int' : 意思就是字符串不能和int类型的数值比较
- cogs 1963. [HAOI 2015] 树上操作 树链剖分+线段树
1963. [HAOI 2015] 树上操作 ★★★☆ 输入文件:haoi2015_t2.in 输出文件:haoi2015_t2.out 简单对比时间限制:1 s 内存限制:256 M ...
- html包含html文件的方法
我们在写asp页面的时候,常常使用include命令来包含公共文件.由于这个方法用起来非常方便,于是很多人在HTML页面里尝试使用include,但是发现根本就不起作用.这是因为,include是VB ...
- Activiti邮件任务
Activiti邮件任务 作者:Jesai 会不会有那么一天,你会妒忌 Activiti有一种任务叫做邮件任务,顾名思义,就是流程办理到邮件任务的时候,系统就会自动的给你发送任务. Activiti所 ...
- Codeforces Choosing Laptop 题解
这题实在是太水了,具体看注释 蒟蒻的方法是一边找过时的电脑一边比大小 蒟蒻不才,只会C++ 其实还会free basic,但它已经过时了 附: 本题洛谷网址 Codeforces网址 希望蒟蒻的题解能 ...
- 每天敲一点code
下面这段代码摘自 <C#并发编程经典实例> 并行LINQ static IEnumerable<int> MultiplyBy2(IEnumerable<int> ...
- JS-04-流程控制和循环
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- epel-release的卸载重装
1.yum remove epel-release 2.清空epel目录:rm -rf /var/cache/yum/x86_64/6/epel/ 3.安装,yum install epel-rel ...
- linux 移动复制删除
linux下文件的复制.移动与删除命令为:cp,mv,rm一.文件复制命令cp 命令格式:cp [-adfilprsu] 源文件(source) 目标文件(destination) ...









