在本章中,我们来学习一下怎么在CentOS 6.4上优化编译MySQL-5.6.12源代码并按装之。
第一步,先删除CentOS已有的MySQL然后安装MySQL的一些依赖包:
引用
# yum remove mysql
# yum -y install gcc gcc-c++ autoconf automake zlib* fiex* libxml* ncurses-devel libmcrypt* libtool-ltdl-devel* cmake cmake-gui libaio-devel
第二步,添加MySQL用户和用户组:
引用
# groupadd mysql
# useradd -g mysql mysql
第三步,下载并解压tar源代码文件:
引用
# wget http://124.14.8.54/download/22816824/28510613/6/gz/143/181/1370360045711_693/mysql-5.6.12.tar.gz
# chmod +x mysql-5.6.12.tar.gz
# tar xzvf mysql-5.6.12.tar.gz
第四步,开始编译源代码:
引用
# cd mysql-5.6.12
# BUILD/autorun.sh;./configure --prefix=/opt/mysql/mysql56 --localstatedir=/data/mysql56/data --enable-assembler --without-isam --with-unix-socket-path=/opt/mysql/mysql56.sock --enable-thread-safe-client --with-client-ldflags=-all-static --with-mysqld-ldflags=-all-static --with-plugins=partition,innobase --with-charset=utf8 --with-collation=utf8_general_ci --with-extra-charsets=all --with-big-tables --without-debug;make //这一步在本人的机子上将进编译了40-50分钟
# make
# make install
下面来解释一下上面的编译参数:
--prefix:指定mysql的安装目标路径,默认情况下为/usr/local/mysql;
--localstatedir:指定mysql用户的数据库目录;
--with-unix-socket-path:指定Mysql启动后,联机套接字文件的位置和文件名;
--enable-assembler:使用一些字符函数的汇编版本;
--without-isam:去掉isam表类型支持,现在很少用了,isam表是一种依赖平台的表;
--enable-thread-safe-client:以线程方式编译客户端 线程安全;
--with-client-ldflags:以纯静态方式编译客户端,在正式的生产环境中能带来很明显的性能提升;
--with-mysqld-ldflags:以纯静态方式编译服务端,在正式的生产环境中能带来很明显的性能提升;
--with-plugins:支持引擎;
--with-charset:添加字符支持,如utf8、gbk等;
--with-collation:设置服务器的排序规则;
--with-extra-charsets:
--with-big-tables:支持大数据库表;
--without-debug:去除debug模式,在正式的生产环境中能带来很明显的性能提升。
第五步,修改mysql目录所有者和组:
引用
# cd /opt/mysql/mysql56 //修改mysql安装目录
# chown -R mysql:mysql .
# cd /data/mysql56/data //修改mysql数据库文件目录
# chown -R mysql:mysql .
第六步,初始化mysql数据库:
引用
# cd /opt/mysql/mysql56
# scripts/mysql_install_db --user=mysql --datadir=/data/mysql56/data
第七步,复制mysql服务启动脚本及加入PATH路:
引用
# cp support-files/mysql.server /etc/init.d/mysqld
# cp support-files/my-default.cnf /etc/my.cnf
# vi /etc/profile
export PATH=/opt/mysql/mysql56/bin:/opt/mysql/mysql56/lib:$PATH
# source /etc/profile
第八步,启动mysql服务并加入开机自启动:
引用
# service mysqld start
# chkconfig --level 35 mysqld on
第九步,检查mysql服务是否启动:
引用
# netstat -tulnp | grep 3306
# mysql -u root -p //密码为空,如果能登陆上,则安装成功。
第十步,修改MySQL用户root的密码:
引用
# mysqladmin -u root password '123456'
另还,最好再建一个软链接:
ln -s /opt/mysql/mysql56/bin/mysql /usr/bin