cygwin mysql开发_Windows下使用Cygwin编译MySQL客户端

mintty 是一个小巧但却很实用的 cygwin 终端机,但有个严重的问题就是无法调用交互性的 windows 原生程序,比如说 mysql.exe,当你在 mintty 中输入如下的命令:

$ mysql -uroot -p

本来 mysql.exe 会提示输入密码,但在 mintty 中程序会直接挂起,不再响应,实际上即使在 -p 参数后面跟上密码,也是一样的。

某些程序,比如 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/......

$ tar zxvf mysql-5.5.0-m2.tar.gz

$ cd mysql-5.5.0-m2

在动手编译之前,先打开 cygwin 安装程序安装 readline,用来替代 mysql 自带的。mysql 源码包捆绑的 readline 在 cygwin中编译会报错。

准备好以后,开始编译过程:

$ ./configure --without-server --without-readline cflags=-o2 cxxflags=-o2

$ make

$ make install

cygwin 的编译速度是很慢的,和原生 *nix 系统完全没法比,所以如果不是闲到发慌,最好不要去编译“复杂”的 mysql server。

编译安装完 mysql client,打开 windows 系统中的 mysql server,使用如下的命令测试一下:

$ mysql -h127.0.0.1 -uroot -p

为什么加上 -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:

$ cp support-files/my-medium.cnf /etc/my.cnf

在 [client] 中加入 protocol=tcp,eg:

# 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 -uroot -p 直接连接 windows 中的 mysql server 了。

令人纠结的乱码问题

顺便提一下,mysql 中大部分人都是使用的 utf-8 编码,我也是。为了规避乱码,需要在 cygwin/mintty 中把字符集设置为 utf-8,不过让人极度不爽的是,这样的话,中文 windows 的程序,就会乱码(比如 ping, tracert,nslookup….),因为中文 windows 环境使用的是 gbk 字符集,没办法,要么换成 e 文 windows,要么忍着。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值