Centos6上进行Mysql5.6安装和主从复制部署
系统:centos6
数据库:mysql5.6
服务器:两台,一主一从
一、Mysql5.6二进制版本的安装
Mysql的安装在有三种模式,第一种是yum安装,第二种是二进制模式的安装,第三种是源码编译安装。本篇采用的是二进制安装方式。
安装前有几个工作建议先做一下,尽量排除掉一切可能失败的因素。
1.在安装前要先检查下系统中是不是已经安装过mysql,如果安装,要先卸载Mysql,将相关mysql的东西全部删除。
2.Mysql用到端口3306,要在防火墙方面上将两个端口打开,重点:如果是阿里云服务器,它的防火墙端口在还有一层过滤,需要等上控制台,在规则里面把端口给放开。
①下载安装包
# cd /usr/local 安装目录在/usr/local,先进入目录 #wget https://cdn.mysql.com//Downloads/MySQL-5.6/mysql-5.6.38-linux-glibc2.12-x86_64.tar.gz 下载linux平台下的64位的Mysql5.6 #tar zxvf mysql-5.6.-linux-glibc2.-x86_64.tar.gz -C /usr/local 将其解压到/usr/local #ln –sv mysql-5.6.-linux-glibc2.-x86_64 mysql 将解压后的文件建立软连接名字为 mysql 或 mv mysql-5.6.-linux-glibc2.-x86_64 mysql 将解压后的文件重命名为mysql
②准备Mysql用户
#groupadd mysql 增加mysql用户组 #useradd -s /sbin/nologin -M -g mysql mysql 增加mysql用户
-s表示指定用户所用的shell,此处为/sbin/nologin,表示不登录。
-M表示不创建用户主目录。 -g表示指定用户的组名为mysql。 -最后的mysql表示用户名。
③准备数据库实例datadir目录
# chown mysql:mysql /usr/local/mysql/data 更改data目录的所有者为mysql用户

# /usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data 初始化实例3306的目录

初始化后的data目录

④准备配置文件
在/etc文件夹下建立my.cnf,配置如下内容。
#vim /etc/my.cnf
[client]
port =
socket = /tmp/mysql.sock
[mysqld]
port =
socket = /tmp/mysql.sock
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
⑤配置环境变量(此步骤非必须,可以省略)
# vim /etc/profile
添加export PATH=/usr/local/mysql/bin/:$PATH
#source /etc/profile 重新加载下配置文件,使配置立即生效

⑥数据库的启动
启动Mysql有好几种方式,I,II,两种模式实质上最终都是是调用III.mysqld_safe启动。
I.可以将mysql配成服务,用server mysql start启动。
II.可以用mysqld -defaults-file=/etc/my.cnf --user=root 这种方式启动。
III.还可以用mysqld_safe --defaults-file=/etc/my.cnf 这种方式启动。
- I如果是将mysql配成服务
# cp /usr/local/mysql/support-files/mysql.server /etc/rc.d/init.d/mysqld # chkconfig --add mysqld 将mysqld服务添加到开机自启列表 # chkconfig mysqld on 设置mysqld服务开机自启 # service mysqld start 启动mysql

- II 如果以mysqld 方式启动
# /usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf --user=root & --user=root参数必须加,要不然报错

- III 如果以mysqld_safe方式启动
#/usr/local/mysql/bin/mysqld_safe --defaults-file=/etc/my.cnf >& >/dev/null &

⑥修改管理员密码并测试
# /usr/local/mysql/bin/mysqladmin -u root password 'admin' 设置管理员密码
# /usr/local/mysql/bin/mysql -u root -p 测试密码输入
至此,Mysql已经安装完成,另一台服务器mysql的安装也是这样,接下来便开始进行主从复制。
二、Mysql主从复制
我们在两台服务器上都装上Mysql,然后一台作为主服务器,一台作为从服务器,作为一主一从模式。
Master:172.23.216.86
Slvae :172.23.216.87
1.主从复制原理
整体上来说,复制有3个步骤:
①master将改变记录到二进制日志(binary log)中(这些记录叫做二进制日志事件,binary log events);
②slave将master的binary log events拷贝到它的中继日志(relay log);
③slave重做中继日志中的事件,将改变反映它自己的数据。

