本文主要介绍了如何在源码安装mysql5.5,所用系统为CentOS6.5


一、安装相应的开发环境

yum install -y ncurses-devel
yum install -y libaio
yum install -y bison
yum install -y gcc-c++
yum install -y openssl-devel


二、安装cmake

跨平台编译器

# tar xf cmake-2.8.8.tar.gz
# cd cmake-2.8.8
# ./bootstrap
# make 
# make install

也可以使用yum或者rpm进行安装

yum install -y cmake


三、编译安装mysql-5.5.33


1、编译安装

# groupadd -r mysql
# useradd -g mysql -r -d /mydata/data mysql
# tar xf mysql-5.5.33.tar.gz 
# cd mysql-5.5.33
# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/mydata/data -DSYSCONFDIR=/etc -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DWITH_SSL=system -DWITH_ZLIB=system -DWITH_LIBWRAP=0-DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci
# make 
# make install

Linux下源码安装Mysql5.5_第1张图片

Linux下源码安装Mysql5.5_第2张图片


2.把mysql下所有文件的属主改为root,属组改为mysql

# cd /usr/local/mysql
# chown -R .mysql .

Linux下源码安装Mysql5.5_第3张图片

3.复制support-files中的my-large.cnf到/etc/my.cnf(实际生产环境最好给my.cnf做备份)并修改my.cnf

# cp support-files/my-large.cnf /etc/my.cnf
# vim /etc/my.cnf

在如下位置添加datadir=/mydata/data

Linux下源码安装Mysql5.5_第4张图片

4.手动初始化复制mysql.server到/etc/rc.d/init.d/mysqld,并把其加进服务

# scripts/mysql_install_db --user=mysql --datadir=/mydata/data/
# cp support-files/mysql.server /etc/rc.d/init.d/mysqld
# chmod +x /etc/rc.d/init.d/mysqld
# chkconfig --add mysqld
# vim /etc/profile.d/mysql.sh

wKioL1PSlVaAe0_IAAAwmwEkc4k168.jpg

至此,可以使用mysql命令和服务:

启动服务:

Linux下源码安装Mysql5.5_第5张图片

mysql客户端命令:

Linux下源码安装Mysql5.5_第6张图片


四、cmake说明

指定安装文件的安装路径时常用的选项:

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql

-DMYSQL_DATADIR=/data/mysql

-DSYSCONFDIR=/etc


默认编译的存储引擎包括:csv、myisam、myisammrg和heap。若要安装其它存储引擎,可以使用类似如下编译选项:

-DWITH_INNOBASE_STORAGE_ENGINE=1

-DWITH_ARCHIVE_STORAGE_ENGINE=1

-DWITH_BLACKHOLE_STORAGE_ENGINE=1

-DWITH_FEDERATED_STORAGE_ENGINE=1


若要明确指定不编译某存储引擎,可以使用类似如下的选项:

-DWITHOUT__STORAGE_ENGINE=1

比如:

-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1

-DWITHOUT_FEDERATED_STORAGE_ENGINE=1

-DWITHOUT_PARTITION_STORAGE_ENGINE=1


如若要编译进其它功能,如SSL等,则可使用类似如下选项来实现编译时使用某库或不使用某库:

-DWITH_READLINE=1

-DWITH_SSL=system

-DWITH_ZLIB=system

-DWITH_LIBWRAP=0


其它常用的选项:

-DMYSQL_TCP_PORT=3306

-DMYSQL_UNIX_ADDR=/tmp/mysql.sock

-DENABLED_LOCAL_INFILE=1

-DEXTRA_CHARSETS=all

-DDEFAULT_CHARSET=utf8

-DDEFAULT_COLLATION=utf8_general_ci

-DWITH_DEBUG=0

-DENABLE_PROFILING=1


如果想清理此前的编译所生成的文件,则需要使用如下命令:

make clean

rm CMakeCache.txt