MySQL Proxy是一个通过MySQL网络协议,提供MySQL服务器与客户端之间连接的应用工具,所有MySQL兼容的客户端(包括mysql命令行,调用mysql命令行的类库,以及支持MySQL网络协议的应用)均无需任何修改即可直接连接Mysql Proxy。

  本文记录ENTERPRISE LINUX5u3版本下源码编译安装MySQL Proxy 0.8的步骤。

1、安装依赖包

源码编译方式安装MySQL Proxy前,下列依赖包必须首先安装:

  • libevent 1.x or higher (1.3b or later is preferred) 
  • lua 5.1.x or higher 
  • glib2 2.16.0 or higher (官方文档说是2.6.0或更高,实际安装时,mysql-proxy 0.8版本时提示不能低于2.16.0的)
  • pkg-config 
  • libtool 1.5 or higher 
  • MySQL 5.0.x or higher developer files 

A>. 安装libevent

RHEL5.3版本自带的libevent版本较低,为1.1版,不符合需求,直接下载更高版本安装,操作步骤如下:

B>. 安装lua脚本语言包

Lua是一个极轻量级的脚本语言,MySQL Proxy通过该语言进行功能扩充。

首先到其官网下载最新版本5.1.4,而后解压安装,依次执行命令如下:

修改MakeFile文件,将:

    INSTALL_TOP= /usr/local

修改为:

    INSTALL_TOP= /usr/local/lua

这样做的目的,是为了将lua相关的文件放在同一目录内,便于查找和应用。

Lua的编译和安装详见目录内的INSTALL文件,三思这里是在linux下安装,直接执行下列命令即能完成编译和安装:

    # make linux install

C>. 安装glib2

官方文档说是需要2.6.0或更高版本,实际在安装mysql-proxy 0.8时,提示glib2的版本不能低于2.16.0,这里为了后面安装进程顺利执行,首先升级系统的glib2,步骤如下。

    # wget http://ftp.gnome.org/pub/gnome/sources/glib/2.22/glib-2.22.5.tar.gz

    # tar xvfz glib-2.22.5.tar.gz

    # cd glib-2.22.5

    # ./configure --prefix=/usr/local/glib-2.2

    # make && make install

D>. 安装MySQL开发包

主要需要用到mysql_config等应用,mysql的开发包可以直接到其官网下载:http://dev.mysql.com/downloads/mysql/5.1.html

Rpm包的安装比较简单,执行命令如下:

    # rpm -ivh MySQL-devel-community-5.1.51-1.rhel5.x86_64.rpm

2、安装MySQL Proxy

接下来,终于轮到正主上场,三思这里安装的是MySQL Proxy 0.8.1版本,也可以直接到其官网下载:http://dev.mysql.com/downloads/mysql-proxy/

    # tar xvfz mysql-proxy-0.8.1.tar.gz

    # cd mysql-proxy-0.8.1

    # ./configure LDFLAGS="-lm -ldl" LUA_CFLAGS="/usr/local/lua/bin/lua -I/usr/local/lua/include" LUA_LIBS="/usr/local/lua/lib -llua" --prefix=/usr/local/mysql-proxy --with-lua

    # make

    # make install

安装成功后,执行mysql-proxy命令验证:

    [root@rhel5u3 mysql-proxy]# /usr/local/mysql-proxy/bin/mysql-proxy -V

    mysql-proxy 0.8.1

    chassis: mysql-proxy 0.8.1

    glib2: 2.22.5

    libevent: 1.4.14b-stable

    LUA: Lua 5.1.4

    package.path: /usr/local/mysql-proxy/lib/mysql-proxy/lua/?.lua

    package.cpath: /usr/local/mysql-proxy/lib/mysql-proxy/lua/?.so

    -- modules

    admin: 0.8.1

    proxy: 0.8.1

  编译过程看起来简单,仅只是几条命令,但就是这个安装颇不顺利,折腾了三思整整一天时间,也许是我运气不好,当然更多应该还是水平有限,实际执行编译的过程中遇到了很多错误,错误信息及解决方案见下,希望对同样遇到该问题的同学有所帮助:

操作系统版本如下:

    [root@rhel5u3 ~]# cat /etc/issue

    Enterprise Linux Enterprise Linux Server release 5.3 (Carthage)

    Kernel \r on an \m

错误1:

    checking for LUA... no

    ... checked for Lua via pkg-config: No package ¨lua¨ found. retrying with lua5.1

看错误信息是说找不到lua包。

解决方案:

A>. 参数1.2步骤中所示,编译安装lua;

B>. 设置环境变量:

    export LUA_CFLAGS="-I/usr/local/lua/include"

    export LUA_LIBS="-L/usr/local/lua/lib -llua -ldl"

注意变量中的路径应为lua实际安装路径,而后重新执行configure配置编译程序。

如果执行上述操作故障依旧,可以尝试将lua安装路径下的etc/lua.pc文件复制到glib2安装路径中的lib/pkgconfig/文件夹内。

错误2:

    checking for GLIB... configure: error: Package requirements (glib-2.0 >= 2.16.0) were not met:

    Requested ¨glib-2.0 >= 2.16.0¨ but version of GLib is 2.12.3

说明默认识别到的glib2版本不正确。

解决方案:

A>. 参照1.3步骤所示,编译安装适当版的glib;

B>. 设置环境变量:

    export GLIB_CFLAGS="-I/usr/local/glib-2.2/include/glib-2.0"

    export GLIB_LIBS="-L/usr/local/glib-2.2/lib/glib-2.0"

    export GMODULE_CFLAGS="-I/usr/local/glib-2.2/include"

    export GMODULE_LIBS="-L/usr/local/glib-2.2/lib"

    export GTHREAD_CFLAGS="-I/usr/local/glib-2.2/include"

    export GTHREAD_LIBS="-L/usr/local/glib-2.2/lib"

特别强调,GMODULE和GTHREAD的相关变量必须设置,否则会遇到(gmodule-2.0 >= 2.16.0) were not met或(gthread-2.0 >= 2.16.0) were not met之类错误。

变量值中的路径应为glib2的实际安装路径,而后重新执行configure配置编译程序。

错误3:

    checking for event_init in -levent... no

    configure: error: libevent is required

没有找到libevent依赖包。

解决方案:

A>. 参照1.1步骤中所示,编译安装libevent。

B>. 设置环境变量:

    export LDFLAGS="-L/usr/local/libevent-1.4/lib -lm"

而后重新执行configure配置编译程序

错误4:

    /usr/local/lua/lib/liblua.a: could not read symbols: Bad value

看起来是lua调用出错,相关文档提示是提示:64bit环境可能遇到该现象。

解决方案:

A>. 编辑lua的src/MakeFile文件,修改下列参数:

    CFLAGS= -O2 -Wall $(MYCFLAGS)

修改为:

    CFLAGS= -O2 -Wall -fPIC $(MYCFLAGS)

B>. 按照1.2步骤中所示,编译安装lua。如果之前已经编译过,记得要执行make clean清除已编译配置。

错误5:

    /usr/local/glib-2.22/include/glib-2.0/glib/gtypes.h:34:24: error: glibconfig.h: No such file or directory

解决方案:

    # cp /usr/local/glib-2.2/lib/glib-2.0/include/glibconfig.h /usr/local/glib-2.2/include/glib-2.0/

而后重新执行编译。