说明:

操作系统:CentOS 5.x 64位

MySQL数据库版本:mysql-5.5.35

MySQL主服务器:192.168.21.128

MySQL从服务器:192.168.21.129

准备篇:

说明:在两台MySQL服务器192.168.21.128和192.168.21.129上分别进行如下操作

备注:

作为主从服务器的MySQL版本建议使用同一版本!

或者必须保证主服务器的MySQL版本要高于从服务器的MySQL版本!

一、配置好IP、DNS 、网关,确保使用远程连接工具能够连接服务器

二、配置防火墙,开启3306端口

vi /etc/sysconfig/iptables  #编辑

-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT  #允许3306端口

特别提示:如果这两条规则添加到防火墙配置的最后一行,导致防火墙启动失败,正确的应该是添加到默认的22端口这条规则的下面,添加好之后防火墙规则如下所示:

#########################################################

# Firewall configuration written by system-config-securitylevel

# Manual customization of this file is not recommended.

*filter

:INPUT ACCEPT [0:0]

:FORWARD ACCEPT [0:0]

:OUTPUT ACCEPT [0:0]

:RH-Firewall-1-INPUT - [0:0]

-A INPUT -j RH-Firewall-1-INPUT

-A FORWARD -j RH-Firewall-1-INPUT

-A RH-Firewall-1-INPUT -i lo -j ACCEPT

-A RH-Firewall-1-INPUT -p icmp --icmp-type any -j ACCEPT

-A RH-Firewall-1-INPUT -p 50 -j ACCEPT

-A RH-Firewall-1-INPUT -p 51 -j ACCEPT

-A RH-Firewall-1-INPUT -p udp --dport 5353 -d 224.0.0.251 -j ACCEPT

-A RH-Firewall-1-INPUT -p udp -m udp --dport 631 -j ACCEPT

-A RH-Firewall-1-INPUT -p tcp -m tcp --dport 631 -j ACCEPT

-A RH-Firewall-1-INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT

-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT

-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT

-A RH-Firewall-1-INPUT -j REJECT --reject-with icmp-host-prohibited

COMMIT

#########################################################

/etc/init.d/iptables restart #最后重启防火墙使配置生效

三、关闭SELINUX

vi /etc/selinux/config

#SELINUX=enforcing #注释掉

#SELINUXTYPE=targeted #注释掉

SELINUX=disabled #增加

:wq  #保存退出

setenforce 0 #立即生效

四 、系统约定

软件源代码包存放位置:/usr/local/src

源码包编译安装位置:/usr/local/软件名字

五、下载软件包

1、下载MySQL

http://cdn.mysql.com/Downloads/MySQL-5.5/mysql-5.5.35.tar.gz

2、下载cmake(MySQL编译工具)

http://www.cmake.org/files/v2.8/cmake-2.8.12.1.tar.gz

以上软件包上传到/usr/local/src目录

六、安装编译工具及库文件(使用CentOS yum命令安装)

yum install -y make apr* autoconf automake curl curl-devel gcc gcc-c++ gtk+-devel zlib-devel openssl openssl-devel pcre-devel gd kernel keyutils patch perl kernel-headers compat*  cpp glibc libgomp libstdc++-devel keyutils-libs-devel libsepol-devel libselinux-devel krb5-devel  libXpm* freetype freetype-devel freetype* fontconfig fontconfig-devel  libjpeg* libpng* php-common php-gd gettext gettext-devel ncurses* libtool* libxml2 libxml2-devel patch policycoreutils bison

安装篇

说明:在两台MySQL服务器192.168.21.128和192.168.21.129上分别进行如下操作,安装mysql-5.5.35

以下是远程登录到服务器,在命令行下面操作的

一、安装cmake

cd /usr/local/src

tar zxvf cmake-2.8.12.1.tar.gz

cd cmake-2.8.12.1

./configure

make #编译

make install #安装

二、安装mysql

groupadd mysql  #添加mysql组

useradd -g mysql mysql -s /bin/false #创建用户mysql并加入到mysql组,不允许mysql用户直接登录系统

mkdir -p /data/mysql #创建MySQL数据库存放目录

chown -R mysql:mysql /data/mysql   #设置MySQL数据库目录权限

mkdir -p /usr/local/mysql-5.5.35 #创建MySQL安装目录

ln -s /usr/local/mysql-5.5.35 /usr/local/mysql  #创建软连接到mysql目录,方便后面的配置

cd /usr/local/src

tar zxvf mysql-5.5.35.tar.gz  #解压

cd mysql-5.5.35

cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql  -DMYSQL_DATADIR=/data/mysql  -DSYSCONFDIR=/etc   #配置

make #编译

make install  #安装

cd /usr/local/mysql

cp ./support-files/my-huge.cnf  /etc/my.cnf  #拷贝配置文件(注意:如果/etc目录下面默认有一个my.cnf,直接覆盖即可)

vi /etc/my.cnf  #编辑配置文件,在 [mysqld] 部分增加

datadir = /data/mysql  #添加MySQL数据库路径

./scripts/mysql_install_db --user=mysql  #生成mysql系统数据库

cp ./support-files/mysql.server  /etc/rc.d/init.d/mysqld  #把Mysql加入系统启动

chmod 755 /etc/init.d/mysqld  #增加执行权限

chkconfig mysqld on #加入开机启动

vi /etc/rc.d/init.d/mysqld  #编辑

basedir = /usr/local/mysql   #MySQL程序安装路径

datadir = /data/mysql  #MySQl数据库存放目录

service mysqld start #启动

vi /etc/profile  #把mysql服务加入系统环境变量:在最后添加下面这一行

export PATH=$PATH:/usr/local/mysql/bin

source  /etc/profile#使配置立即生效

下面这两行把myslq的库文件链接到系统默认的位置,这样你在编译类似PHP等软件时可以不用指定mysql的库文件地址。

ln -s /usr/local/mysql/lib/mysql /usr/lib/mysql

ln -s /usr/local/mysql/include/mysql /usr/include/mysql

mkdir /var/lib/mysql  #创建目录

ln -s /tmp/mysql.sock  /var/lib/mysql/mysql.sock  #添加软链接

mysql_secure_installation  #设置Mysql密码,根据提示按Y 回车输入2次密码

/usr/local/mysql/bin/mysqladmin -u root -p password "123456"   #或者直接修改密码

到此,mysql安装完成!

配置篇

一、配置MySQL主服务器(192.168.21.128)

mysql -u root -p  #进入MySQL控制台

create database osyunweidb;  #建立数据库osyunweidb

insert into mysql.user(Host,User,Password) values('localhost','osyunweiuser',password('123456'));   #创建用户osyunweiuser,密码123456

grant all on osyunweidb.* to 'osyunweiuser'@'192.168.21.130' identified by '123456' with grant option;  #授权用户osyunweiuser从192.168.21.130完全访问数据库,注意:这里的192.168.21.130是要连接数据库Web服务器IP

insert into mysql.user(Host,User,Password) values('localhost','osyunweidbbak',password('123456'));   #建立MySQL主从数据库同步用户osyunweidbbak密码123456

flush privileges;   #刷新系统授权表

grant replication slave  on *.* to 'osyunweidbbak'@'192.168.21.129' identified by '123456' with grant option; #授权用户osyunweidbbak只能从192.168.21.129这个IP访问主服务器192.168.21.128上面的数据库,并且只具有数据库备份的权限

二、把MySQL主服务器192.168.21.128中的数据库osyunweidb导入到MySQL从服务器192.168.21.129中

1、导出数据库osyunweidb

mysqldump -u root -p --default-character-set=utf8 --opt -Q -R --skip-lock-tables osyunweidb > /home/osyunweidbbak.sql    #在MySQL主服务器进行操作,导出数据库osyunweidb到/home/osyunweidbbak.sql

备注:在导出之前可以先进入MySQL控制台执行下面命令

flush tables with read lock;    #数据库只读锁定命令,防止导出数据库的时候有数据写入

unlock tables;   #解除锁定

scp /home/osyunweidbbak.sql root@192.168.21.129:/home  #把home目录下的osyunweidbbak.sql 数据库文件上传到MySQL从服务器的home目录下面

2、导入数据库到MySQL从服务器

mysql  -u root -p  #进入从服务器MySQL控制台

create database osyunweidb;   #创建数据库

use osyunweidb  #进入数据库

source  /home/osyunweidbbak.sql #导入备份文件到数据库

mysql -u osyunweidbbak -h 192.168.21.128 -p  #测试在从服务器上登录到主服务器

三、配置MySQL主服务器(192.168.21.128)的my.cnf文件

vi /etc/my.cnf #编辑配置文件,在[mysqld]部分添加下面内容

server-id=1 #设置服务器id,为1表示主服务器,注意:如果原来的配置文件中已经有这一行,就不用再添加了。

log-bin=mysql-bin #启动MySQ二进制日志系统,注意:如果原来的配置文件中已经有这一行,就不用再添加了。

