mysql-proxy二進制版本安裝測試

環境:mysql

MySQL主庫 192.168.160.250linux

mysql從庫  192.168.160.233sql

mysqlproxy 192.168.110.110vim

 

 

[root@ local]# getconf LONG_BIT
64app

wget http://mysql.cdpa.nsysu.edu.tw/Downloads/MySQL-Proxy/socket

網站上下載oop

wget http://mysql.cdpa.nsysu.edu.tw/Downloads/MySQL-Proxy/mysql-proxy-0.8.4-linux-rhel5-x86-64bit.tar.gz測試

tar zxvf mysql-proxy-0.8.3-linux-rhel5-x86-64bit.tar.gz  -C /usr/local/網站

cd /usr/local/ui

mv mysql-proxy-0.8.3-linux-rhel5-x86-64bit/ mysql-proxy

vim /etc/profile

export PATH=/usr/local/share/aclocal:/usr/local/mysql/bin:/usr/local/mysql-proxy/bin:$PATH
source /etc/profile

 

[root@xnile local]# mysql-proxy --help
Usage:
  mysql-proxy [OPTION...] - MySQL Proxy


Help Options:
  -?, --help                                              Show help options
  --help-all                                              Show all help options
  --help-proxy                                            Show options for the proxy-module


Application Options:
  -V, --version                                           Show version
  --defaults-file=<file>                                  configuration file
  --verbose-shutdown                                      Always log the exit code when shutting down
  --daemon                                                Start in daemon-mode
  --user=<user>                                           Run mysql-proxy as user
  --basedir=<absolute path>                               Base directory to prepend to relative paths in the config
  --pid-file=<file>                                       PID file in case we are started as daemon
  --plugin-dir=<path>                                     path to the plugins
  --plugins=<name>                                        plugins to load
  --log-level=(error|warning|info|message|debug)          log all messages of level ... or higher
  --log-file=<file>                                       log all messages in a file
  --log-use-syslog                                        log all messages to syslog
  --log-backtrace-on-crash                                try to invoke debugger on crash
  --keepalive                                             try to restart the proxy if it crashed
  --max-open-files                                        maximum number of open files (ulimit -n)
  --event-threads                                         number of event-handling threads (default: 1)
  --lua-path=<...>                                        set the LUA_PATH
  --lua-cpath=<...>                                       set the LUA_CPATH

 

[root@xnile local]# mysql-proxy --help-proxy
Usage:
  mysql-proxy [OPTION...] - MySQL Proxy


proxy-module
  -P, --proxy-address=<host:port>                         listening address:port of the proxy-server (default: :4040)
  -r, --proxy-read-only-backend-addresses=<host:port>     address:port of the remote slave-server (default: not set)
  -b, --proxy-backend-addresses=<host:port>               address:port of the remote backend-servers (default: 127.0.0.1:3306)
  --proxy-skip-profiling                                  disables profiling of queries (default: enabled)
  --proxy-fix-bug-25371                                   fix bug #25371 (mysqld > 5.1.12) for older libmysql versions
  -s, --proxy-lua-script=<file>                           filename of the lua script (default: not set)
  --no-proxy                                              don't start the proxy-module (default: enabled)
  --proxy-pool-no-change-user                             don't use CHANGE_USER to reset the connection coming from the pool (default: enabled)
  --proxy-connect-timeout                                 connect timeout in seconds (default: 2.0 seconds)
  --proxy-read-timeout                                    read timeout in seconds (default: 8 hours)
  --proxy-write-timeout                                   write timeout in seconds (default: 8 hours)

 

[root@xnile local]# vim /etc/mysql-proxy.cnf 

[mysql-proxy]

proxy-address=192.168.110.110:38141    能夠修改端口

admin-username=root
admin-password=123456
admin-lua-script=/usr/local/mysql-proxy/lib/mysql-proxy/lua/admin.lua
proxy-backend-addresses=192.168.160.250:3306
proxy-read-only-backend-addresses=192.168.160.233:3306
proxy-lua-script=/usr/local/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua
log-file=/var/tmp/mysql-proxy.log
log-level=debug
daemon=true
keepalive=true

 

[root@xnile bin]# vim +40 /usr/local/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua 
 29 
 30 local commands    = require("proxy.commands")
 31 local tokenizer   = require("proxy.tokenizer")
 32 local lb          = require("proxy.balance")
 33 local auto_config = require("proxy.auto-config")
 34 
 35 --- config
 36 --
 37 -- connection pool
 38 if not proxy.global.config.rwsplit then
 39         proxy.global.config.rwsplit = {
 40                 min_idle_connections = 1,
 41                 max_idle_connections = 2,
 42 
 43                 is_debug = false
 44         }
 45 end
 46 

