mysql proxy代理安装和配置

服务器说明:

192.168.1.219   mysql主库(主从复制)

192.168.1.177   mysql从库(主从复制)

192.168.1.202   mysql proxy代理(实现读写分离)

安装需要的基础组件,基本系统都可以满足lua的组件版本要求

安装lua(确定是否需要安装)

yum -y install gcc* gcc-c++* autoconf* automake* zlib* libxml* ncurses-devel* libmc rypt* libtool* flex*

pkgconfig*

Mysql Proxy的安装

下载mysql-proxy-0.8.5-linux-el6-x86-64bit.tar.gz

注:若是你安装的软件包是已编译的,则无需安装lua

a、解压安装

cd /usr/local/software

tar -zxvf mysql-proxy-0.8.5-linux-el6-x86-64bit.tar.gz

cp mysql-proxy-0.8.5-linux-el6-x86-64bit /usr/local/mysql-proxy

b、授权

chmod -R 775 /usr/local/mysql-proxy

chown -R mysql:mysql /usr/local/mysql-proxy

c、环境变量的设置

vim /etc/profile   //打开此文件,在文件尾部加上以下内容

LUA_PATH="/usr/local/mysql-proxy/share/doc/mysql-proxy/?.lua"    // lua环境变量的设置

export LUA_PATH

export PATH=$PATH:/usr/local/mysql-proxy/bin     //mysql proxy 环境变量的设置

保存并退出后执行下面命令

source /etc/profile  // 使变量立即生效

d、修改mysql proxy的读写分离脚本的配置

vim /usr/local/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua

默认最小4个(最大8个)以上的客户端连接才会实现读写分离, 现改为最小1个最大2个,便于读写分离的测试

-- connection pool

if not proxy.global.config.rwsplit then

proxy.global.config.rwsplit = {

min_idle_connections = 1,  // 改为1

max_idle_connections = 2,  // 改为2

is_debug = false

}

end

这是因为mysql-proxy会检测客户端连接, 当连接没有超过min_idle_connections预设值时,

不会进行读写分离, 即查询操作会发生到Master上.

e、开启防火墙端口设置

vim /etc/sysconfig/iptables    //打开防火墙配置文件,加入以下内容

-A INPUT -m state --state NEW -m tcp -p tcp --dport 4040 -j ACCEPT

注:mysql-proxy的服务端口默认为4040

f、主库和从库给代理服务器创建登录用户并授权

登录主库192.168.1.219,给主机192.168.1.202创建登录用户并授权

ssh root@192.168.1.219  // 登录主数据库服务器

mysql -uroot -p321321   // 连接mysql数据库

mysql>grant all on *.* to 'test'@'192.168.1.202' identified by '321321';  // 创建登录用户并授权

mysql>flush privileges;   // 刷新MySQL的系统权限相关表

登录从库192.168.1.177,给主机192.168.1.202创建登录用户并授权,操作步骤和主库一样,

注意:主库和从库给代理服务器创建登录用户并密码应该一致

g、启动mysql-proxy

vim /usr/local/mysql-proxy/mysql-proxy.sh   // 新建一个shell文件,加入以下内容

#!/bin/sh

mysql-proxy --daemon --log-level=debug --log-file=/var/log/mysql-proxy.log

--plugins=proxy -b 192.168.1.219:3306 -r 192.168.1.177:3306

--proxy-lua-script="/usr/local/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua" --plugins=admin

--admin-username="test" --admin-password="321321"

--admin-lua-script="/usr/local/mysql-proxy/share/doc/mysql-proxy/admin.lua"

保存并退出

chmod 775 /usr/local/mysql-proxy/mysql-proxy.sh  // 授予执行权限

./mysql-proxy.sh   // 启动mysql-proxy

查看mysql-proxy服务端口

netstat -tupln |grep mysql

监控启动日志

tail -f /var/log/mysql-proxy.log

测试mysql proxy读写分离

在读写分离测试时,需要开启多个客户端窗口连接mysql-proxy

a、打开主库的mysql 日志

tail -f /usr/local/mysql/my.log

b、打开从库的mysql 日志

tail -f /usr/local/mysql/my.log

c、开启多个客户端窗口连接mysql-proxy

mysql -h192.168.1.202 -P4040 -utest -p321321

插入数据   查询数据进行测试

