centos6.9编译安装mysql5.7.19

废话不多说,先直接来完全操作命令

yum install cmake gcc gcc-c++ ncurses-devel wget
wget http://downloads.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz
tar zxf boost_1_59_0.tar.gz
wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.19.tar.gz
tar zxf mysql-5.7.19.tar.gz
cd mysql-5.7.19
cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql  -DMYSQL_DATADIR=/usr/local/mysql/data  -DMYSQL_UNIX_ADDR=/tmp/mysql.sock  -DDEFAULT_CHARSET=utf8  -DDEFAULT_COLLATION=utf8_general_ci  -DWITH_BOOST=../mysql/boost
也可以用注释的那条,只不过参数多了而已,具体参数请参考 https://dev.mysql.com/doc/refman/5.7/en/source-configuration-options.html
#cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DSYSCONFDIR=/etc -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1  -DWITH_PARTITION_STORAGE_ENGINE=1 -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DENABLED_LOCAL_INFILE=1 -DENABLE_DOWNLOADS=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8mb4 -DDEFAULT_COLLAION=utf8mb4_general_ci -DWITH_DEBUG=0 -DMYSQL_MAINTAINER_MODE=0 -DWITH_SSL=bundled -DWITH_ZLIB=bundled -DWITH_BOOST=../boost_1_59_0
如果遇到错误
rm -rf CMakeCache.txt
make
make install

下载mysql_boost源码包
解压
安装cmake
用cmake编译
提示缺少ncurses-devel,根据提示安装
yum install ncurses-devel
[sudo apt install libncurses5-dev]
然后常规make,make install
参考http://blog.csdn.net/u012453679/article/details/60480682,但是完全照步骤去操作,根本不通
,在初始化的时候会出现ERROR] COLLATION ‘utf8_general_ci’ is not valid for CHARACTER SET ‘latin1’,参考http://sndapk.blog.51cto.com/5385144/925738解决,然后再次初始化,启动,登录mysql,执行查询命令,提示需要进行修改密码,用set password=password(‘新密码’);解决
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_BOOST=./mysql/boost
cmake 参数解释:
-DCMAKE_INSTALL_PREFIX: 指定安装路径
-DMYSQL_DATADIR : 指定数据存放路径
-DMYSQL_UNIX_ADDR :指定套间字路径
-DDEFAULT_CHARSET : 设置字符集
-DDEFAULT_COLLATION : 设置字符校验集
-DWITH_BOOST : 指定Boost扩展源码路径

你可能感兴趣的:(Linux)