前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CentOS 7.2下MySQL读写分离配置

CentOS 7.2下MySQL读写分离配置

作者头像
星哥玩云
发布2022-08-17 15:15:37
4190
发布2022-08-17 15:15:37
举报
文章被收录于专栏:开源部署

MySQL读写分离配置

环境:CentOS7.2 MySQL5.7

场景描述: 数据库Master主服务器:192.168.206.100 数据库Slave从服务器:192.168.206.200 MySQL-Proxy调度服务器:192.168.206.210

以下操作,均是在192.168.206.210即MySQL-Proxy调度服务器 上进行的。

1.检查系统所需软件包

安装之前需要配置EPEL YUM源 wget https://mirrors.ustc.edu.cn/epel//7/x86_64/Packages/e/epel-release-7-11.noarch.rpm rpm -ivh epel-release-7-11.noarch.rpm yum clean all yum update

yum install -y gcc* gcc-c++* autoconf* automake* zlib* libxml* ncurses-devel* libmcrypt* libtool* flex* pkgconfig* libevent* glib*

2.编译安装lua

MySQL-Proxy的读写分离主要是通过rw-splitting.lua脚本实现的,因此需要安装lua

lua可通过以下方式获得  从http://www.lua.org/download.html下载源码包

从rpm.pbone.net搜索相关的rpm包 download.Fedora.RedHat.com/pub/fedora/epel/5/i386/lua-5.1.4-4.el5.i386.rpm  download.fedora.redhat.com/pub/fedora/epel/5/x86_64/lua-5.1.4-4.el5.x86_64.rpm

这里我们建议采用源码包进行安装 cd /opt/install wget http://www.lua.org/ftp/lua-5.1.4.tar.gz tar zvfx lua-5.1.4.tar.gz cd lua-5.1.4 make linux make install mkdir /usr/lib/pkgconfig/ cp /opt/install/lua-5.1.4/etc/lua.pc /usr/lib/pkgconfig/ export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/lib/pkgconfig

注意的问题

编译的时候,遇到的问题是,缺少依赖包** readline**, 然后readline又依赖ncurses,所以要先安装着两个软件 yum install -y readline-devel ncurses-devel

3.安装配置MySQL-Proxy

下载mysql-proxy

下载:http://dev.mysql.com/downloads/mysql-proxy/ wget https://downloads.mysql.com/archives/get/file/mysql-proxy-0.8.5-linux-glibc2.3-x86-64bit.tar.gz tar zxvf mysql-proxy-0.8.5-linux-glibc2.3-x86-64bit.tar.gz mv zxvf mysql-proxy-0.8.5-linux-glibc2.3-x86-64bit /usr/local/mysql-proxy

** 配置mysql-proxy,创建主配置文件** cd /usr/local/mysql-proxy mkdir lua #创建脚本存放目录 mkdir logs #创建日志目录 cp share/doc/mysql-proxy/rw-splitting.lua  ./lua #复制读写分离配置文件 vi /etc/mysql-proxy.cnf  #创建配置文件 [mysql-proxy] user=root #运行mysql-proxy用户 admin-username=proxyuser #主从mysql共有的用户 admin-password=123456 #用户的密码 proxy-address=192.168.206.210:4040 #mysql-proxy运行ip和端口,不加端口,默认4040 proxy-read-only-backend-addresses=192.168.206.200 #指定后端从slave读取数据 proxy-backend-addresses=192.168.206.100 #指定后端主master写入数据 proxy-lua-script=/usr/local/mysql-proxy/lua/rw-splitting.lua #指定读写分离配置文件位置 admin-lua-script=/usr/local/mysql-proxy/lua/admin.lua #指定管理脚本 log-file=/var/log/mysql-proxy.log #日志位置 log-level=info #定义log日志级别 daemon=true#以守护进程方式运行 keepalive=true #mysql-proxy崩溃时,尝试重启

这里就有一个坑了

配置文件里面的注释要全部删掉,不然可能会引起一些字符不能识别的错误。  这还不是最坑的,最坑的是:即使删掉注释,去除多余的空白字符,仍然可能会报如下错误: 2018-09-21 06:39:40: (critical) Key file contains key “daemon” which has a value that cannot be interpreted.

或者: 2018-09-21 06:52:22: (critical) Key file contains key “keepalive” which has a value that cannot be interpreted.

出现以上问题的原因是daemon=true,keepalive=true现在不这样写了,要改为: daemon=1 keepalive=1

给配置文件执行权限 chmod 660 /etc/mysql-porxy.cnf

配置admin.lua 文件

在/etc/mysql-proxy.cnf 配置文件中,还差/usr/local/mysql-proxy/lua/admin.lua 的管理文件,实际现在还没有创建的。所以,现在需要编辑创建admin.lua文件。mysql-proxy-0.8.5的这个版本,我找到了下面的admin.lua脚本,对这个版本才是有效的: vim  /usr/local/mysql-proxy/lua/admin.lua

function set_error(errmsg) proxy.response = { type = proxy.MYSQLD_PACKET_ERR, errmsg = errmsg or "error" } end function read_query(packet) if packet:byte() ~= proxy.COM_QUERY then set_error("[admin] we only handle text-based queries (COM_QUERY)") return proxy.PROXY_SEND_RESULT end local query = packet:sub(2) local rows = { } local fields = { } if query:lower() == "select * from backends" then fields = { { name = "backend_ndx",   type = proxy.MYSQL_TYPE_LONG }, { name = "address",   type = proxy.MYSQL_TYPE_STRING }, { name = "state",   type = proxy.MYSQL_TYPE_STRING }, { name = "type",   type = proxy.MYSQL_TYPE_STRING }, { name = "uuid",   type = proxy.MYSQL_TYPE_STRING }, { name = "connected_clients",   type = proxy.MYSQL_TYPE_LONG }, } for i = 1, #proxy.global.backends do local states = { "unknown", "up", "down" } local types = { "unknown", "rw", "ro" } local b = proxy.global.backends[i] rows[#rows + 1] = { i, b.dst.name,  -- configured backend address states[b.state + 1], -- the C-id is pushed down starting at 0 types[b.type + 1],  -- the C-id is pushed down starting at 0 b.uuid,  -- the MySQL Server's UUID if it is managed b.connected_clients  -- currently connected clients } end elseif query:lower() == "select * from help" then fields = { { name = "command",   type = proxy.MYSQL_TYPE_STRING }, { name = "description",   type = proxy.MYSQL_TYPE_STRING }, } rows[#rows + 1] = { "SELECT * FROM help", "shows this help" } rows[#rows + 1] = { "SELECT * FROM backends", "lists the backends and their state" } else set_error("use 'SELECT * FROM help' to see the supported commands") return proxy.PROXY_SEND_RESULT end proxy.response = { type = proxy.MYSQLD_PACKET_OK, resultset = { fields = fields, rows = rows } } return proxy.PROXY_SEND_RESULT end

** 修改读写分离配置文件** vim /usr/local/mysql-proxy/lua/rw-splitting.luaif not proxy.global.config.rwsplit  proxy.global.config.rwsplit = {   min_idle_connections = 1, #默认超过4个连接数时,才开始读写分离,改为1   max_idle_connections = 1, #默认8,改为1   is_debug = false  } end

启动mysql-proxy /usr/local/mysql-proxy/bin/mysql-proxy --defaults-file=/etc/mysql-proxy.cnf

netstat -tupln | grep 4000 #已经启动killall -9 mysql-proxy #关闭mysql-proxy

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档