Linux 源码编译安装 MySQL 5.5.x

Linux 环境:CentOS 6.5

MySQL 版本:5.5.20,附下载地址:【点击下载

1、安装cmake

MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具。

因此,我们首先要在系统中源码编译安装cmake工具。

下载 cmake

[root@ruxingli soft]# wget http://www.cmake.org/files/v2.8/cmake-2.8.4.tar.gz

解压

[root@ruxingli soft]# tar zxvf cmake-2.8.4.tar.gz

[root@ruxingli soft]# cd cmake-2.8.4
[root@ruxingli cmake-2.8.4]# ./configure
[root@ruxingli cmake-2.8.4]# make && make install

2、确保以下所需系统软件包已经被安装

通过 rpm -qa | grep name 的方式验证以下软件包是否已全部安装。

gcc* gcc-c++* autoconf* automake* zlib* libxml* ncurses-devel* libgcrypt* libtool*

如果缺少相关的软件包,可通过yum -y install 的方式在线安装,或直接从系统安装光盘中找到并通过rpm -ivh 的方式安装。

3、安装前的系统测试

建立mysql安装目录及数据存放目录

[root@ruxingli cmake-2.8.4]# mkdir -p /usr/local/mysql5.5.20

创建用户和用户组

[root@ruxingli cmake-2.8.4]# groupadd mysql
[root@ruxingli cmake-2.8.4]# useradd -g mysql mysql

赋予数据存放目录权限

[root@ruxingli mysql-5.5.20]# chown mysql:mysql -R /usr/local/mysql5.5.20/

4、编译安装MySQL5.5.20

[root@ruxingli soft]# tar zxvf mysql-5.5.20.tar.gz
[root@ruxingli soft]# cd mysql-5.5.20<strong>
</strong>

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql5.5.20/ -DSYSCONFDIR=/etc/ -DMYSQL_DATADIR=/usr/local/mysql5.5.20/data/ -DMYSQL_TCP_PORT=3306 -DMYSQL_UNIX_ADDR=/tmp/mysqld.sock -DMYSQL_USER=mysql -DEXTRA_CHARSETS=all -DWITH_READLINE=1 -DWITH_SSL=system -DWITH_EMBEDDED_SERVER=1 -DENABLED_LOCAL_INFILE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_SSL=bundled

可能出现的错误

技术分享

解决方法:

[root@ruxingli mysql-5.5.20]# yum install bison

技术分享

解决方法:

去掉 -DMYSQL_USER=mysql

[root@ruxingli mysql-5.5.20]# make
[root@ruxingli mysql-5.5.20]# make install
初始化数据库

执行前需赋给scripts/mysql_install_db文件执行权限

[root@ruxingli mysql-5.5.20]# chmod 755 scripts/mysql_install_db
[root@ruxingli mysql-5.5.20]# scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql5.5.20/ --datadir=/usr/local/mysql5.5.20/data/

创建管理MySQL数据库的shell脚本

[root@ruxingli mysql-5.5.20]# mkdir /usr/local/mysql5.5.20/init.d
[root@ruxingli mysql-5.5.20]# cp support-files/mysql.server /usr/local/mysql5.5.20/init.d/mysql

赋予shell脚本可执行权限:

[root@ruxingli mysql-5.5.20]# chmod +x /usr/local/mysql5.5.20/init.d/mysql
启动MySQL

[root@ruxingli mysql-5.5.20]# /usr/local/mysql5.5.20/init.d/mysql start

如果启动失败,请参考http://blog.csdn.net/zalion/article/details/9274263

我的解决方法是:

[root@ruxingli3 mysql]# rm -rf /var/lock/subsys/mysql

通过命令行来管理MySQL服务器

[root@ruxingli3 mysql5.5.20]# /usr/local/mysql5.5.20/bin/mysql
为 root 账户设置初始密码

[root@ruxingli3 mysql5.5.20]# /usr/local/mysql5.5.20/bin/mysqladmin -u root password '123456'
进入命令行MySQL

[root@ruxingli3 mysql5.5.20]# /usr/local/mysql5.5.20/bin/mysql -u root -p123456

删除本机匿名连接的空密码帐号

mysql> use mysql;
mysql> delete from user where password='';
mysql> flush privileges;
mysql> select Host,User,Password from user;
mysql> exit


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。