系统: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安装和主从复制部署的更多相关文章

  1. MySQL5.7安装、主从复制、读写分离原理解析以及详细配置

    一.Linux下mysql彻底卸载 1.查看mysql的安装情况 rpm -qa | grep -i mysql 2.删除上图安装的软件 rpm -ev mysql-community-libs--. ...

  2. Solr6.5在Centos6上的安装与配置 (一)

    这篇文章主要是介绍在Centos6上Solr6.5的安装与配置. 一.安装准备及各软件使用版本说明: 1.JDK8,版本jdk1.8.0_121下载地址:jdk-8u121-linux-x64.tar ...

  3. CentOS-6.4-minimal版中源代码安装MySQL-5.5.38

    完整版见https://jadyer.github.io/2014/09/29/centos-install-mysql/ /** * CentOS-6.4-minimal版中源代码安装MySQL-5 ...

  4. Docker安装mysql5.7并且配置主从复制

    Docker安装mysql5.7并且配置主从复制 一.拉取mysql镜像 二.创建文件docker.cnf 2.1 mysql主机(192.168.21.55:3307) 2.1.1 创建文件夹 2. ...

  5. 在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. ...

  6. 在CentOS6上利用PXE+Kickstart+Apache+DHCP实现无人值守安装

    在CentOS6上利用PXE+Kickstart+Apache+DHCP实现无人值守安装 1.PXEServer:OS:CentOS6.9IP:172.16.25.69: (1)apache:# mo ...

  7. 在 CentOS6 上安装 GraphicsMagick-1.3.30

    在 CentOS6 上安装 GraphicsMagick-1.3.30 1.简介: 1.1.在介绍 GraphicsMagick 前我们不得不先介绍下 ImageMagick: ImageMagick ...

  8. vmware上搭建kickstart 网络安装centos6.2的过程

    前言 什么是PXE? PXE(Pre-boot Execution Environment,预启动执行环境)协议使计算机可以通过网络启动.协议分client和server. PXE client 在网 ...

  9. CentOS7.5 上使用 bundle 文件安装 MySQL8.0 MySQL5.0

    CentOS7.5 上使用 bundle 文件安装 MySQL8.0 MySQL5.0 CentOS7.5 环境 [root@instance-fjii60o3 ~]# rpm -qi centos- ...

随机推荐

  1. VisualStudio快捷键大全

    Ctrl+m+Crtr+o折叠所有大纲Ctrl+M+Crtr+P: 停止大纲显示Ctrl+K+Crtr+C: 注释选定内容Ctrl+K+Crtr+U: 取消选定注释内容Ctrl+J : 列出成员 智能 ...

  2. 实验:实现https

    实现https 环境 1.三台主机分别为A,B,C. 2.A主机设置为CA和DNS服务器,ip为192.168.213.129 3.B主机为client,ip为192.168.213.253 4.C主 ...

  3. 知识树杂谈Java面试(4)

    一. Java集合 1.  集合分类:  Collection.Map. 2. Collection: 3. Map 4. 注意点 a. List 有序.可重复:Set 无序.不可重复:Map  键值 ...

  4. win10 uwp 绑定静态属性

    Jasoon 大神问,如何绑定静态属性. 我们经常有静态属性,那么我们如何绑定 假如我们的ViewModel有一个静态属性 public static string CVTE { set; get; ...

  5. win10 UWP 蜘蛛网效果

    我看见了知乎首页登录背景和普通的地球人写的博客,发现了个好看的效果. 那么我来告诉大家如何做这个效果. 第一步是在 Canvas 画点,第二步是让点移动,第三步是画线 在 Canvas 画一个点 我们 ...

  6. HTML之事件处理程序

    HTML事件 <body> <input type="button" value="按钮1" id="but1" oncl ...

  7. Spring 笔记总结

    1.Spring框架的核心是提供一个容器(BeanFactory 或 ApplicationContext),提供以下功能: 1)创建和销毁组件对象,类似"工厂类" 2)采用不同的 ...

  8. Java基础-方法(07)

    方法的定义 方法其实就是完成特定功能的代码块在很多语言里面都有函数的定义函数在Java中被称为方法 格式: 修饰符 返回值类型 方法名(参数类型 参数名1,参数类型 参数名2…) { 函数体; ret ...

  9. LeetCode Questions List (LeetCode 问题列表)- Java Solutions

    因为在开始写这个博客之前,已经刷了100题了,所以现在还是有很多题目没有加进来,为了方便查找哪些没加进来,先列一个表可以比较清楚的查看,也方便给大家查找.如果有哪些题目的链接有错误,请大家留言和谅解, ...

  10. LeetCode 695. Max Area of Island (岛的最大区域)

    Given a non-empty 2D array grid of 0's and 1's, an island is a group of 1's (representing land) conn ...