从yum源中获得官方为我们提供的mysql、php等其功能有限,而我们自行编译,是为了定制化,可以在编译过程中添加我们需要的功能模块,需要什么服务就安装什么,这样系统就比较纯净。
实验环境
主机(版本:ip) | 功用 |
---|---|
虚拟机server1(rhel6.5:172.25.2.1) | 搭建lnmp |
真机(rhel7.3:172.25.2.250) | 测试机 |
首先,封装一个rhel6.5的母盘,然后快照一个镜像
一、源码编译MySQL
1、解压安装mysql:tar zxf mysql-boost-5.7.17.tar.gz
2、安装cmake,cmake相当于configure,用来编译yum install -y cmake-2.8.12.2-4.el6.x86_64.rpm
3、进入解压目录,编译:
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/lnmp/mysql \ #安装目录
-DMYSQL_DATADIR=/usr/local/lnmp/mysql/data \ #数据库存放目录
-DMYSQL_UNIX_ADDR=/usr/local/lnmp/mysql/data/mysql.sock \ #Unix socket 文件路径
-DWITH_MYISAM_STORAGE_ENGINE=1 \ #安装 myisam 存储引擎
-DWITH_INNOBASE_STORAGE_ENGINE=1 \ #安装 innodb 存储引擎
-DDEFAULT_CHARSET=utf8 \ #使用 utf8 字符
-DDEFAULT_COLLATION=utf8_general_ci \ #校验字符
-DEXTRA_CHARSETS=all \ #安装所有扩展字符集
-DWITH_BOOST=boost/boost_1_59_0/
- 当报错:
CMake Error at cmake/boost.cmake:81 (MESSAGE):
You can download it with -DDOWNLOAD_BOOST=1 -DWITH_BOOST=<directory>
This CMake script will look for boost in <directory>. If it is not there,
it will download and unpack it (in that directory) for you.
If you are inside a firewall, you may need to use an http proxy:
export http_proxy=http://example.com:80
解决:缺少 -DWITH_BOOST= 参数 编译时添加-DWITH_BOOST=boost/boost_1_59_0/
4、发现报错,根据提示解决依赖性问题,需要安装:yum install -y gcc gcc-c++ ncurses-devel
5、再次重新编译:
- 重新编译时,需要清除原来的对象文件和缓存信息:
make clean;rm -fr CmakeCache.txt
6、发现有一个警告:
CMake Warning at cmake/bison.cmake:20 (MESSAGE):
Bison executable not found in PATH
Call Stack (most recent call first):
sql/CMakeLists.txt:549 (INCLUDE)
解决:yum install -y bison
,再次重新编译。
7、make && make install
过程时间较长,如果make还有问题,删除原来的目录,重新解压编译
8、复制启动脚本/root/mysql-5.7.17/support-files/mysql.server
到/etc/init.d/mysqld
,并给可执行权限chmod +x /etc/init.d/mysqld
9、将原来的/etc/my.cnf
备份,重新拷贝安装包里的到/etc
下
[root@server1 support-files