MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具。因此,我们首先要在系统中源码编译安装cmake工具。

注:安装前须查看是否已经安装了如下依赖包,如果没有请安装。

apt-get -y install gcc g++ libncurses5-dev ncurses-devel openssl

一.主库安装及配置

1.源码安装cmake

# tar xf cmake-3.0.0.tar.gz

# cd cmake-3.0.0

# ./configure --prefix=/usr/local/cmake

# make && make install或gmake && gmake install

注:这里定要用源码安装,不能用apt-get安装,不然会在编译时报错。

2.编译安装mysql

#mkdir -p /mysql/data /usr/local/mysql

#useradd -r -s /usr/sbin/nologin mysql

#chown mysql.mysql -R /mysql/data

# tar xf mysql-5.5.21.tar.gz

# cd mysql-5.5.21

# /usr/local/cmake/bin/cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql

-DMYSQL_DATADIR=/mysql/data/ \

-DMYSQL_UNIX_ADDR=/mysql/data/mysqld.sock \

-DWITH_INNOBASE_STORAGE_ENGINE=1 \

-DSYSCONFDIR=/etc \

-DEXTRA_CHARSETS=all \

-DDEFAULT_CHARSET=utf8 \

-DDEFAULT_COLLATION=utf8_unicode_ci \

-DWITH_DEBUG=0# make && make install

注:如果在中途有提示报错不能继续,请将如上的一些依赖包,并删除CMakeCache文件再重新编译;

编译各参数说明:

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql

; mysql安装的主目录,5.5.17版本默认为/usr/local/mysql,(可省略)

-DMYSQL_DATADIR=/home/system_username/mysql/mysqldata

; mysql数据保存的路径,自定义

-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock

; 系统Socket文件(.sock)设置,基于该文件路径进行Socket连接,必要为绝对路径

-DSYSCONFDIR=/etc mysql ; 配置文件my.cnf地址,默认/etc下(可省略)

-DMYSQL_TCP_PORT=3306

; 数据库服务器TCP/IP连接的监听端口,默认为3306(可省略)

-DENABLED_LOCAL_INFILE=1 ; 默认为关闭,这里开启

-DEXTRA_CHARSETS=all

-DDEFAULT_CHARSET=utf8

-DDEFAULT_COLLATION=utf8-general_ci ; 数据库编码设置

-DWITH_INNOBASE_STORAGE_ENGINE=1

-DWITH_ARCHIVE_STORAGE_ENGINE=1

-DWITH_BLACKHOLE_STORAGE_ENGINE=1

-DWITH_FEDERATED_STORAGE_ENGINE=1

-DWITH_PARTITION_STORAGE_ENGINE=1 ; 存储引擎设置

# cp support-files/my-medium.cnf /etc/my.cnf

# cp support-files/mysql.server /etc/init.d/mysqld

# chmod +x /etc/init.d/mysqld

# cd scripts/

# sh mysql_install_db --user=mysql --basedir=/usr/local/mysql/ --datadir=/mysql/data/

# ln /usr/local/mysql/bin/* /usr/local/sbin/

# service mysqld start

给root加个密码123456

# /usr/local/mysql/bin/mysqladmin -u root password 123456

使用mysql数据库/更改root用户的登录密码

# mysql -uroot -p 123456

> use mysql ;

> update user set password=PASSWORD("654321") where user='root ';

> mysql>FLUSH PRIVILEGES ;

3. 主库配置文件my.cnf修改

# vim /etc/my.cnf

log-bin=master-bin

log-bin-index=master-bin.index

binlog_format=mixed

server-id = 1

datadir=/mysql/data

innodb_file_per_table = 1 ; 重要有用

sync_binlog = 1 ;此参数设置,用于事务安全

SHOW GLOBAL VARIABLES LIKE '%log' ; 查看全局设置

4. 添加从库授权用户

# mysql -uroot -p

> GRANT REPLICATION SLAVE ON *.* TO 'repluser'@'192...' IDENTIFIED BY 'REPLPASS' ;

> FLUSH PRIVILEGES ;

> SHOW MASTER status ;

