CentOS6.8使用cmake安装MySQL5.7.18

所属分类: 数据库 / Mysql 阅读数: 844
收藏 0 赞 0 分享

参照网上资料在CentOS6.8服务器上使用cmake安装了MySQL5.7.18,安装过程中遇到了各种各样的问题,大多问题在网上都能找到解决方法,解决不了的问题我就卸了装、装了卸,最终装成功了,安装过程整理一下,存档备用。

安装MySQL相关依赖:

yum -y install gcc gcc-c++ gcc-g77 make cmake bison ncurses-devel autoconf automake zlib* fiex* libxml*  libmcrypt* libtool-ltdl-devel* libaio libaio-devel bzr libtool ncurses5-devel imake libxml2-devel expat-devel

安装boost_1_59_0(必须是该版本):

1、获取源码:假如下载到/usr/local/src目录下,则进入目录cd /usr/local/src,然后获取源码软件包

复制代码 代码如下:
wget https://sourceforge.net/projects/boost/files/boost/1.59.0/boost_1_59_0.tar.gz/download

2、解压:

tar -xzvf boost_1_59_0.tar.gz

3、进入boost目录:

cd boost_1_59_0

4、进行配置:

./bootstrap.sh

5、编译:

./b2

6、安装:

./b2 install

编译安装完成后,会把boost头文件拷贝到/usr/local/include/目录下,库文件在/usr/local/lib/下。

安装cmake(最新版本):

1、获取源码:依然下载到/usr/local/src目录下,cd /usr/local/src,获取软件包

wget https://cmake.org/files/v3.8/cmake-3.8.0.tar.gz

2、解压:

tar -xzvf cmake-3.8.0.tar.gz

3、进入cmake目录:

cd cmake-3.8.0

4、./bootstrap

5、gmake

6、gmake install 

安装mysql5.7.18:

1、添加mysql用户和所属组:

/usr/sbin/groupadd mysql
/usr/sbin/useradd -g mysql mysql

2、创建mysql安装目录和数据目录

mkdir /usr/local/mysql
mkdir /usr/local/mysql/data

3、修改mysql目录所有者

chown -R mysql:mysql /usr/local/mysql

4、获取mysql源码包:还在/usr/local/src目录下

wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.18.tar.gz

5、解压:

tar -xzvf mysql-5.7.18.tar.gz

6、进入mysql目录:

cd mysql-5.7.18

7、cmake编译配置:

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DMYSQL_DATADIR=/usr/local/mysql/mydata \
-DSYSCONFDIR=/etc \
-DEXTRA_CHARSETS=all \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DMYSQL_TCP_PORT=3306 \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DWITH_SSL=yes \
-DWITH_BOOST=/usr/local/src/boost_1_59_0 \
-DMYSQL_USER=mysql

8、编译安装:

make && make install

9、到mysql的安装目录bin下,初始化数据库

cd /usr/local/mysql/bin
./mysqld --initialize --user=mysql --datadir=/usr/local/mysql/data/ --basedir=/usr/local/mysql --socket=/usr/local/mysql/mysql.sock

运行后最后一句[note] 生成了一个mysql默认密码,复制到一个地方,保存下来。 

10、添加mysql服务,拷贝mysql配置文件
回到mysql安装目录 cd ..
进入support-files目录 cd support-files
复制启动文件 cp -a mysql.server /etc/init.d/mysql  //-a 可以把原来的属性一起复制过来

11、网上的资料显示还有my.cnf要编辑,但是我安装之后没有找到my.cnf文件。查了资料说是没有的话,运行系统默认配置,所以对my.cnf的配置这里就省略了。

12、启动mysql

service mysql start

13、设置开机自启

chkconfig mysql on

14、登录mysql

到mysql安装目录的bin下 cd bin

./mysql -uroot -p
Enter password:   //输入之前保存的默认密码

15、修改root密码

SET PASSWORD = PASSWORD('mysql123');

16、刷新mysql的系统权限相关表

flush privileges;

17、退出mysql:

quit;

至此,编译安装结束。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

mysql多表连接查询实例讲解

本篇文章中给大家通过实例代码讲述了mysql多表连接查询的方法,有需要的朋友们可以参考学习下。
收藏 0 赞 0 分享

MySQL设置global变量和session变量的两种方法详解

这篇文章主要介绍了MySQL设置global变量和session变量的两种方法,每种方法给大家介绍的非常详细 ,需要的朋友可以参考下
收藏 0 赞 0 分享

8种手动和自动备份MySQL数据库的方法

作为流行的开源数据库管理系统,MySQL的使用者众多,为了维护数据安全性,数据备份是必不可少的。本文就为大家介绍几种适用于企业的数据备份方法,需要的朋友可以参考下
收藏 0 赞 0 分享

使用JDBC连接Mysql数据库会出现的问题总结

这篇文章主要给大家介绍了关于使用JDBC连接Mysql数据库会出现的问题的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Ubuntu中MySQL的参数文件my.cnf示例详析

这篇文章主要给大家介绍了关于Ubuntu中MySQL的参数文件my.cnf的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

解决启动MongoDB错误:error while loading shared libraries: libstdc++.so.6:cannot open shared object file:

本文提供了解启动MongoDB时提示:error while loading shared libraries: libstdc++.so.6: cannot open shared object file: 错误的解决方案
收藏 0 赞 0 分享

PHP定时备份MySQL与mysqldump语法参数详解

本文为大家介绍了PHP利用mysqldump命令定时备份MySQL与mysqldump语法参数大全以及定时备份的PHP实例代码
收藏 0 赞 0 分享

定时备份 Mysql并上传到七牛的方法

常见的 MySQL 数据备份方式有,直接打包复制对应的数据库或表文件(物理备份)、mysqldump 全量逻辑备份、xtrabackup 增量逻辑备份等。这篇文章主要介绍了定时备份 MySQL 并上传到七牛 ,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL锁(表锁,行锁,共享锁,排它锁,间隙锁)使用详解

本文全面讲解了MySQL中锁包括表锁,行锁,共享锁,排它锁,间隙锁的详细使用方法
收藏 0 赞 0 分享

MySQL中的排序函数field()实例详解

这篇文章主要给大家介绍了关于MySQL中排序函数field()的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享
查看更多