3

我正在尝试在亚马逊 ec2 上的 ubuntu 上设置 mysql-proxy 我已经完成了以下操作:

sudo apt-get install mysql-proxy --yes
vi /etc/default/mysql-proxy

我将以下内容放在“/etc/default/mysql-proxy”上

ENABLED="true"
OPTIONS="--proxy-lua-script=/usr/share/mysql-proxy/rw-splitting.lua
     --proxy-address=127.0.0.1:3306
     --proxy-backend-addresses=private_ip_of_another_ec2_db_server:3306,private_ip_of_another_ec2_db_server:3306"

还与“--proxy-address=private_ip_or_public_ip_of_proxy-server:3306 或 4040”和“--proxy-backend-addresses=public_ip_of_another_ec2_db_server:3306,public_ip_of_another_ec2_db_server:3306”相关联

之后,我尝试使用 mysql 从另一台 PC 连接代理服务器,例如:

mysql -u some_user -pxxxxx -h proxy_server_ip
or 
mysql -u some_user -pxxxxx -h proxy_server_ip -P 4040

但它不工作它的显示错误:

ERROR 2003 (HY000): Can't connect to MySQL server on 'ip' (10061)

我想告诉你可以远程连接数据库服务器,我允许远程连接到任何主机

我也试过 /etc/init.d/mysql-proxy start 或 /etc/init.d/mysql-proxy restart 但没有结果

只是为了通知您 /etc/init.d/mysql-proxy stop 显示失败

谁能帮我在ubuntu上设置和配置mysql-proxy

===

编辑

我从stackoverflow的其他问题中找到了一些帮助,并且根据评论中的建议,已经完成了以下程序。现在看来它正在工作。

我在本地(在代理服务器上)安装了 mysql-client 和 mysql-server,然后我尝试使用以下命令运行 mysql-proxy:

mysql-proxy --proxy-backend-addresses=10.73.151.244:3306 --proxy-backend-addresses=10.73.198.7:3306 --proxy-address=:4040 --admin-username=root --admin-password=root --admin-lua-script=>/usr/lib/mysql-proxy/lua/admin.lua

然后我尝试远程连接到代理服务器及其工作。但似乎我需要在屏幕下运行此命令,因为当我关闭终端代理停止工作时。

你能告诉我我需要在屏幕下运行这个命令还是有其他方法让它一直活着?

4

2 回答 2

2

无需在您的 mysql-proxy 上安装 Mysql 客户端或 Mysql Server。

安装 mysql-proxy 确实具有编译到其中的“完整守护程序功能”。

如果您正在运行 Ubuntu Server,您可能希望使用 UPSTART 服务脚本。

这个脚本可以复制到/etc/init/mysql-proxy.conf

# mysql-proxy.conf (Ubuntu 14.04.1) Upstart proxy configuration file for AWS RDS
# mysql-proxy - mysql-proxy job file

description "mysql-proxy upstart script"
author "shadowbq <shadowbq@gmail.com>"

# Stanzas
#
# Stanzas control when and how a process is started and stopped
# See a list of stanzas here: http://upstart.ubuntu.com/wiki/Stanzas#respawn

# When to start the service
start on runlevel [2345]

# When to stop the service
stop on runlevel [016]

# Automatically restart process if crashed
respawn

# Essentially lets upstart know the process will detach itself to the background
expect daemon

# Run before process
pre-start script
    [ -d /var/run/mysql-proxy ] || mkdir -p /var/run/mysql-proxy
    echo "starting mysql-proxy"
end script

# Start the process
exec /usr/bin/mysql-proxy --plugins=proxy --proxy-lua-script=/usr/share/mysql-proxy/rw-splitting.lua --log-level=debug --proxy-backend-addresses=private_ip_of_another_ec2_db_server:3306,private_ip_of_another_ec2_db_server:3306 --daemon --log-use-syslog --pid-file=/var/run/mysql-proxy/mysql-proxy.pid

在上面的示例中,我将 AWS RDS 服务器硬编码到脚本中,而不是摆弄默认值和配置文件

于 2014-10-01T04:08:02.813 回答
1

安装升级版 0.8.5

笔记:

apt repo 没有 0.8.5 所以我们需要从 mysql 官网下载 tar

先决条件:-

创建/etc/default/mysql-proxy具有以下内容的 文件 ENABLED="true" OPTIONS="--defaults-file=/etc/mysql/mysql-proxy.cnf"

安装程序:-

  1. 下载 mysql-proxy 0.8.x
  2. 在 /usr/local 中解压
  3. 使用 /usr/local/mysql-proxy-0.8.5-linux-debian6.0-x86-64bit/bin 更新 PATH 环境 vim /etc/environment (to update environment path) cd /usr/local/mysql-proxy-0.8.5-linux-debian6.0-x86-64bit/bin

  4. 运行命令 sudo ./mysql-proxy --defaults-file=/etc/mysql/mysql-proxy.cnf

示例 mysql-proxy.cnf 文件

[mysql-proxy]
log-level=debug
log-file=/var/log/mysql-proxy.log
pid-file = /var/run/mysql-proxy.pid
daemon = true
--no-proxy = false
admin-username=ADMIN
admin-password=ADMIN
proxy-backend-addresses=RDS-ENDPOINT:RDS-PORT
admin-lua-script=/usr/lib/mysql-proxy/lua/admin.lua
proxy-address=0.0.0.0:4040
admin-address=localhost:4041
  1. 更改 RDS 或 mysql 的主机 ip 和端口

  2. 通过代理连接到 Mysql 服务器

    mysql -h{proxy-host-ip} -P 4040 -u{mysql_username} -p

于 2017-03-17T10:32:07.993 回答