注:如果主服务器已经存在应用数据,则在进行主从复制时,需要做以下处理: (主数据库进行锁表操作,不让数据再进行写入动作。

mysql> FLUSH TABLES WITH READ LOCK;

二.从库安装及配置

1. 源码安装cmake和mysql见主库安装步骤

。 。 。 。 。 。

2. 从库配置文件夹my.cnf修改

# vim /etc/my.cnf

relay-log = relay-log

relay-log-index = relay-log.index

service-id = 2

binlog_format=mixed

datadir=/mydata/data

innodb_file_per_table = 1

read-only=YES/ON/1/TURE ; 从数据库只有读权限

注:read-only对PERSU权限的用户不生效

3. 连接到主库

# mysql -uroot

> CHANGE MASTER TO MASTER_HOST=’192.168.X.X’, MASTER_USER=’repluser’,

MASTER_LOG_FILE=’master-bin.00000X’,MASTER_LOG_POS=XXX ;

> START SLAVE

> SHOW SLAVE STATUS\G ;

STOP SLAVE IO_THREAD; 单独开启关闭线程

STOP SLAVE SQL_THERAD;

/mydata/data/目录下存放两个重要的文件,master.info/relay-log.info

这两个文件记录着复制的过程

# file master.info 是一个ASCII码文件

开启关闭线程,都会记录在mysql错误日志当中

tail /mydata/data/node2.magedu.com.err

三.Mysql-proxy

1.解压mysql-proxy二进制包,可直接使用

# tar xf mysql-proxy-0.8.3-linux-rhel5-x86-32bit.tar.gz

# mv mysql-proxy-0.8.3 mysql-proxy

# cd mysql-proxy

# vim share/doc/mysql-proxy/rw-splitting.lua

if not proxy.global.config.rwsplit then

proxy.global.config.rwsplit = {

min_idle_connections = 1, ; 将参数改为1

max_idle_connections = 1,

is_debug = false

}

End

2.创建启动脚本

# vim mysql-proxy.sh

#!/bin/bash

/home/wang/mysql-proxy/bin/mysql-proxy --proxy-backend-addresses=192.168.10.48:3306 --proxy-read-only-backend-addresses=192.168.10.45:3306 --proxy-lua-script=/home/wang/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua &

# sh mysql-proxy.sh

# netstat -anpt |grep 4040 / 4041 ;查看进程是否启动

3. 在另外一台主机上通过mysql命令连入mysql-proxy的4040端口,默认情况下不能连接,因为数据库默认拒绝从远程登录,所以要在主从数据库都进行权限设置,允许远程登录,这里要注意的是,在主从做权限,非mysql-proxy这台主机,本人就是因为这个失误,倒致半到没找到原因!!

1)主从都做如下配置

# mysql -uroot

> grant all privileges on *.* to ‘wang’@’%’ identified by ‘wang’;

> flush privileges

>exit

2) 现可在另一台主机上通过mysql命令成功登录主从服务,如果是写操作将会在主服务器上操作,读操作会在从服务器上操作,至此就实现了mysql主从和读写分离的作用。

四.在windows平台下连接linux中mysql服务器

使用Navicat for MySQL连接远程的MySQL服务器,却提示:Can't get hostname for your address
明明已经使用grant命令授权过了的呀,原来还需要再执行一步:

也有可能是防火墙的原因,关闭iptables防火墙,或查看selinux里是否开启等;

1)编辑/etc/my.cnf,在:
[mysqld]
内添加一行:skip-name-resolve


2
)MySQL忽略数据库表名大小写
修改/etc/my.cnf,在
[mysqld]
内添加一行:lower_case_table_names=1

附:MySQL常见错误代码说明
1005:创建表失败
1006
:创建数据库失败
1007
:数据库已存在,创建数据库失败
1008
:数据库不存在,删除数据库失败
1009
:不能删除数据库文件导致删除数据库失败
1010
:不能删除数据目录导致删除数据库失败
1011
:删除数据库文件失败
1012
:不能读取系统表中的记录
1020
:记录已被其他用户修改
1021
:硬盘剩余空间不足,请加大硬盘可用空间
1022
:关键字重复,更改记录失败
1023
:关闭时发生错误
1024
:读文件错误
1025
:更改名字时发生错误
1026
:写文件错误
1032
:记录不存在
1036
:数据表是只读的,不能对它进行修改
1037
:系统内存不足,请重启数据库或重启服务器
1038
:用于排序的内存不足,请增大排序缓冲区
1040
:已到达数据库的最大连接数,请加大数据库可用连接数
1041
:系统内存不足
1042
:无效的主机名
1043
:无效连接
1044
:当前用户没有访问数据库的权限
1045
:不能连接数据库,用户名或密码错误
1048
:字段不能为空
1049
:数据库不存在
1050
:数据表已存在
1051
:数据表不存在
1054
:字段不存在
1065
:无效的SQL语句,SQL语句为空
1081
:不能建立Socket连接
1114
:数据表已满,不能容纳任何记录
1116
:打开的数据表太多
1129
:数据库出现异常,请重启数据库
1130
:连接数据库失败,没有连接数据库的权限
1133
:数据库用户不存在
1141
:当前用户无权访问数据库
1142
:当前用户无权访问数据表
1143
:当前用户无权访问数据表中的字段
1146
:数据表不存在
1147
:未定义用户对数据表的访问权限
1149
:SQL语句语法错误
1158
:网络错误,出现读错误,请检查网络连接状况
1159
:网络错误,读超时,请检查网络连接状况
1160
:网络错误,出现写错误,请检查网络连接状况
1161
:网络错误,写超时,请检查网络连接状况
1062
:字段值重复,入库失败
1169
:字段值重复,更新记录失败
1177
:打开数据表失败
1180
:提交事务失败
1181
:回滚事务失败
1203
:当前用户和数据库建立的连接已到达数据库的最大连接数,请增大可用的数据库连接数或重启数据库
1205
:加锁超时
1211
:当前用户没有创建用户的权限
1216
:外键约束检查失败,更新子表记录失败
1217
:外键约束检查失败,删除或修改主表记录失败
1226
:当前用户使用的资源已超过所允许的资源,请重启数据库或重启服务器
1227
:权限不足,您无权进行此操作
1235
:MySQL版本过低,不具有本功能