binlog-do-db=osyunweidb#需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行

binlog-ignore-db=mysql  #不同步mysql系统数据库

:wq!  #保存退出

service mysqld  restart  #重启MySQL

mysql -u root -p   #进入mysql控制台

show variables like 'server_id'; #查看server-id的值是否为1

mysql> show variables like 'server_id';

+---------------+-------+

| Variable_name | Value |

+---------------+-------+

| server_id     | 1     |

+---------------+-------+

1 row in set (0.00 sec)

show master status;  #查看主服务器,出现以下类似信息

mysql> show master status;

+------------------+----------+--------------+------------------+

| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+------------------+----------+--------------+------------------+

| mysql-bin.000011 |      107 | osyunweidb   | mysql            |

+------------------+----------+--------------+------------------+

1 row in set (0.00 sec)

注意:这里记住File的值:mysql-bin.000011和Position的值:107,后面会用到。

四、配置MySQL从服务器(192.168.21.129)的my.cnf文件

vi /etc/my.cnf  #编辑配置文件,在[mysqld]部分添加下面内容

server-id=2   #设置服务器id,修改其值为2,表示为从数据库

log-bin=mysql-bin  #启动MySQ二进制日志系统,注意:如果原来的配置文件中已经有这一行,就不用再添加了。

replicate-do-db=osyunweidb  #需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行

replicate-ignore-db=mysql   #不同步mysql系统数据库

read_only  #设置数据库只读

:wq!   #保存退出

service mysqld restart #重启MySQL

mysql  -u root -p  #进入MySQL控制台

show variables like 'server_id'; #查看server-id的值,必须为上面设置的2,否则请返回修改配置文件

mysql> show variables like 'server_id';

+---------------+-------+

| Variable_name | Value |

+---------------+-------+

| server_id     | 2     |

+---------------+-------+

1 row in set (0.01 sec)

slave stop;  #停止slave同步进程

change master to master_host='192.168.21.128',master_user='osyunweidbbak',master_password='123456',master_log_file='mysql-bin.000011' ,master_log_pos=107;  #执行同步语句

slave start;   #开启slave同步进程

SHOW SLAVE STATUS\G #查看slave同步信息,出现以下内容

mysql> SHOW SLAVE STATUS\G

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event

Master_Host: 192.168.21.128

Master_User: osyunweidbbak

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: mysql-bin.000011

Read_Master_Log_Pos: 107

Relay_Log_File: mysqlslave-relay-bin.000004

Relay_Log_Pos: 253

Relay_Master_Log_File: mysql-bin.000011

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

Replicate_Do_DB: osyunweidb

Replicate_Ignore_DB: mysql

Replicate_Do_Table:

Replicate_Ignore_Table:

Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table:

Last_Errno: 0

Last_Error:

Skip_Counter: 0

Exec_Master_Log_Pos: 107

Relay_Log_Space: 560

Until_Condition: None

Until_Log_File:

Until_Log_Pos: 0

Master_SSL_Allowed: No

Master_SSL_CA_File:

Master_SSL_CA_Path:

Master_SSL_Cert:

Master_SSL_Cipher:

Master_SSL_Key:

Seconds_Behind_Master: 0

Master_SSL_Verify_Server_Cert: No

Last_IO_Errno: 0

Last_IO_Error:

Last_SQL_Errno: 0

Last_SQL_Error:

Replicate_Ignore_Server_Ids:

Master_Server_Id: 1

1 row in set (0.00 sec)

mysql>

注意查看:

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

以上这两个参数的值为Yes,即说明配置成功!

测试篇

测试MySQL主从服务器是否正常运行

1、进入MySQL主服务器(192.168.21.128)

mysql -u root -p  #进入MySQL控制台

use osyunweidb #进入数据库

CREATE TABLE test ( id int not null primary key,name char(20) );   #创建test表

2、进入MySQL从服务器

mysql -u root -p #进入MySQL控制台

use osyunweidb   #进入数据库

show  tables; #查看osyunweidb表结构,会看到有一个新建的表test,表示数据库同步成功

mysql> show  tables;

+----------------------+

| Tables_in_osyunweidb |

+----------------------+

| test                 |

+----------------------+

1 row in set (0.00 sec)

至此,Linux下MySQL数据库主从同步配置完成!