mysql proxy代理安装和配置的更多相关文章

  1. mysql.zip免安装版配置

    MYSQL ZIP免安装版配置 1. 下载MySQL 选择自己想要的.本次安装.我使用的是mysql-5.6.17-winx64  地址:http://dev.mysql.com/downloads/ ...

  2. mysql数据库的安装与配置

    mysql数据库的安装与配置及workbench的简单使用 mysql数据库社区版下载:https://dev.mysql.com/downloads/installer/ 我这里选的是社区安装版(适 ...

  3. MySQL服务器的安装和配置,MySQL Workbench 8.0.12安装,MySQL的基本使用

    一 MySQL服务器的安装和配置 二 MySQL Workbench 8.0.12安装 三 MySQL的基本使用 一MySQL服务器的安装和配置 MySQL是目前最为流行的开放源码的数据库,是完全网络 ...

  4. linux学习之centos(三):mysql数据库的安装和配置

    前言:mysql简介 说到数据库,我们大多想到的是关系型数据库,比如mysql.oracle.sqlserver等等,这些数据库软件在windows上安装都非常的方便,在Linux上如果要安装数据库, ...

  5. linux应用之mysql数据库的安装及配置(centos)

    CentOS下Mysql数据库的安装与配置   如果要在Linux上做j2ee开发,首先得搭建好j2ee的开发环境,包括了jdk.tomcat.eclipse的安装(这个在之前的一篇随笔中已经有详细讲 ...

  6. MySQL数据库的安装与配置(windows)

    MySQL是目前最为流行的开放源码的数据库,是完全网络化的跨平台的关系型数据库系统,它是由瑞典MySQLAB公司开发,目前属于Oracle公司.任何人都能从Internet下载MySQL软件,而无需支 ...

  7. MySQL集群安装与配置

    MySQL集群安装与配置   文章目录 [隐藏] 一.mysql集群安装 二.节点配置 三.首次启动节点 四.测试服务是否正常 五.安全关闭和重启 MySQL Cluster 是 MySQL 适合于分 ...

  8. Windows下MySQL 5.6安装及配置详细图解

    一.安装前的准备 1.下载安装程序包,可到MySQL官方网站http://www.mysql.com/下载,如图1-1: 图1-1 下载后的安装文件如图1-2所示: 图1-2 二.安装 1.双击下载的 ...

  9. 第一章 Mysql 简介及安装和配置

    Mysql是最流行的关系型数据库管理系统,在WEB应用方面MySQL是最好的RDBMS(Relational Database Management System:关系数据库管理系统)应用软件之一. ...

随机推荐

  1. 小记 百度地图 soso地图 经纬度偏移

    项目里遇到了这么个问题,数据库原有数据是微信上用的,所以是soso地图坐标, 但是现在要做百度地图,坐标偏移严重,网上找了也没说偏移多少,自己手动测试10多分钟,得到个大概值,反正差不多就行了. so ...

  2. Web应用开发中的几个问题

    Introduction 由于Ajax技术在Gmail中的成功应用和高性能的V8引擎的推出使得编写Web应用变得流行 起来,使用前端技术也可以编写具有复杂交互的应用.相对于native应用,Web应用 ...

  3. JS设计模式——10.门面模式

    门面模式 这是一种组织性的模式,它可以用来修改类和对象的接口,使其更便于使用.它可以让程序员过得更轻松,使他们的代码变得更容易管理. 门面模式有两个作用: 简化类的接口 消除与使用她的客户代码之间的耦 ...

  4. 利用SSLStrip截获https协议--抓取邮箱等密码

    1.SSL解析 SSL 是 Secure Socket Layer 的简称, 中文意思是安全套接字层,由 NetScape公司所开发,用以保障在 Internet 上数据传输的安全,确保数据在网络的传 ...

  5. sru源码--language model

    import sys import os import argparse import time import random import math import numpy as np import ...

  6. 查看gcc的默认宏定义命令【转】

    转自:http://blog.csdn.net/cywosp/article/details/10730931 有些时候我们在编写代码或者阅读开源项目时经常会遇到一些陌生的宏定义,在找遍所有源代码都没 ...

  7. PHP 生成、识别二维码及安装相关扩展/工具

    2018-02-20 00:30:26  更新:推荐新扩展(极力推荐) 这篇文章里用的两个二维码扩展都有些问题和麻烦:phpqrcode(生成二维码)的源码有点小 bug: 而 php-zbarcod ...

  8. C# 日文网址转punnycode

    Uri uri = new Uri(url); IdnMapping idn = new IdnMapping();url= url.Replace(uri.Host, idn.GetAscii(ur ...

  9. SQLAlchemy-对象关系教程ORM-create

    ORM是建立在SQL语言构造器之上的工具集,用于将Python对象映射到数据库的行,提供了一系列接口用于从数据库中存取对象(行).在ORM 工作时,在底层调用SQL语言构造器的API,这些通用的操作有 ...

  10. bootstrap File Input 多文件上传插件使用记录(二)删除原文件

    在上一篇文章中,主要介绍了file input插件的初始化和多文件同步上传到服务器的相关配置等.这篇主要介绍file input插件的编辑等. 使用场景: 在后台管理框架中,一条数据中包含不固定的多张 ...