Mysql双机热备安装文档
Mysql双机热备安装文档
1. 安装环境和资源
211.88.22.74 4CPU 8G 120G硬盘 centos6.5_64
211.88.22.73 4CPU 8G 120G硬盘 centos6.5_64
服务器两台。这里使用211.88.22.74作为主服务器,211.88.22.73作为从服务器。
1.1 mysql下载地址
a. 官方下载地址:
http://dev.mysql.com/downloads/mysql/#downloads
或镜像文件下载:
http://dev.mysql.com/downloads/mirrors.html
本例安装使用的是:mysql-5.6.12-linux-glibc2.5-x86_64.tar.gz。
- liunx上安装mysql
2.1安装步骤:
安装MySQL主要有两种方法:一种是通过源码自行编译安装,这种适合高级用户定制MySQL的特性,这里不做说明;另一种是通过编译过的二进制文件进行 安装。二进制文件安装的方法又分为两种:一种是不针对特定平台的通用安装方法,使用的二进制文件是后缀为.tar.gz的压缩文件;第二种是使用RPM或 其他包进行安装,这种安装进程会自动完成系统的相关配置,所以比较方便。
a. 通用安装方法
mysql-5.6.12-linux-glibc2.5-x86_64.tar.gz
b.RPM安装方法:
mysql-5.6.12-linux-glibc2.5-x86_64.rpm
mysql-5.6.12-linux-glibc2.5-x86_64.rpm
2.1.1 通用安装步骤
检查是否已安装,grep的-i选项表示匹配时忽略大小写
[root@cloudview73 ~]#rpm -qa|grep -i mysql
mysql-libs-5.1.61-4.el6.x86_64
*可见已经安装了库文件,应该先卸载,不然会出现覆盖错误。注意卸:载时使用了–nodeps选项,忽略了依赖关系:
[root@cloudview73 ~]#rpm -e mysql-libs-5.1.61-4.el6.x86_64 –nodeps
添加mysql组和mysql用户,用于设置mysql安装目录文件所有者和所属组。
[root@cloudview73 ~]#groupadd mysql
[root@cloudview73 ~]#useradd -r -g mysql mysql
*useradd -r参数表示mysql用户是系统用户,不可用于登录系统。
将二进制文件解压到指定的安装目录,我们这里指定为/usr/local
[root@cloudview73 ~]# cd/usr/local/
[ncp@cloudview73 local]$ tar -zxvf mysql-5.6.12-linux-glibc2.5-x86_64.tar.gz
*加压后在/usr/local/生成了解压后的文件夹mysql-5.6.12-linux-glibc2.5-x86_64,这名字太长,我们为它建立一个符号链接mysql,方便输入。
[root@cloudview73 ~]#ln -s mysql-5.6.12-linux-glibc2.5-x86_64 mysql
/usr/local/mysql/下的目录结构
进入mysql文件夹,也就是mysql所在的目录,并更改所属的组和用户。
[ncp@cloudview73 local] cdmysql[ncp@cloudview73local] chown -R mysql .
[ncp@cloudview73 local]$ chgrp -R mysql .
注意:后面的那个点不要忘了,否则会报错。
执行mysql_install_db脚本,对mysql中的data目录进行初始化并创建一些系统表格。注意 mysql服务进程mysqld运行时会访问data目录,所以必须由启动mysqld进程的用户(就是我们之前设置的mysql用户)执行这个脚本,或 者用root执行,但是加上参数–user=mysql。
[root@localhost mysql]scripts/mysql_install_db –user=mysql
*如果mysql的安装目录(解压目录)不是/usr/local/mysql,那么还必须指定目录参数,如
[root@localhost mysql]scripts/mysql_install_db –user=mysql \
–basedir=/opt/mysql/mysql \
–datadir=/opt/mysql/mysql/data
*将mysql/目录下除了data/目录的所有文件,改回root用户所有,mysql用户只需作为mysql/data/目录下所有文件的所有者。
[root@localhost mysql]chown -R root .
[root@localhost mysql]chown -R mysql data
复制配置文件
[root@localhost mysql] cp support-files/my-default.cnf /ect/my.cnf
将mysqld服务加入开机自启动项。
*首先需要将scripts/mysql.server服务脚本复制到/etc/init.d/,并重命名为mysqld。
[root@localhostmysql] cp support-files/mysql.server /etc/init.d/mysqld
*通过chkconfig命令将mysqld服务加入到自启动服务项中。
[root@localhost mysql]#chkconfig –add mysqld
*注意服务名称mysqld就是我们将mysql.server复制到/etc/init.d/时重命名的名称。
*查看是否添加成功
[root@localhost mysql]#chkconfig –list mysqld
mysqld 0:off
1:off 2:on 3:on 4:on 5:on 6:off
i. 重启系统,mysqld就会自动启动了。
*检查是否启动
root@localhost mysql]#netstat -anp|grep mysqld
tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 2365/mysqld
unix 2 [ ACC ] STREAM LISTENING 14396 2365/mysqld /tmp/mysql.sock
*如果不想重新启动,那可以直接手动启动。
[root@localhost mysql]#service mysqld start
Starting MySQL.. SUCCESS!
j. 运行客户端程序mysql,在mysql/bin目录中,测试能否连接到mysqld。
[root@localhost mysql]#/usr/local/mysql/bin/mysql
Welcome to the MySQLmonitor. Commands end with ; or \g.
Your MySQL connection idis 2
Server version:5.5.29-log MySQL Community Server (GPL)
Copyright (c) 2000, 2012,Oracle and/or its affiliates. All rights reserved.
Oracle is a registeredtrademark of Oracle Corporation and/or its affiliates. Other names may betrademarks of their respective owners.
Type ‘help;’ or ‘\h’ forhelp. Type ‘\c’ to clear the current input statement.
mysql> quit
Bye
*此时会出现mysql>命令提示符,可以输入sql语句,输入quit或exit退出。为了避免每次都输入mysql的全路径/usr/local/mysql/bin/mysql,可将其加入环境变量中,在/etc/profile最后加入两行命令:
MYSQL_HOME=/usr/local/mysql
export PATH=
PATH:
MYSQL_HOME/bin
这样就可以在shell中直接输入mysql命令来启动客户端程序了
[root@localhost mysql]#mysql
Welcome to the MySQLmonitor. Commands end with ; or \g.
Your MySQL connection idis 3
Server version:5.5.29-log MySQL Community Server (GPL)
Copyright (c) 2000, 2012,Oracle and/or its affiliates. All rights reserved.
Oracle is a registeredtrademark of Oracle Corporation and/or its
affiliates. Other namesmay be trademarks of their respective
owners.
Type ‘help;’ or ‘\h’ forhelp. Type ‘\c’ to clear the current input statement.
mysql>
源码包到此安装完毕。
3. rpm方式安装mysql
4. 检查是否已安装,grep的-i选项表示匹配时忽略大小写
5. [root@localhost JavaEE]#rpm -qa|grep -i mysql
6. mysql-libs-5.1.61-4.el6.x86_64
7. 可见已经安装了库文件,应该先卸载,不然会出现覆盖错误。注意卸载时使用了–nodeps选项,忽略了依赖关系:
8. [root@localhost JavaEE]#rpm -e mysql-libs-5.1.61-4.el6.x86_64 –nodeps
9. 2. 安装MySQL的服务器端软件,注意切换到root用户:
10. [root@localhost JavaEE]#rpm –ivh
MySQL-server-5.6.12-2.el6.x86_64.rpm安装完成后,安装进程会在Linux中添加一个mysql组,以及属于mysql组的用户mysql。可通过id命令查看:
11. [root@localhost JavaEE]#id mysql
12. uid=496(mysql)gid=493(mysql) groups=493(mysql)
13. MySQL服务器安装之后虽然配置了相关文件,但并没有自动启动mysqld服务,需自行启动:
14. [root@localhost JavaEE]#service mysql start
15. Starting MySQL.. SUCCESS!
16. 可通过检查端口是否开启来查看MySQL是否正常启动:
17. [root@localhost JavaEE]#netstat -anp|grep 3306
18. tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 34693/mysqld
19. c. 安装MySQL的客户端软件:
20. [root@localhost JavaEE]#rpm -ivh MySQL-client-5.6.12-6.x86_64.rpm
21. 如果安装成功应该可以运行mysql命令,注意必须是mysqld服务以及开启:
22. [root@localhost JavaEE]#mysql
23. Welcome to the MySQLmonitor. Commands end with ; or \g.
24. Your MySQL connection idis 1
25. Server version: 5.5.29MySQL Community Server (GPL)
26. Copyright (c) 2000, 2012,Oracle and/or its affiliates. All rights reserved.
27. Oracle is a registered trademarkof Oracle Corporation and/or its affiliates. Other names may be trademarks oftheir respective owners.
28. Type ‘help;’ or ‘\h’ forhelp. Type ‘\c’ to clear the current input statement.
29. mysql>
RPM安装方式文件分布
到此mysql安装完毕。主服务器和从服务器两台机器都安装上mysql。
4.开始主从设置
配置MySQL主服务器(211.88.22.74)
进入mysql操作界面,在主服务器上为从服务器建立一个连接帐户,该帐户必须授予REPLICATION SLAVE权限。因为从mysql版本3.2以后就可以通过REPLICATION对其进行双机热备的功能操作。
操作指令如下:
mysql> grant replication slave on . to ‘iec’@’ 211.88.22.74’ identified by ‘iec2016
mysql> flush privileges;
创建好同步连接帐户后,我们可以通过在从服务器(Slave)上用replicat帐户对主服务器(Master)数据库进行访问下,看下是否能连接成功。
在从服务器(Slave)上输入如下指令:
[root@YD146 ~]# mysql -h 211.88.22.74 -uiec –piec2016
如果出现下面的结果,则表示能登录成功,说明可以对这两台服务器进行双机热备进行操作。
修改mysql配置文件
如果上面的准备工作做好,那边我们就可以进行对mysql配置文件进行修改了,首先找到mysql配置所有在目录,一般在安装好mysql服务后,都会将配置文件复制一一份出来放到/ect目录下面,并且配置文件命名为:my.cnf。即配置文件准确目录为/etc/my.cnf
找到配置文件my.cnf打开后,在[mysqld]下修改即可:
server-id = 1
log-bin=mysql-bin //其中这两行是本来就有的,可以不用动,添加下面两行即可
binlog-do-db = cieccNcp
binlog-ignore-db = mysql
重启mysql服务
修改完配置文件后,保存后,重启一下mysql服务,如果成功则没问题。
查看主服务器状态
进入mysql服务后,可通过指令查看Master状态,输入如下指令:
注意看里面的参数,特别前面两个File和Position,在从服务器(Slave)配置主从关系会有用到的。
注:这里使用了锁表,目的是为了产生环境中不让进新的数据,好让从服务器定位同步位置,初次同步完成后,记得解锁。
从服务器Slave配置
修改配置文件
因为这里面是以主-从方式实现mysql双机热备的,所以在从服务器就不用在建立同步帐户了,直接打开配置文件my.cnf进行修改即可,道理还是同修改主服务器上的一样,只不过需要修改的参数不一样而已。如下:
[mysqld]
server-id = 2
log-bin=mysql-bin
replicate-do-db =cieccNcp
replicate-ignore-db = mysql
重启mysql服务
用change mster 语句指定同步位置
这步是最关键的一步了,在进入mysql操作界面后,输入如下指令:
mysql>stop slave; //先停步slave服务线程,这个是很重要的,如果不这样做会造成以下操作不成功。
mysql>change master to
master_host=’211.88.22.74’,master_user=’iec’,master_password=’iec2016’,
master_log_file=’ mysql-bin.000016 ‘,master_log_pos=107;
注:master_log_file, master_log_pos由主服务器(Master)查出的状态值中确定。也就是刚刚叫注意的。master_log_file对应File, master_log_pos对应Position。Mysql 5.x以上版本已经不支持在配置文件中指定主服务器相关选项。
遇到的问题,如果按上面步骤之后还出现如下情况:
则要重新设置slave。指令如下
mysql>stop slave;
mysql>reset slave;
之后停止slave线程重新开始。成功后,则可以开启slave线程了。
mysql>start slave;
查看从服务器(Slave)状态
出现如图下红框中的状态表示配置成功。
查看下面两项值均为Yes,即表示设置从服务器成功。
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
到此主备配置完毕。下面测试一下。
测试同步
之前开始已经说过了在数据库cieccNcp只有一个表tb_mobile没有数据,我们可以先查看下两服务器的数据库是否有数据:
主服务器上:211.88.22.74
从服务器上:211.88.22.73
现在主从服务器上都是空的。
我们在主服务器上插入一条数据看看是否同步:
下面我们在看下从服务器上有没有备份这条数据:
可以从上面两个截图上看出,在Master服务器上进行插入的数据在Slave服务器可以查到,这就表示双机热备配置成功了。
谷营中西软件科技园—wanzuwodou!!!!!!!!!!!!!!!!!!