当前位置: 移动技术网 > IT编程>数据库>Mysql > Linux下编译安装Mysql 5.5的简单步骤

Linux下编译安装Mysql 5.5的简单步骤

2017年12月12日  | 移动技术网IT编程  | 我要评论

我们结婚了120728,ca1653,银富鳞

首先是安装cmake环境。因为博主测试机是ubuntu,所以直接用apt-get install cmake命令来安装,yum相信应该也一样。或者可以编译安装,步骤如下。

复制代码 代码如下:

wget http://www.cmake.org/files/v2.8/cmake-2.8.12.2.tar.gz
tarx zvfc cmake-2.8.12.2.tar.gz
cd cmake-2.8.12.2
 ./configure
make && make install

安装完成后执行cmake -version,确定已经正确安装。

然后下载mysql最新源码包,编译安装。

复制代码 代码如下:

wget http://dev.mysql.com/get/downloads/mysql-5.5/mysql-5.5.36.tar.gz
tar xzvf mysql-5.5.36.tar.gz
cd mysql-5.5.36
cmake -dcmake_install_prefix=/usr/local/mysql -dextra_charsets=all -ddefault_charset=utf8 -ddefault_collation=utf8_general_ci -dwith_readline=1 -dwith_ssl=system -dwith_zlib=system -dwith_embedded_server=1 -denabled_local_infile=1 -dmysql_datadir=/data/mysql
make && make install

这里博主遇到一个有关ssl的错误,提示信息如下所示。

linking c shared module adt_null.so
[ 65%] built target audit_null
scanning dependencies of target vio
[ 65%] building c object vio/cmakefiles/vio.dir/vio.c.o
[ 65%] building c object vio/cmakefiles/vio.dir/viosocket.c.o
[ 65%] building c object vio/cmakefiles/vio.dir/viossl.c.o
/root/mysql-5.5.36/vio/viossl.c: in function ‘ssl_do':
/root/mysql-5.5.36/vio/viossl.c:175: error: ‘ssl_op_no_compression' undeclared (first use in this function)
/root/mysql-5.5.36/vio/viossl.c:175: error: (each undeclared identifier is reported only once
/root/mysql-5.5.36/vio/viossl.c:175: error: for each function it appears in.)
make[2]: *** [vio/cmakefiles/vio.dir/viossl.c.o] error 1
make[1]: *** [vio/cmakefiles/vio.dir/all] error 2
make: *** [all] error 2

最后发现这个问题的原因是mysql5.5无法在openssl-1.0.0及更低版本下编译导致的。如果不需要ssl可以去掉with_ssl配置项,也可以升级openssl的版本,另外更方便的方法可以在cmake之前打一个补丁。

复制代码 代码如下:

wget http://dev.mysql.com/get/downloads/mysql-5.5/mysql-5.5.36.tar.gz
tar xzvf mysql-5.5.36.tar.gz
cd mysql-5.5.36
wget -c "http://bugs.mysql.com/file.php?id=19941&bug_id=68999" -o mysql-openssl.patch
patch -p1 < span > mysql-openssl.patch

最后复制配置文件、修改。

复制代码 代码如下:

cp support-files/my-medium.cnf /etc/my.cnf
sed '/skip-external-locking/i\datadir = /data/mysql' -i /etc/my.cnf
sed -i 's:#innodb:innodb:g' /etc/my.cnf
sed -i 's:/usr/local/mysql/data:/data/mysql:g' /etc/my.cnf

启动mysql,成功!

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网