1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
|
Installation Instructions
*************************
Installing from Bazaar
======================
Get the latest source from:
$ bzr branch lp:mysql-proxy
Later you can update the tree by running
$ cd mysql-proxy/
$ bzr pull
As you built from BZR none of the configure scripts is prepared. You need:
- autoconf 2.56 or higher
- automake 1.9 or higher
- libtool 1.5.x (not higher)
- flex
to generate the configure script. Use the provided autogen.sh to rebuild
the config-scripts:
$ sh ./autogen.sh
You should have a configure script, ready to build.
MacOS X
-------
In case you are using fink some packages are in different locations and need to be adjusted.
pkg-config installs its pkg.m4 into the fink locations while automake looks in
/usr/local/share/aclocal. Setting ACLOCAL_FLAGS to get a include directory makes aclocal
aware of the new location.
$ ACLOCAL_FLAGS="-I /opt/local/share/aclocal"
$ export ACLOCAL_FLAGS
$ sh ./autogen.sh
if using fink probably: ACLOCAL_FLAGS="-I /sw/share/aclocal"
Installing from Source
======================
$ gzip -cd mysql-proxy-<version>.tar.gz | tar xf -
$ cd mysql-proxy-<version>
Preparing the Build
===================
As you have the source in the right place and the configure script exists, you have
to make sure that the dependencies are in place;
- libevent 1.4 or higher
- lua 5.1.x or higher
- glib2 2.16.0 or higher
- pkg-config
- mysql 5.0.x or higher developer files
- Ensure $MYSQL_HOME/bin is in the PATH (mysql_config required)
CentOS release 4.3 (Final)
--------------------------
CentOS 4.3 does not have lua 5.1 (it is on 5.0) and it has a version of
glib-2.0 that is too old to build.
If you can afford to upgrade lua and glib-2, just obtain newer versions of
LUA and Glib-2 source rpms and run "rpmbuild --rebuild <source rpm name>",
for example out of Fedora Core 7, and install the resulting newer packages.
libevent and libevent-devel have been gathered from Dag Wieers
<dag@wieers.com> repository.
$ yum install \
lua \
lua-devel \
libevent \
libevent-devel \
glib2 \
glib2-devel \
pkg-config \
mysqlclient14-devel
If you cannot upgrade the glib2 to the required minimum version, you'll have
to hack up the glib2 package to install to /usr/local and compile the proxy with
----
%build
export PKG_CONFIG_PATH="/usr/local/lib64/pkgconfig"
export GLIB_CFLAGS="-I/usr/local/include/glib-2.0 -I/usr/local/lib64/glib-2.0/include"
export GLIB_LIBS="-L/usr/local/lib64 -Wl,-rpath /usr/local/lib64 -lglib-2.0"
%configure \
--datadir=%{_datadir}/%{name} \
%if 0%{?with_lua}
--with-lua
%else
--without-lua
%endif
%{__make}
----
Ubuntu/Debian
-------------
$ apt-get install \
pkg-config \
liblua5.1-0 \
liblua5.1-dev \
libevent-dev \
libevent1 \
libglib2.0-0 \
libglib2.0-dev \
libmysqlclient-dev
On Debian and Ubuntu you need to tell the configure script that it has to use
"pkg-config lua5.1" to detect the lua-libriaries instead of the default
"pkg-config lua".
$ ./configure --with-lua=lua5.1
MacOSX
------
If you are using darwin-ports pkg-config might not be able to see the glib-2.0.pc in
/opt/local/lib/pkgconfig.
$ ./configure PKG_CONFIG_PATH=/opt/local/lib/pkgconfig \
LDFLAGS=-L/opt/local/lib \
CPPFLAGS=-I/opt/local/include
openSUSE
--------
Make sure that the following RPM packages (and their dependencies) are
installed (use YaST or any other package management tool to install these):
- glib2-devel
- mysql-devel
- lua-devel
- libevent
You can convert the source tarball into an installable binary RPM by running
the following command:
$ rpmbuild -ta --clean mysql-proxy-<version>.tar.gz
The binary will be installed in /usr/sbin/mysql-proxy, the example lua scripts
are placed into /usr/share/doc/packages/mysql-proxy
Windows
-------
Prerequisites:
Visual C++ 2008 Express - http://www.microsoft.com/express/vc/ (free download, but needs free registration to use for more than 30 days)
bzr (if using Launchpad) - http://bazaar-vcs.org/Download
MySQL Server (>5.0) - http://dev.mysql.com/downloads/ (5.1 recommended)
7-Zip - http://www.7-zip.org/ (to open tar.gz files)
CMake (2.6) - http://www.cmake.org/files/v2.6/cmake-2.6.4-win32-x86.exe
GLib2 (>=2.16) - http://www.gtk.org/download-windows.html you need both the "bin" and "dev" binary packages
libevent (1.4.11) - source only: http://monkey.org/~provos/libevent/ (you need the exact version!)
Lua (>=5.1.4) - source only: http://www.lua.org/download.html
Flex - binary only: http://gnuwin32.sourceforge.net/packages/flex.htm
Compiling MySQL Proxy on Windows is a bit more involved, mostly because it has some dependencies that are unusual for
native Windows and unlike on Linux, Windows does not have a package manager like rpm or apt.
We do not use cygwin to avoid forcing users to install a complete Cygwin environment, even though Cygwin would make
most of this straightforward.
However, for all dependencies we need, with the exception of libevent, there are binary packages with DLLs available.
Libevent must be compiled as a DLL, but MySQL Proxy comes with the patches and CMake files to transparently do so.
After downloading all the packages from above install both Visual C++ 2008 Express, bzr, 7-Zip, CMake and MySQL Server
as any other Windows application that comes with an installer.
Attention: For the MySQL Server be sure to also install the "Developer Components".
You only need to install the "C Include Files/Lib Files".
It helps if you make sure to let the installers add their respective programs to the PATH variable, this makes dealing
with them on the command line easier.
Next, choose a directory where you will build MySQL Proxy and extract the dependencies to. A short path without spaces
is preferred because it makes it easier to enter the paths when running CMake (this example will use c:\work).
If you have downloaded the source package of MySQL Proxy, extract it to c:\work. If you are using the latest sources from
Launchpad, you can use the Windows Explorer with the TortoiseBzr plugin to branch the sources to c:\work.
This example will assume the MySQL Proxy sources are in c:\work\mysql-proxy.
Extract Flex, the two GLib2 packages and Lua to c:\work.
Note: Some files in the "dev" and "bin" GLib2 packages are identical, simply let 7-Zip overwrite them. The two packages are
necessary because one contains the .lib files and the other contains the DLLs we need at runtime (they get copied into the
installer package).
At this point your folder structure in c:\work should look like this (omitting the subdirectories for brevity):
c:\work\
flex\
glib\
lua-5.1.14\
mysql-proxy\
Since the Windows binaries available for Lua 5.1 are using a different version of Microsoft's C runtime dlls, we need to compile
it ourselves. In order to make it work for MySQL Proxy, we need to add two compiler flags to the .bat file Lua provides for
compiling with Visual Studio.
In the file etc\luavs.bat, edit this line:
@set MYCOMPILE=cl /nologo /MD /O2 /W3 /c /D_CRT_SECURE_NO_DEPRECATE
to:
@set MYCOMPILE=cl /nologo /MD /O2 /W3 /c /D_CRT_SECURE_NO_DEPRECATE /D_BIND_TO_CURRENT_MFC_VERSION=1 /D_BIND_TO_CURRENT_CRT_VERSION=1
Then go to the Lua source directory and run the .bat file:
cd c:\work\lua-5.1.4
etc\luavs.bat
The resulting src\lua51.dll is now linked to the correct runtime DLL and can be used with MySQL Proxy.
Note that we have not extracted libevent yet. Since we will be building libevent from source with our DLL patches applied,
we extract libevent into a subdirectory of the MySQL Proxy sources. Using 7-Zip extract the folder libevent-1.4.11-stable into:
c:\work\mysql-proxy\deps\
Attention: When extracting libevent be sure to extract the folder, not the .tar file inside the .tar.gz archive (when opening
libevent-1.4.11-stable.tar.gz 7-Zip will only follow the .gz part, double click on the libevent-1.4.11-stable.tar inside 7-Zip
to be able to extract the folder, not the .tar archive!)
At this point c:\work\mysql-proxy\deps\libevent-1.4.11-stable should be a folder containing source files.
In a command line window, cd to c:\work\mysql-proxy.
We recommend performing an out-of-source build, i.e. executing CMake from a different directory than were the sources are,
because that makes it easy to throw away everything that was not part of the source archive - invaluable when fixing with build errors.
Create a directory called "build":
mkdir build
cd build
Inside the directory c:\work\mysql-proxy\build execute the following CMake command line (you may have to enable word wrapping in the program
you use to read this since it's all on one line to avoid problems with copy/pasting the command):
cmake -G "Visual Studio 9 2008" -DFLEX_EXECUTABLE=c:\work\flex\bin\flex -DMYSQL_INCLUDE_DIRS="c:\Program Files\MySQL\MySQL Server 5.1\include" -DGLIB_DEV_BASE_DIR=c:\work\glib -DLUA_INCLUDE_DIRS=c:\work\lua-5.1.4\src -DLUA_LIBRARY_DIRS=c:\work\lua-5.1.4\src -DCMAKE_INSTALL_PREFIX=c:\work\install -DCMAKE_BUILD_TYPE=Release ..
This command should end with a line like this:
-- Build files have been written to: C:/work/mysql-proxy/build
Now we can actually compile MySQL Proxy:
You can either open the Visual C++ IDE and open the mysql-proxy.sln Solution file in c:\work\mysql-proxy\build and build the solution, or
use the vcbuild command from the command line. Both do the same thing.
If you want to use the binaries on a different machine than where you compiled them on, be sure to build using the "Release" configuration!
In the IDE there is a dropdown that let's you select it, or from the command line do:
cd c:\work\mysql-proxy\build
vcbuild mysql-proxy.sln "Release|Win32"
At this point, there will be lots of warnings during the compilation, but you can safely ignore them. However there should be no errors.
The build should end in a line like:
Build complete: 88 Projects succeeded, 0 Projects failed, 28 Projects skipped
You cannot easily run MySQL Proxy from its build directory, because it will not find the necessary DLLs. To produce a ZIP file you can use
to "install" MySQL Proxy use CPack (part of CMake):
cpack -G ZIP
(Note: CPack also supports NSIS installers, so if you have NSIS installed you can use cpack -G NSIS)
It will produce a ZIP file named like "mysql-proxy-0.7.2-win32.zip" in the directory c:\work\mysql-proxy\build.
Simply extract this ZIP file to whereever you want to install MySQL Proxy. Inside the new directory there will be the familiar
bin\mysql-proxy.exe command.
Verify that it works by running:
bin\mysql-proxy --help-all
Whew that's it, we are done :)
All other Platforms
-------------------
On most platforms a simple configure run works nicely:
$ ./configure
If lua isn't shipped with a lua.pc file for pkg-config we need to override the
pkg-config checks:
$ ./configure \
LUA_CFLAGS="-I/directory/of/lua.h" \
LUA_LDFLAGS="-L/directory/of/liblua.so -llua"
In case libevent is not detected correctly, you should set LDFLAGS and CPPFLAGS:
$ ./configure \
LDFLAGS="-L/directory/of/libevent.so -levent" \
CPPFLAGS="-I/directory/of/event.h"
In case the detected MySQL is not the correct one:
export DEFAULT_MYSQL=/path/to/mysql-5.1
export MYSQL_LIBS="-L${DEFAULT_MYSQL} -lmysqlclient -lz -lm"
export MYSQL_CFLAGS="-I${DEFAULT_MYSQL}/include"
export MYSQL_CONFIG="${DEFAULT_MYSQL}/bin/mysql_config"
export MYSQL_TEST_BIN="${DEFAULT_MYSQL}/bin/mysqltest"
Building
========
$ make
$ make install
You should have a /usr/local/sbin/mysql-proxy now.
Documentation
=============
MySQL Proxy uses doxygen for its documentation. In order to make the best use out of the documentation, you
need to have these packages installed (and in your path):
- Doxygen: http://doxygen.org
- Graphviz: http://graphviz.org
- MSCGen: http://www.mcternan.me.uk/mscgen/
All of these programs are available for various popular platforms.
After installing these programs, generating the documentation is as simple as:
$ make docs
or
$ make docs-bzr
The latter command produces the same documentation as the first one, the only difference is that it will include more detailed
information about the version the documentation was generated from, which is useful if you work with the source from Launchpad
directly: The documentation's version number will include the revision number and the date of the last commit in your tree.
MySQL Proxy's documentation is generated as HTML output in the doxygen/html/ directory.
|