linux mysql 主从数据库_Linux下MySQL数据库主从同步配置相关推荐

  1. linux 查找文件 mysql数据库_Linux下MySQL数据库目录多了好多文件

    发现Linux下Mysql数据库目录多了好多Mysql-bin.0000X这些文件,经过自己查找资料确认了这些就是二进制日志文件,因为数据库重要,所以步步要小心,我需要非常确认这些文件可以删除才删除, ...

  2. yum mysql 启动失败_Linux下MySQL数据库yum升级后无法启动解决办法 | 系统运维

    说明: 操作系统:CentOS 5.8 Web运行环境:Apache+MySQL+PHP(全部使用yum命令在线安装) Apache版本:2.2.3 MySQL版本:5.0.95 PHP版本:5.1. ...

  3. mysql putty 备份_Linux下mysql数据库的备份-putty

    前提:具有ssh登陆权限 工作步骤: 下载软件putty,设置ssh 登陆选项 登陆后,进入自己的主页目录*(通过FTP可以访问到) 执行mysqldump命令可执行数据库备份,而mysqlresto ...

  4. linux mysql 端口号_linux下mysql 查看默认端口号与修改端口号方法

    一.查看默认端口号 1.登录mysql [root@localhost ~]# mysql -uroot -p Enter password: 输入数据库密码: 2.使用show global var ...

  5. linux下mysql目录结构_linux下mysql安装配置与目录结构

    本节内容: linux下mysql安装与配置.mysql目录结构. 1.准备安装程序(官方网站下载) 服务端:MySQL-server-community-5.1.44-1.rhel4.i386.rp ...

  6. linux mysql dump命令_linux下mysql命令

    1.linux下启动mysql的命令: mysqladmin start /ect/init.d/mysql start (前面为mysql的安装路径) 2.linux下重启mysql的命令: mys ...

  7. linux上mysql卸数_Linux下MySQL卸载和安装图文教程

    Linux下MySQL卸载和安装图文教程 发布时间:2020-09-02 08:43:17 来源:脚本之家 阅读:59 作者:伊宇紫 第一次写博客,做了两年的开发,工作之余给自己找点有意义的事做,分享 ...

  8. linux mysql 超级用户_Linux下MySQL忘记超级用户口令的解决办法linux操作系统 -电脑资料...

    以前我都是讲述在windows中忘记了mysql root密码的找回方法,下面我来介绍在Linux下MySQL忘记超级用户口令的解决办法,有碰到此类问题的同学可进入参考, 解决办法一 MySQL忘记超 ...

  9. linux mysql 装哪里_linux 下 mysql 安装目录在哪里

    linux 下 mysql 安装目录在哪里.linux mysql 安装介绍: linux 服务器 RedHat 5.0.server. MySQL 版本: 下载地址链接:http://dev.mys ...

  10. linux下mysql的创建_linux下mysql创建库命令

    Linux下mysql数据库要怎么通过命令来创建一个新的数据库呢?下面由学习啦小编为大家整理了linux下mysql创建库命令的相关知识,希望对大家有帮助! linux下mysql创建库命令方法步骤 ...

最新文章

  1. 第五届全国大学生计算机系统能力培养大赛 | 赠书
  2. FPGA 的I/O BANK介绍
  3. 算法设计与分析课程的时间空间复杂度
  4. 聚类(上)K-mean算法
  5. OpenGL波浪模拟
  6. Good Bye 2017 G. New Year and Original Order 数位dp + 按数贡献
  7. OpenCV中神经网络的应用
  8. x264 x264_slicetype_analyse 函数分析
  9. 记事本编程开发以及IDEA编程开发
  10. 课程设计-基于SSM实现个人健康管理系统
  11. Android APP功能测试(个人总结完整版)
  12. python gif压缩_基于python压缩gif图片大小。
  13. Web前端工程师学习路线
  14. dvanced Installer Architect
  15. 吸粉神器——维盟智慧wifi,微信粉丝生产基地!
  16. 苹果新产品中的机器学习算法
  17. 锐捷ruijie无线控制器AC登录说明
  18. 有没有压缩视频的软件?能压缩视频的软件?压缩视频用什么软件比较好?
  19. 椭圆机会不会练出肌肉腿
  20. 我学习从事项目经理第五课

热门文章

  1. R语言中的字符串处理函数
  2. markdownFormat
  3. 详解MySQL中EXPLAIN解释命令(转)
  4. 终结VC2005分发包版本问题
  5. 拓端tecdat|R语言状态空间模型:卡尔曼滤波器KFAS建模时间序列
  6. 7-10 统计字符出现次数 (20 point(s))
  7. django数据库增删改查操作
  8. Java从入门到精通 第21章 Annotation
  9. sphinx mysql实时搜素_【原创】sphinx实时索引的配置及实际应用、实例
  10. linux上pybind11编辑python库