MySQL的Master/Slave群集安装和配置
本文介绍MySQL的Master/Slave群集安装和配置,版本号安装最新的稳定版GA 5.6.19。
为了支持有限HA。我们用Master/Slave读写简单孤立的集群。有限HA这是当Master不可用,数据不会丢失。但在Master写的,必须手工处理故障。假设要支持更高的可用性。能够使用两台Master来做热切换。
Master和Slave的MySQL安装是同样的,仅仅是my.cnf的配置不同,须要配置二进制日志文件复制。
没有特殊说明,命名中带#的为root用户操作。带$的为mysql Linux用户的操作。
安装准备
1. 在安装MySQL前,须要确认以下的系统软件已经安装在Linux中。
|
软件名称 |
软件描写叙述 |
|
gcc-4.4.7 |
编程语言编译器 |
|
gcc-c++-4.4.7 |
C++语言编译器 |
|
cmake-2.6.4-5 |
跨平台的开源构建系统 |
|
ncurses-devel-5.7-3.20090208 |
控制打印控制台屏幕 |
2. 创建mysql Linux用户
# groupadd mysql
# useradd -g mysql mysql
# passwd mysql
3. 准备安装文件夹
创建MySQL安装文件夹,并赋权限给mysql用户:
# mkdir /usr/local/mysql-5.6.19
# chown mysql:mysql /usr/local/mysql-5.6.19
# chmod -R 770 /usr/local/mysql-5.6.19
4. 创建MySQL数据存储文件夹:
# mkdir /data
# mkdir /data/mysql
# chown mysql:mysql /data/mysql
5. 授权MySQL解压源代码文件夹/usr/local/src文件夹的可运行权限给全部用户:
# chmod -R 757 /usr/local/src
安装MySQL
1. 解压缩安装包:
$ cd /usr/local/src
$ tar -xzvf mysql-5.6.19.tar.gz
2. 配置MySQL编译參数
$ cd /usr/local/src/mysql-5.6.19
$ cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql-5.6.19\
-DMYSQL_DATADIR=$MYSQL_DATA_PATH\
-DSYSCONFDIR=/usr/local/mysql-5.6.19/conf\
-DDEFAULT_CHARSET=utf8\
-DDEFAULT_COLLATION=utf8_general_ci\
-DWITH_READLINE=1\
-DWITH_INNOBASE_STORAGE_ENGINE=1\
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1
备注:
-DCMAKE_INSTALL_PREFIX: 配置MySQL的安装文件夹。
-DMYSQL_DATADIR: 配置MySQL的数据文件夹。
-DSYSCONFDIR: 配置MySQL的配置文件文件夹。
-DDEFAULT_CHARSET: 默认字符集。
-DDEFAULT_COLLATION:设定默认语言的排序规则。
-DWITH_READLINE:支持批量导入mysql数据。
-DWITH_INNOBASE_STORAGE_ENGINE:使用INNOBASE存储引擎。
-DWITH_ARCHIVE_STORAGE_ENGINE:常应用于日志记录和聚合分析,不支持索引。
-DWITH_BLACKHOLE_STORAGE_ENGINE:黑洞存储引擎。
-DWITH_PERFSCHEMA_STORAGE_ENGINE:性能模式引擎。
3. 运行make
$ make
$ make install
4. 改动myql用户的环境变量,添加MYSQL_HOME。并把bin加到PATH:
$ vi ~/.bash_profile
|
# User specific environment and startup programs # MySQL home文件夹 export MYSQL_HOME=/usr/local/mysql-5.6.19 PATH=$PATH:$HOME/bin:$MYSQL_HOME/bin export PATH |
初始化MySQL
1. 安装service脚本
# cp /usr/local/mysql-5.6.19/support-files/mysql.server/etc/init.d/mysqld
# chown mysql:mysql/etc/init.d/mysqld
# chmod 700 /etc/init.d/mysqld
2. 创建mysql权限数据库
$ $MYSQL_HOME/scripts/mysql_install_db--basedir=$MYSQL_HOME --datadir=/data/mysql
3. 创建PID文件文件夹
$ mkdir $MYSQL_HOME/var
my.cnf格式不对,非常easy在启动时错误,最好在原有文件的基础上通过vi工具在linux上改动。
假设文件已经损坏,能够通过默认的模板中拷贝:
$ cp $MYSQL_HOME/support-files/my-default.cnf$MYSQL_HOME/my.cnf
编辑my.cnf
$ vi $MYSQL_HOME/my.cnf
在文件里添加蓝色字体部分:
|
# For advice on how to change settings please see # http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html [mysqld] # Remove leading # and set to the amount of RAM for the most important data # cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%. innodb_buffer_pool_size = 256M innodb_flush_log_at_trx_commit=1 # Remove leading # to turn on a very important data integrity option: logging # changes to the binary log between backups. log_bin=master-bin log_bin_index=master-bin.index # These are commonly set, remove the # and set as required. # basedir = ..... datadir = /data/mysql port = 3306 # first master server id server_id = 1 socket = /tmp/mysql.sock pid-file = /usr/local/mysql-5.6.19/var/master.pid # Remove leading # to set options mainly useful for reporting servers. # The server defaults are faster for transactions and fast SELECTs. # Adjust sizes as needed, experiment to find the optimal values. # join_buffer_size = 128M # sort_buffer_size = 2M # read_rnd_buffer_size = 2M sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES |
和master的配置文件一样进行改动。但注意文件里的log文件名称、datadir和server_id等内容不同。
编辑my.cnf
$ vi $MYSQL_HOME/my.cnf
在文件里添加蓝色字体部分:
|
# For advice on how to change settings please see # http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html [mysqld] # Remove leading # and set to the amount of RAM for the most important data # cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%. innodb_buffer_pool_size = 256M innodb_flush_log_at_trx_commit=1 # Replication # relay-log=slave-relay-bin # relay-log-index=slave-relay-bin.index # These are commonly set, remove the # and set as required. # basedir = ..... datadir = /data/mysql port = 3306 # first slave server id of master 1 server_id = 101 socket = /tmp/mysql.sock pid-file = /usr/local/mysql-5.6.19/var/slave.pid # Remove leading # to set options mainly useful for reporting servers. # The server defaults are faster for transactions and fast SELECTs. # Adjust sizes as needed, experiment to find the optimal values. # join_buffer_size = 128M # sort_buffer_size = 2M # read_rnd_buffer_size = 2M sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES |
6. 启动MySQL
启动和停止master和slave都全然一样。
$ service mysqldstart
通过以下命令查看是否启动成功:
$ service mysqldstatus
7. 停止MySQL
$ service mysqld stop
管理MySQL安全性
默认MySQL的root的用户password为空。为了提高安全性,应该设置root用户一个安全的password。
在server上通过mysql用户打开MySQLclient:
$ mysql –u root
设置一个安全的password:
mysql> SET PASSWORD FORroot@localhost=PASSWORD('secret');
配置Master和Slave之间的复制
在Master上创建一个复制用户,当中secret为用户的password:
mysql> CREATEUSER repl_user IDENTIFIED BY 'secret';
并赋给复制权限:
mysql>GRANTREPLICATION SLAVE ON *.* TO repl_user;
获取读锁:
mysql> FLUSH TABLES WITHREAD LOCK;
显示当前二进制文件名称及位置值:
mysql> SHOW MASTER STATUS;
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2lsYmVydHpob3U=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">
在另外一个会话中在Master上运行:
$ mysqldump -u root-p --all-databases --master-data > data_dump.sql
运行后。保存在当前文件夹中。
4. 释放Master上的读锁
在获取读锁的会话中。运行释放锁命令:
mysql> UNLOCK TABLES;
5. 导入dump数据到Slave中
通过scp拷贝data_dump.sql到Slave的机器上。
$ scp data_dump.sqlmysql@<ip of slave>:/home/mysql
在Slave上通过以下的命令导入到Slave的MySQL中。
$ mysql –u root -p
mysql>source data_dump.sql;
6. 配置Master和Slave之间的复制
mysql> CHANGE MASTER TO MASTER_HOST='<ip
or hostame of master>',
MASTER_USER='repl_user',
MASTER_PASSWORD='secret',
MASTER_PORT = 3306,
MASTER_LOG_FILE='master-bin.000003',
MASTER_LOG_POS=881;
上面的MASTER_LOG_FILE和MASTER_LOG_POS须要配置6.2中查询到的信息。<ipor hostame of master>是Master的IP或主机名。
启动Slave:
mysql> START SLAVE;
7. 验证Master和Slave的状态
在Master上运行:
mysql> SHOW MASTER STATUS;
在Slave上运行:
mysql> SHOW SLAVE STATUS;
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2lsYmVydHpob3U=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">
上述资料显示,无论是什么错误,Slave_IO_State信息‘Waitigfor master to send event’,说明复制连接配置OK。
至今,二MySQL的Master/Slave集群模式已成功部署。能够Master运行数据更新操作,研究发现,正常的副本Slave上。
MySQL的Master/Slave群集安装和配置的更多相关文章
- mysql数据库在Linux下安装与配置
mysql是一种开放源代码的关系型数据库系统(RDBMS),使用最常用的数据库管理语言--结构化查询语句(SQL)进行数据库管理. 由于mysql的开源,因此任何人都可以在General Publ ...
- mysql数据库在windows下安装与配置
mysql是一种开源源代码的关系型数据库系统(RDBMS),使用最常用的数据库管理语言--结构化查询语句(SQL)进行数据库管理. MySQL是开放源代码的,因此任何人都可以在General Pu ...
- mysql (master/slave)复制原理及配置
1 复制概述 Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,并重 ...
- MySQL半同步复制的安装和配置
(1)检查master/slave是否支持动态加载插件 > show variables like 'have_dynamic_loading'; +---------------------- ...
- mysql源码包手动安装、配置以及测试(亲测可行)
笔记编者:小波/qq463431476博客首页:http://www.cnblogs.com/xiaobo-Linux/ 记下这篇mysql笔记,望日后有用! redhat6采用centos yum源 ...
- MySQL数据库学习笔记(一)----MySQL 5.6.21的安装和配置(setup版)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- 【MySQL】源码编译安装和配置MySql 5.5.32(单实例)
[需求描述] 在CentOS环境中,通过编译源码的方式,安装并且配置“单实例”的MySQL5.5.32数据库. MySQL的安装目录为:/application/mysql-5.5.32 MySQL数 ...
- mysql 5.6.20的安装、配置服务、设置编码格式
一.安装 安装环境 系统:Window 32 版本:Mysql 5.6.20 1. 首先从官网上http://dev.mysql.com/downloads/mysql/ ...
- MySQL数据库学习二 MSQL安装和配置
2.1 下载和安装MySQL软件 2.1.1 基于客户端/服务器(C/S)的数据库管理系统 服务器:MySQL数据库管理系统 客户端:操作MySQL服务器 2.1.2 MySQL的各种版本 社区版(C ...
随机推荐
- MongoDB使用手册
一.安装包下载地址 http://www.mongodb.org/downloads 二.服务器端使用 LINUX版本: ①用tar -zxvf mongodb-linux-x86_64-1.2.4. ...
- COCOS2D-X之圆形进度条的一个简单Demo
这应该是游戏中很常见的一个效果.显示某个事件的进度等,在加载资源或者联网的时候经常用到.所以有必要学习学习 一.我们直接在COCOS2D-X自带的HelloCpp的工程中添加代码即可.我们在初始化中添 ...
- InPageError c000009c使用chkdsk修复磁盘
chkdsk e: /f /r 回车运行就表示修复e盘上的错误,并找到坏扇区恢复可读取的信息. 其它: [Path} FileName] 指定需要 chkdsk 检查碎片整理的文件或文件集的位置和名称 ...
- javascript 学习资料网址一览
1.http://www.runoob.com/ 2.https://developer.mozilla.org/zh-CN/ 3.http://www.imooc.com/ 视频类
- HDU ACM 1081 To The Max->最大子矩阵
分析:利用求最大子段和的思想进行求解. 1.首先累加s[i][j].表示第j列中i从第1行加到第i行的和. 2.对每一列的i1到i2行的和进行计算(0<i1<i2<=n),得出t[k ...
- 构建基于Jenkins + Github的持续集成环境
搭建持续集成首先要了解什么是持续集成,带着明确的目标去搭建持续集成环境才能让我们少走很多弯路.持续集成(Continuous integration)简称CI,是一种软件开发的实践,可以让团队在持续集 ...
- Java 的垃圾回收机制(转)
先看一段转载,原文出自 http://jefferent.iteye.com/blog/1123677 虚拟机中的共划分为三个代:年轻代(Young Generation).年老点(Old Gener ...
- 基于visual Studio2013解决C语言竞赛题之1093连接链表
题目 解决代码及点评 #include <stdio.h> #include <stdlib.h> #include <math.h> #i ...
- Linux开发环境的搭建和使用——Linux 常用的命令使用
概要 视或电影中看到过类似的场景,黑客面对一个黑色的屏幕,上面飘着密密麻麻的字符,梆梆一顿敲,就完毕了窃取资料的任务. Linux 刚出世时没有什么图形界面.全部的操作全靠命令完毕.就如同电视里的黑客 ...
- Android:Drag and Drop的应用
最近看了下Drag and Drop部分的原文,觉得很有意思就像自己试着做一下,说实在的原文真的是不好读啊,要感谢那些为我们发表译文的大神们, 真的是不容易,原文中给了例子,但是只有后面零星的代码,真 ...