mysql5.7 cmake源码编译安装

本文介绍如何从源码编译安装MySQL 5.7版本,并详细记录了解决过程中遇到的问题及解决方案,包括cmake配置参数详解、boost库安装及链接问题等。

mysql5.7 cmake源码编译安装,
-----该文章的知识点是一个大牛总结的,我这里只是加工了一下,非原创文章。

搜狐开源镜像站:http://mirrors.sohu.com/
网易开源镜像站:http://mirrors.163.com/
开源中国:http://mirrors.oschina.net/
首都在线科技股份有限公司:http://mirrors.yun-idc.com/
阿里云开源镜像:http://mirrors.aliyun.com/
LUPA:http://mirror.lupaworld.com/
常州贝特康姆软件技术有限公司(原cn99):http://centos.bitcomm.cn/

一、安装MySQL

1、安装cmake

cd /usr/local/src

tar zxvf cmake-3.7.2.tar.gz

cd cmake-3.7.2

./configure

make

make install

2、安装MySQL

cd /usr/local/src

mkdir -p /usr/local/boost

cp boost_1_59_0.tar.gz /usr/local/boost
#cmake的时候去这个路径解压该boost_1_59_0.tar.gz包(为什么这么做,是因为曾经这里遇到过一个问题:
在网上看到有文章写到,源码安装mysql时候,需要先安装boost库,于是执行了下面的命令
一、安装boost库
1 tar xvf boost_1_59_0
2 cd boost_1_59_0
3 ./bootstrap.sh --with-libraries=system,filesystem,log,thread --with-toolset=gcc
4 ./b2 toolset=gcc cxxflags="-std=c++11"
5 ./b2 install --prefix=/usr/local/boost

二、cmake mysql5.7
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_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.sock -DMYSQL_TCP_PORT=3306 -DENABLED_LOCAL_INFILE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local//boost/

报错:
Call Stack (most recent call first):
cmake/boost.cmake:167 (COULD_NOT_FIND_BOOST)
CMakeLists.txt:451 (INCLUDE)

参数:DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local//boost/ # 这2个参数意思是cmake的时候去/usr/local//boost找 boost,如果没有就去下载,但是之前通过安装boost库,无论如何cmake都找不到boost文件,后来问了几个大牛,说上面不用安装boost库,直接把boost库的tar.gz包拷贝到/usr/local//boost/下即可;我个人猜测可能跟编译php的时候一个道理,例如,我们编译php扩展库-with-gd with-png-dir=/usr/local/libpng,编译gd的时候,gd也要去找libpng,libpng有系统lib库的默认位置,这里php编译去/usr/local/libpng了,gd却去系统默认位置找了,导致gd编译失败,从而导致这里php编译png成功了,php编译gd的时候失败,因为gd去默认位置找了,----这里不是本章重点,可以忽略,大概解决办法就是去makefile文件里找到对应的变量修改成对应的路径,再重新编译配置,未测试过,仅做参考。

啰嗦完了,下面继续正常安装流程:
groupadd mysql #添加mysql组

useradd -g mysql mysql -s /bin/false #创建用户mysql并加入到mysql组,不允许mysql用户直接登录系统

mkdir -p /data/mysql #创建MySQL数据库存放目录

chown -R mysql:mysql /data/mysql #设置MySQL数据库存放目录权限

mkdir -p /usr/local/mysql #创建MySQL安装目录

cd /usr/local/src #进入软件包存放目录

tar zxvf mysql-5.7.16.tar.gz #解压

cd mysql-5.7.16 #进入目录

cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/data/mysql -DWITH_INNOBASE_STORAGE_ENGINE=1 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EMBEDDED_SERVER=OFF -DWITH_BOOST=/usr/local/boost

注意:可以使用-DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local/boost参数在线安装boost软件包,需要服务器联网,容易下载失败。

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_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.sock -DMYSQL_TCP_PORT=3306 -DENABLED_LOCAL_INFILE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local//boost/

make #编译

make install #安装

编译出错, 重新编译前要删除编译失败的文件,重新编译时,需要清除旧的对象文件和缓存信息。

make clean

rm -f CMakeCache.txt

rm -rf /etc/my.cnf #删除系统默认的配置文件(如果默认没有就不用删除)

cd /usr/local/mysql #进入MySQL安装目录

./bin/mysqld --user=mysql --initialize --basedir=/usr/local/mysql --datadir=/data/mysql #生成mysql系统数据库

--initialize表示默认生成密码, --initialize-insecure 表示不生成密码, 密码为空。

看到这一行[Note] A temporary password is generated for root@localhost: i>X18*=Rav=7

cp /usr/local/mysql/support-files/my-default.cnf /usr/local/mysql/my.cnf

ln -s /usr/local/mysql/my.cnf /etc/my.cnf #添加到/etc目录的软连接

cp /usr/local/mysql/support-files/mysql.server /etc/rc.d/init.d/mysqld #把Mysql加入系统启动

chmod 755 /etc/init.d/mysqld #增加执行权限

chkconfig mysqld on #加入开机启动

vi /etc/rc.d/init.d/mysqld #编辑

basedir=/usr/local/mysql #MySQL程序安装路径

datadir=/data/mysql #MySQl数据库存放目录

:wq! #保存退出

service mysqld start #启动

