Windows下使用Cygwin编译MySQL客户端
2015-05-11 11:08
113 查看
转自:http://www.phpvim.net/os/windows/build-mysql-client-on-cygwin.html (蓝色字为本人添加)
MinTTY 是一个小巧但却很实用的 Cygwin 终端机,但有个严重的问题就是无法调用交互性的 Windows 原生程序,比如说 mysql.exe,当你在 MinTTY 中输入如下的命令:
本来 mysql.exe 会提示输入密码,但在 MinTTY 中程序会直接挂起,不再响应,实际上即使在 -p 参数后面跟上密码,也是一样的。
(我自己在windows服务器上用Cygwin编译mysql-5.6.16后,用mysql命令的时候一直挂起,不明白原因,网上找了好多,只有这篇文章有说到这个挂起的问题)
某些程序,比如 python,会提供参数 -i,使自身在终端中进入交互模式,可惜并非所有的程序都有这样的参数。
解决的办法,使用 Cygwin 版本的 MySQL 客户端,但 Cygwin 并没有提供,所以就只有自己动手编译一个!
在 http://dev.mysql.com/downloads 下载源码包并解压。
(
wget
http://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.0-m2.tar.gz/from/......
保存的文件是......,应该改成
wget-O
mysql-5.5.0-m2.tar.gz http://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.0-m2.tar.gz/from/......
保存成文件mysql-5.5.0-m2.tar.gz
)
在动手编译之前,先打开 Cygwin 安装程序安装 readline,用来替代 MySQL 自带的。MySQL 源码包捆绑的 readline 在 Cygwin中编译会报错。
准备好以后,开始编译过程:
(
我在./configure时出错,报cannot remove `libtoolT': No such file or directory
这时直接打开 configure,把 $RM “$cfgfile” 那行注释掉,重新再运行
./configure 就可以了
make也会报错,do_abi_check fail
此时编辑Makefile,查找do_abi_check:
将do_abi_check: 之后到done 都注释,保存后make,ok
)
Cygwin 的编译速度是很慢的,和原生 Linux 系统完全没法比,所以如果不是闲到发慌,最好不要去编译“复杂”的 MySQL Server。
编译安装完 MySQL Client,打开 Windows 系统中的 MySQL Server,使用如下的命令测试一下:
为什么加上 -h127.0.0.1 呢?默认的情况下,不带 -h 参数或者使用 -h localhost,MySQL 都会使用 Unix socket file 连接服务器,即使你在命令中指定了端口也会被忽略的,所以肯定连接不上的,提示找不到 /tmp/mysql.sock。使用 IP 或者主机名后,MySQL 就会使用 TCP/IP 模式连接服务器的 3306 端口,这样就什么没问题了。
为了方便,在配置文件中强制客户端使用 TCP/IP 连接模式。
复制 mysql-5.5.0-m2/support-files 中的配置文件样板到 /etc/my.cnf,EG:
在 [client] 中加入 protocol=TCP,EG:
之后就可以使用 mysql -uroot -p 直接连接 Windows 中的 MySQL Server 了。
令人纠结的乱码问题
顺便提一下,MySQL 中大部分人都是使用的 UTF-8 编码,我也是。为了规避乱码,需要在 Cygwin/MinTTY 中把字符集设置为 UTF-8,不过让人极度不爽的是,这样的话,中文 Windows 的程序,就会乱码(比如 ping, tracert,nslookup….),因为中文 Windows 环境使用的是 GBK 字符集,没办法,要么换成 E 文 Windows,要么忍着。
MinTTY 是一个小巧但却很实用的 Cygwin 终端机,但有个严重的问题就是无法调用交互性的 Windows 原生程序,比如说 mysql.exe,当你在 MinTTY 中输入如下的命令:
1 | $ mysql -u root -p |
(我自己在windows服务器上用Cygwin编译mysql-5.6.16后,用mysql命令的时候一直挂起,不明白原因,网上找了好多,只有这篇文章有说到这个挂起的问题)
某些程序,比如 python,会提供参数 -i,使自身在终端中进入交互模式,可惜并非所有的程序都有这样的参数。
解决的办法,使用 Cygwin 版本的 MySQL 客户端,但 Cygwin 并没有提供,所以就只有自己动手编译一个!
在 http://dev.mysql.com/downloads 下载源码包并解压。
12 | $ wget http://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.0-m2.tar.gz/from/...... $ tar zxvf mysql-5.5.0-m2.tar.gz $ cd mysql-5.5.0-m2 |
wget
http://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.0-m2.tar.gz/from/......
保存的文件是......,应该改成
wget-O
mysql-5.5.0-m2.tar.gz http://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.0-m2.tar.gz/from/......
保存成文件mysql-5.5.0-m2.tar.gz
)
在动手编译之前,先打开 Cygwin 安装程序安装 readline,用来替代 MySQL 自带的。MySQL 源码包捆绑的 readline 在 Cygwin中编译会报错。
准备好以后,开始编译过程:
12 | $ ./configure --without-server --without-readline CFLAGS=-O2 CXXFLAGS=-O2 $ make $ make install |
我在./configure时出错,报cannot remove `libtoolT': No such file or directory
这时直接打开 configure,把 $RM “$cfgfile” 那行注释掉,重新再运行
./configure 就可以了
make也会报错,do_abi_check fail
此时编辑Makefile,查找do_abi_check:
将do_abi_check: 之后到done 都注释,保存后make,ok
)
Cygwin 的编译速度是很慢的,和原生 Linux 系统完全没法比,所以如果不是闲到发慌,最好不要去编译“复杂”的 MySQL Server。
编译安装完 MySQL Client,打开 Windows 系统中的 MySQL Server,使用如下的命令测试一下:
1 | $ mysql -h 127.0.0.1 -uroot -p |
为了方便,在配置文件中强制客户端使用 TCP/IP 连接模式。
复制 mysql-5.5.0-m2/support-files 中的配置文件样板到 /etc/my.cnf,EG:
1 | $ cp support-files/my-medium.cnf /etc/my.cnf |
12 | # The following options will be passed to all MySQL clients [client] #password = your_password port = 3306 socket = /tmp/mysql.sock protocol = TCP ## 指定客户端连接的默认编码,注意是 utf8,不是 utf-8 ## 可根据需要自行修改 default-character-set = utf8 |
令人纠结的乱码问题
顺便提一下,MySQL 中大部分人都是使用的 UTF-8 编码,我也是。为了规避乱码,需要在 Cygwin/MinTTY 中把字符集设置为 UTF-8,不过让人极度不爽的是,这样的话,中文 Windows 的程序,就会乱码(比如 ping, tracert,nslookup….),因为中文 Windows 环境使用的是 GBK 字符集,没办法,要么换成 E 文 Windows,要么忍着。
相关文章推荐
- Windows下使用Cygwin编译MySQL客户端
- Windows SublimeText内使用NDK编译Android so(不用cygwin)
- 在Windows下(不使用cygwin)NDK直接编译openssl动态库
- Windows SublimeText内使用NDK编译Android so(不用cygwin)
- Windows下使用MySQL客户端连接MySQL服务器的操作
- Windows环境下使用cygwin ndk_r9c编译x264
- 在windows下使用vs2013编译和调试mysql源代码
- Windows下使用Code::Blocks+cygwin编译CuraEngine
- 在Windows使用Cygwin编译Redis 3.x
- windows下Qt5.6.0 编译Mysql驱动,并使用。
- 使用Cygwin编译Windows版本的Rsync
- 在Windows使用Cygwin编译Redis 3.x
- Windows下使用VIM&Cygwin,搭建Mainframe开发环境(六)---用awk/sed合并PLI/Cobol编译结果
- 在Windows中使用Cygwin环境下的gcc编译器编译【电脑教程网】Informix ESQ/C程序
- android学习——NDK入门 windows下安装cygwin 与 Eclipse使用CDT 自动编译
- 在Windows下面使用cygwin将含有JNI的C文件编译成DLL文件
- 在 Cygwin 中编译 MySQL 客户端
- 使用cygwin在windows下编译ndk
- windows下cygwin使用ndkr8编译ffmpeg
- windows下使用cygwin编译memcached1.4.15