2.主从复制的配置
①主数据库实例设置server-id和开启bin-log;
②主数据库实例创建用于同步的账号;
③从数据库实例设置server-id;
④从数据库实例配置同步参数;
⑤从数据库实例启动同步开关。
①主数据库实例设置server-id和开启bin-log
在master的my.cnf文件中的[mysqld]节点出添加server-id和bin-log
# vim /etc/my.cnf
[mysqld] log-bin= /usr/local/mysql/data/mysql-bin 二进制日志路径格式 server-id = 主库从库的id不能相同 replicate-ignore-db = mysql 在进行主从同步时忽略mysql这个库
之后在数据库主库中查看是否开启
mysql>show variables like "server_id"; 显示为1表示正确 mysql>show variables like "log_bin"; 显示为ON表示二进制日志开启

②主库创建用于同步的账号
mysql>GRANT REPLICATION SLAVE ON *.* TO 'replication'@'%' identified by ''; 创建一个用于从库复制的账号 mysql>flush privileges; 刷新下权限列表 mysql> show master status \G; 查看主库状态

③从数据库设置server-id
在slave中my.cnf的[mysqld]节点出添加server-id
# vim /etc/my.cnf
[mysqld] server-id =
④在slave中配置同步参数
mysql>CHANGE MASTER TO MASTER_HOST=' 172.23.216.86', 主库的ip地址 MASTER_PORT=, 端口号 MASTER_USER='replication', 账号 MASTER_PASSWORD='', 密码 MASTER_LOG_FILE='mysql-bin.000002', 开始复制的文件 MASTER_LOG_POS=; 复制的位置
⑤从数据库启动同步开关
mysql>start slave; 从库执行start slave mysql>show slave status \G; 查看从库状态