保證主從同步能夠安裝SemiSyncReplication插件

測試挺簡單,不寫了

[root@xnile bin]# more  /var/tmp/mysql-proxy.log 2014-05-21 11:16:25: (debug) chassis-unix-daemon.c:121: we are the child: 7306 2014-05-21 11:16:25: (message) chassis-unix-daemon.c:136: [angel] we try to keep PID=7306 alive2014-05-21 11:16:25: (critical) plugin proxy 0.8.3 started 2014-05-21 11:16:25: (debug) max open file-descriptors = 65535 2014-05-21 11:16:25: (debug) chassis-unix-daemon.c:157: waiting for 7306 2014-05-21 11:16:25: (message) proxy listening on port :4040 2014-05-21 11:16:25: (message) added read/write backend: 192.168.160.250:3306 2014-05-21 11:16:25: (message) added read-only backend: 192.168.160.233:3306 2014-05-21 11:17:00: (message) chassis-unix-daemon.c:136: [angel] we try to keep PID=7320 alive 2014-05-21 11:17:00: (debug) chassis-unix-daemon.c:157: waiting for 7320 2014-05-21 11:17:00: (debug) chassis-unix-daemon.c:121: we are the child: 7320 2014-05-21 11:17:00: (critical) plugin proxy 0.8.3 started 2014-05-21 11:17:00: (debug) max open file-descriptors = 65535 2014-05-21 11:17:00: (message) proxy listening on port :4040 2014-05-21 11:17:00: (message) added read/write backend: 192.168.160.250:3306 2014-05-21 11:17:00: (message) added read-only backend: 192.168.160.233:3306 2014-05-21 11:25:34: (message) proxy-plugin.c.1664: connect(192.168.160.250:3306) failed: Connection refused. Retrying with different backend. 2014-05-21 11:25:34: (critical) proxy-plugin.c.1773: Cannot connect, all backends are down. 2014-05-21 11:27:34: (debug) network-backend.c.184: backend 192.168.160.250:3306 was down for more than 4 sec, waking it up 2014-05-21 11:40:21: (message) chassis-unix-daemon.c:136: [angel] we try to keep PID=7476 alive 2014-05-21 11:40:21: (debug) chassis-unix-daemon.c:121: we are the child: 7476 2014-05-21 11:40:21: (debug) chassis-unix-daemon.c:157: waiting for 7476 2014-05-21 11:40:21: (critical) plugin proxy 0.8.3 started 2014-05-21 11:40:21: (debug) max open file-descriptors = 65535 2014-05-21 11:40:21: (critical) network-socket.c:451: bind(0.0.148.253:3306) failed: Address already in use (98) 2014-05-21 11:40:21: (critical) chassis-mainloop.c:267: applying config of plugin proxy failed 2014-05-21 11:40:21: (critical) mysql-proxy-cli.c:597: Failure from chassis_mainloop. Shutting down. 2014-05-21 11:40:21: (message) Initiating shutdown, requested from mysql-proxy-cli.c:598 2014-05-21 11:40:21: (message) shutting down normally, exit code is: 1 2014-05-21 11:40:21: (debug) chassis-unix-daemon.c:167: 7476 returned: 7476 2014-05-21 11:40:21: (message) chassis-unix-daemon.c:176: [angel] PID=7476 exited normally with exit-code = 1 (it used 1 kBytes max) 2014-05-21 11:40:21: (message) Initiating shutdown, requested from mysql-proxy-cli.c:273 2014-05-21 11:40:21: (message) shutting down normally, exit code is: 1 2014-05-21 11:41:18: (critical) mysql-proxy-cli.c:503: Unknown option -p (use --help to show all options) 2014-05-21 11:41:18: (message) Initiating shutdown, requested from mysql-proxy-cli.c:513 2014-05-21 11:41:18: (message) shutting down normally, exit code is: 1 2014-05-21 11:41:22: (critical) mysql-proxy-cli.c:503: Unknown option -p (use --help to show all options) 2014-05-21 11:41:22: (message) Initiating shutdown, requested from mysql-proxy-cli.c:513 2014-05-21 11:41:22: (message) shutting down normally, exit code is: 1 2014-05-21 11:49:32: (message) chassis-unix-daemon.c:136: [angel] we try to keep PID=7524 alive2014-05-21 11:49:32: (debug) chassis-unix-daemon.c:121: we are the child: 7524

相關文章
相關標籤/搜索