vi /etc/profile #把mysql服务加入系统环境变量:在最后添加下面这一行

export PATH=$PATH:/usr/local/mysql/bin

:wq! #保存退出

source /etc/profile #使配置立刻生效

下面这两行把myslq的库文件链接到系统默认的位置,这样你在编译类似PHP等软件时可以不用指定mysql的库文件地址。

ln -s /usr/local/mysql/lib/mysql /usr/lib/mysql

ln -s /usr/local/mysql/include/mysql /usr/include/mysql

mkdir /var/lib/mysql #创建目录

ln -s /tmp/mysql.sock /var/lib/mysql/mysql.sock #添加软链接

mysql_secure_installation #修改Mysql密码,输入之前生成的密CSJlm3DyTG.d回车,根据提示操作。

Press y|Y for Yes, any other key for No: y #是否安装密码安全插件?选择y

There are three levels of password validation policy: #有以下几种密码强度选择

LOW Length >= 8

MEDIUM Length >= 8, numeric, mixed case, and special characters

STRONG Length >= 8, numeric, mixed case, special characters and dictionary file

Please enter 0 = LOW, 1 = MEDIUM and 2 = STRONG: 0 #选择0,只要8位数字即可,选1要有大写,小写,特殊字符等

UNINSTALL PLUGIN validate_password ; #卸载密码强度插件

mysqladmin -uroot -p password 123456 #修改密码
show variables like "%pass%";
set global validate_password_length=4; #修改密码规则
set global validate_password_policy=0;
set password = password('1234');

'''
ps -ef |grep mysql
/bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/data/mysql --pid-file=/data/mysql/iZ230hvszdwZ.pid
/usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysql --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/data/mysql/iZ230hvszdwZ.err --pid-file=/data/mysql/iZ230hvszdwZ.pid

root密码忘记了,数据库进不去了,怎么改密码呢:

/etc/init.d/mysqld stop
用这种方式启动mysql
mysqld_safe --skip-grant-tables --skip-networking &
mysql -uroot -p #进入mysql
执行该命令修改密码
update mysql.user set authentication_string=password('123456') where user='root' and Host = 'localhost';
退出,kill -9 mysql的进程
正常启动mysql:
/etc/init.d/mysqld start

转载于:https://blog.51cto.com/bajiebushizhu/2074036

### 准备工作 在开始源码编译安装 MySQL 5.7 之前,需要确保系统中已经安装了必要的开发工具和库文件。首先,安装编译所需的依赖包: ```bash yum install -y gcc gcc-c++ make tar openssl openssl-devel cmake ncurses ncurses-devel libarchive ``` 此外,为了能够顺利进行编译过程,还需要创建一个专门用于运行 MySQL 服务的用户,这可以通过以下命令实现: ```bash useradd -s /sbin/nologin mysql ``` ### 下载并解压 MySQL 源码包 接下来,从官方站点下载 MySQL 5.7源码包,并将其解压到合适的目录下: ```bash wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.41.tar.gz tar -zxvf mysql-5.7.41.tar.gz cd mysql-5.7.41 ``` ### 编译配置 使用 `cmake` 工具对 MySQL 进行编译配置,指定安装路径、数据存储目录、字符集等选项: ```bash cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_DATADIR=/data/mysql \ -DDEFAULT_CHARSET=utf8 \ -DDEFAULT_COLLATION=utf8_general_ci \ -DWITH_EXTRA_CHARSETS:STRING=all \ -DWITH_DEBUG=0 \ -DWITH_SSL=yes \ -DWITH_READLINE=1 \ -ENABLED_LOCAL_INFILE=1 \ -DWITH_BOOST:PATH=/usr/include/boost/ ``` ### 编译安装 一旦配置完成,就可以开始编译 MySQL 源代码了。这个过程可能需要一些时间,具体取决于系统的性能: ```bash make ``` 编译完成后,将编译好的文件安装到之前指定的目标位置: ```bash make install ``` ### 配置 MySQL #### 配置用户权限 确保 MySQL 用户拥有对其数据目录的读写权限: ```bash chown -R mysql:mysql /usr/local/mysql ``` #### 初始化数据库 进入 MySQL 安装目录下的 bin 目录,执行初始化脚本以创建初始数据库结构: ```bash cd /usr/local/mysql/bin/ ./mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data ``` #### 配置为系统服务 为了让 MySQL 能够作为系统服务运行,需要复制启动脚本到 `/etc/init.d/` 目录,并设置开机启动: ```bash cp support-files/mysql.server /etc/init.d/mysqld chkconfig --add mysqld chkconfig mysqld on ``` #### 配置环境变量 为了让 `mysql` 命令能够在任何位置被识别,需要更新系统的 PATH 环境变量: ```bash echo "PATH=\$PATH:/usr/local/mysql/bin" >> /etc/profile source /etc/profile ``` ### 启动 MySQL 服务 现在可以启动 MySQL 服务了: ```bash service mysqld start ``` 如果一切正常,MySQL 服务应该已经成功启动。可以通过连接到 MySQL 服务器来验证安装是否成功: ```bash mysql -u root -p ``` 首次登录时,由于使用了 `--initialize-insecure` 参数,所以不需要输入密码。登录后,建议立即更改 root 用户的密码以增强安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值