http://www.cnblogs.com/wangbaigui/p/4473522.html

Mysql主从配置+读写分离(转)的更多相关文章

  1. Mysql主从配置+读写分离

    Mysql主从配置+读写分离     MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具.因此,我们首先要在系统中源码编译安装cmake工具. ...

  2. MySQL 主从配置 读写分离

    Master配置 1.创建用户: 在Master MySQL上创建一个用户‘repl’,并允许其他Slave服务器可以通过远程访问Master,通过该用户读取二进制日志,实现数据同步. create ...

  3. 聊聊Mysql主从同步读写分离配置实现

    Hi,各位热爱技术的小伙伴您们好,好久没有写点东西了,今天写点关于mysql主从同步配置的操作日志同大家一起分享.最近自己在全新搭建一个mysql主从同步读写分离数据库简单集群,我讲实际操作步骤整理分 ...

  4. 使用docker 实现MySQL主从同步/读写分离

    1. 利用 docker 实现 mysql 主从同步 / 读写分离 为了保证数据的完整和安全,mysql 设计了主从同步,一个挂掉还可以用另个.最近重构论坛,想来改成主从吧.担心失误,就先拿 dock ...

  5. Docker容器启动Mysql,Docker实现Mysql主从,读写分离

    Docker容器启动Mysql,Docker实现Mysql主从,读写分离 一.Docker文件编排 二.配置主从复制 2.1 配置master 2.2 配置slave 三.验证主从复制 3.1 mas ...

  6. mysql 主从同步-读写分离

    主从同步与读写分离测试 一.  实验环境(主从同步) Master                   centos 7.3              192.168.138.13 Slave     ...

  7. mysql主从同步--读写分离。

    1.mysql 安装参考 https://www.cnblogs.com/ttzzyy/p/9063737.html 2. 主mysql,从mysql 指定配置文件启动 mysqld --defaul ...

  8. docker-compose.yml样例(mysql主从+mycat读写分离)

    Docker-compose.yml文件示例 1.mysql主从复制的docker-compose.yml文件 # cat docker-compose.yml version: '2' # 这个ve ...

  9. MySQL主从及读写分离配置

    <<MySQL主从又叫做Replication.AB复制.简单讲就是A和B两台机器做主从后,在A上写数据,B也会跟着写数据,两者数据实时同步>> MySQL主从是基于binlo ...

随机推荐

  1. Tableau 群集部署

    由于公司连续两个月月底Tableau服务器过载崩溃,因此有了搭建Tableau服务器群集的想法.目前还在测试阶段,所以做一步写一步了. 目录: 一.安装和配置工作服务器 二.其他参考文档 一. 安装和 ...

  2. codeforces 623A. Graph and String 构造

    题目链接 给出一个图, 每个节点只有三种情况, a,b, c. a能和a, b连边, b能和a, b, c,连边, c能和b, c连边, 且无重边以及自环.给出初始的连边情况, 判断这个图是否满足条件 ...

  3. 安装duetdisplay遇到的问题

    1.报错failed to correctly acquire vcredist_x64.exe ifle:CRC error 已经确认了 和墙有关系,通过FQ可以正常安装了. 2.在PAD屏幕上面播 ...

  4. Django : Table 'MyDjango.django_admin_log' doesn't exist

    原因: 添加admin之后,没有运行 manage.py syncdb 解决方法: 在命令行中运行manage.py syncdb 即可 运行截图:

  5. graph isomorphism 开源算法库VFlib, Nauty

    VFlib 开源算法库网站:http://www.cs.sunysb.edu/~algorith/implement/vflib/implement.shtml Nauty 开源算法库网站:http: ...

  6. literal控件的例子

    Literal的Mode属性,举例说明 这个属性的枚举值:PassThrough  Encode  Transform <%@ Page Language="C#" Auto ...

  7. WPF:使用Json.NET在TreeView中树形显示JSON数据

    原文 WPF:使用Json.NET在TreeView中树形显示JSON数据 据 读者可以参考这个开源的可以树形显示XML和JSON的工具: Mgen Object 603:XML/JSON树形显示小工 ...

  8. perl post 带上请求头

    my $url='https://www.zjcap.cn/business/dispatch_post.do?action=submitAdminLogin'; my $res = $ua-> ...

  9. BZOJ 1029: [JSOI2007]建筑抢修

    1029: [JSOI2007]建筑抢修 Description 小刚在玩JSOI提供的一个称之为“建筑抢修”的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的入侵者.但是T部落的基地里已经有 ...

  10. Java学习之链表

    数据结构学了,java实现下 package com.gh.Link; /** * 链表的实现 * @author ganhang * */ public class Links { public s ...