至此,主从复制完成。现在在master上进行数据库相关操作,之后就会发现从库中也有相关内容。
------------------------------------------------------------------------其他-------------------------------------------------------------
1.彻底解除主从复制关系
1). stop slave;
2). reset slave; 或直接删除master.info和relay-log.info这两个文件;
3). 修改my.cnf删除主从相关配置参数。
2.让slave不随MySQL自动启动
修改my.cnf 在[mysqld]中增加 skip-slave-start 选项。
Centos6上进行Mysql5.6安装和主从复制部署的更多相关文章
- MySQL5.7安装、主从复制、读写分离原理解析以及详细配置
一.Linux下mysql彻底卸载 1.查看mysql的安装情况 rpm -qa | grep -i mysql 2.删除上图安装的软件 rpm -ev mysql-community-libs--. ...
- Solr6.5在Centos6上的安装与配置 (一)
这篇文章主要是介绍在Centos6上Solr6.5的安装与配置. 一.安装准备及各软件使用版本说明: 1.JDK8,版本jdk1.8.0_121下载地址:jdk-8u121-linux-x64.tar ...
- CentOS-6.4-minimal版中源代码安装MySQL-5.5.38
完整版见https://jadyer.github.io/2014/09/29/centos-install-mysql/ /** * CentOS-6.4-minimal版中源代码安装MySQL-5 ...
- Docker安装mysql5.7并且配置主从复制
Docker安装mysql5.7并且配置主从复制 一.拉取mysql镜像 二.创建文件docker.cnf 2.1 mysql主机(192.168.21.55:3307) 2.1.1 创建文件夹 2. ...
- 在centos6上实现编译安装lamp和wordpress,并编译xcache
author:JevonWei 版权声明:原创作品 软件环境: centos6.9 httpd-2.4.27.tar.bz2 apr-1.5.2.tar.bz2 apr-util-1.5.4.tar. ...
- 在CentOS6上利用PXE+Kickstart+Apache+DHCP实现无人值守安装
在CentOS6上利用PXE+Kickstart+Apache+DHCP实现无人值守安装 1.PXEServer:OS:CentOS6.9IP:172.16.25.69: (1)apache:# mo ...
- 在 CentOS6 上安装 GraphicsMagick-1.3.30
在 CentOS6 上安装 GraphicsMagick-1.3.30 1.简介: 1.1.在介绍 GraphicsMagick 前我们不得不先介绍下 ImageMagick: ImageMagick ...
- vmware上搭建kickstart 网络安装centos6.2的过程
前言 什么是PXE? PXE(Pre-boot Execution Environment,预启动执行环境)协议使计算机可以通过网络启动.协议分client和server. PXE client 在网 ...
- CentOS7.5 上使用 bundle 文件安装 MySQL8.0 MySQL5.0
CentOS7.5 上使用 bundle 文件安装 MySQL8.0 MySQL5.0 CentOS7.5 环境 [root@instance-fjii60o3 ~]# rpm -qi centos- ...
随机推荐
- Python自学笔记-进程,线程(Mr serven)
对于操作系统来说,一个任务就是一个进程(Process),比如打开一个浏览器就是启动一个浏览器进程,打开一个记事本就启动了一个记事本进程,打开两个记事本就启动了两个记事本进程,打开一个Word就启动了 ...
- HDU1421搬寝室(简单DP)
当然,还可以加滚动数组优化. #include<cstdio> #include<cstdlib> #include<iostream> #include<m ...
- 一个demo学会js
全栈工程师开发手册 (作者:栾鹏) 快捷链接: js系列教程1-数组操作全解 js系列教程2-对象和属性全解 js系列教程3-字符串和正则全解 js系列教程4-函数与参数全解 js系列教程5-容器和算 ...
- cocos2dx - tmx地图分层移动处理
接上一节内容:cocos2dx - 节点管理 瓦片地图(Tiled Map) 在cocos2dx文档中有简单的介绍及使用.详情可以看:http://www.cocos2d-x.org/docs/man ...
- linux_base_commond_one
1.cd commond a. cd usr 切换到该目录下usr目录 b. cd ../ 切换到上一层目录 c.cd / 切换到系统根目录 d. cd ~ 切换到用户主目录 e. cd - 切 ...
- mybatis的搭建和注入spring的方式
mybatis实际上是一个更多关注sql语句的框架,他的出现是想让开发者更简单的去操作数据库. 与hibernate相比较,hibernate更多的是去sql化,虽然hibernate也可以本地sql ...
- win10 uwp Window.Current.Dispatcher中Current为null
本文说的是进行网络中异步界面出现的错误,可能带有一定的主观性和局限性,说的东西可能不对或者不符合每个人的预期.如果觉得我有讲的不对的,就多多包含,或者直接关掉这篇文章,但是请勿生气或者发怒吐槽,可以在 ...
- Java并发编程之原子变量
原子变量最主要的一个特点就是所有的操作都是原子的,synchronized关键字也可以做到对变量的原子操作.只是synchronized的成本相对较高,需要获取锁对象,释放锁对象,如果不能获取到锁,还 ...
- 【CSS】伪类和伪元素选择器
伪类 基于当前元素所处的状态或具有的特性,用于设置元素自身的特殊效果. a:link 规定所有未被点击的链接: a:visited 匹配多有已被点击过的链接: a:active 匹配所有鼠标按下 ...
- 阿里官方Java代码规范标准《阿里巴巴Java开发手册 终极版 v1.3.0》
终极版 v1.3.0 2017年开春之际,阿里诚意献上重磅大礼:<阿里巴巴Java开发手册>,首次公开阿里官方Java代码规范标准.这套Java统一规范标准将有助于提高行业编码规范化水平, ...