时间:2021-07-01 10:21:17 帮助过:4人阅读
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服务器可以查到,这就表示双机热备配置成功了。
鼎峰小胡
QQ.2881064155
Skype.2881064155@qq.com
CentOS下Mysql双机热备安装详解
标签: