署环境centos7.2+mysql5.7.13
1、依赖包
注: 相关依赖包的作用
cmake:由于从 MySQL5.5 版本开始弃用了常规的 configure 编译方法,所以需要 CMake 编译
器,用于设置 mysql 的编译参数。如:安装目录、数据存放目录、字符编码、排序规则等。
Boost #从 MySQL 5.7.5 开始 Boost 库是必需的, mysql 源码中用到了 C++的 Boost 库,要求
必须安装 boost1.59.0 或以上版本
GCC 是 Linux 下的 C 语言编译工具, mysql 源码编译完全由 C 和 C++编写,要求必须安装
GCC
bison:Linux 下 C/C++语法分析器
ncurses:字符终端处理库
1)安装 CMAKE 及必要的软件
将软件放到/usr/local/src/
安装 cmake
tar xzf cmake-3.5.2.tar.gz
cd cmake-3.5.2
./bootstrap
gmake && gmake install
cmake –version ---查看 cmake 版本
安装 ncurses
tar xzf ncurses-5.9.tar.gz
cd ncurses-5.9
./configure && make && make install
安装bison
tar xzf bison-3.0.4.tar.gz
cd bison-3.0.4
./configure && make && make install
安装 bootst
tar zxf boost_1_59_0.tar.gz
mv boost_1_59_0 /usr/local/boost
2) 创建 mysql 用户和用户组及目录
groupadd -r mysql && useradd -r -g mysql -s /bin/false -M mysql
---新建 msyql 组和 msyql 用户禁止登录 shell
#mkdir /usr/local/mysql ---创建目录
#mkdir /usr/local/mysql/data ---数据库目录
2、编译安装mysql源码包
解压mysql源码包:
tar xzf mysql-5.7.13.tar.gz
cd mysql-5.7.13
执行cmake命令进行编译前的配置&编译:
make -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysqk/data/ -DSYSCONFDIR=/etc -DDEFAULT_CHARSET=utf8
-DDEFAULT_COLLATION=utf8_general_ci -DEXTRA_CHARSETS=all -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock -DWITH_HYISAM_STORAGE_ENGINE=1
-DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DWITH_SYSTEMD=1 -DWITH_BOOST=/usr/local/boost
make && make install
为了加快编译速度可以按下面的方式编译安装
make -j $(grep processor /proc/cpuinfo | wc -l) && make install
-j 参数表示根据 CPU 核数指定编译时的线程数,可以加快编译速度。默认为 1 个线程编译。
若要重新运行 cmake 配置,需要删除 CMakeCache.txt 文件
配置含义: -DCMAKE_INSTALL_PREFIX=/usr/local/mysql [MySQL 安 装 的 根 目录] -DMYSQL_DATADIR=/usr/local/mysql /data [MySQL 数据库文件存放目录] -DSYSCONFDIR=/etc [MySQL 配置文件所在目录] -DWITH_MYISAM_STORAGE_ENGINE=1 [添加 MYISAM 引擎支持 ] -DWITH_INNOBASE_STORAGE_ENGINE=1 [添加 InnoDB 引擎支持 ] -DWITH_ARCHIVE_STORAGE_ENGINE=1 [添加 ARCHIVE 引擎支持 ] -DMYSQL_UNIX_ADDR=/usr/local/mysql /mysql.sock [指定 mysql.sock 位置 ] -DWITH_PARTITION_STORAGE_ENGINE=1 [安装支持数据库分区 ] -DEXTRA_CHARSETS=all [使 MySQL 支持所有的扩展字符] -DDEFAULT_CHARSET=utf8 [设置 MySQL 的默认字符集为utf8]
-DDEFAULT_COLLATION=utf8_general_ci [设置默认字符集校对规则 ] -DWITH_SYSTEMD=1 [可以使用 systemd 控制 mysql 服务] -DWITH_BOOST=/usr/local/boost [指向 boost 库所在目录]
优化mysql执行路径
vi /etc/profile
export PATH=$PATH:/usr/local/mysql/bin
source /etc/profile
3、设置权限并初始化 MySQL 系统授权表
cd /usr/local/mysql
#chown -R mysql:mysql . ---更改所有者,属组,注意是 mysql .
#bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql
--datadir=/usr/local/mysql/data
#5.7.6 之后版本初始系统数据库脚本(本文使用此方式初始化)**
#/usr/local/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
5、创建配置文件
cd /usr/local/mysql/support-files ---进入 MySQL 安装目录支持文件目录
cp my-default.cnf /etc/my.cnf ---复制模板为新的配置文件
cd /usr/local/mysql-5.7.13/support-files/
cp my-default.cnf /etc/my.cnf
官网说:从5.7开始不在二进制包中提供my-default.cnf文件。
创建文件中配置选项,如下图所示,添加如下配置项
vim /etc/my.cnf
[mysql] basedir = /usr/local/mysql datadir = /usr/local/mysql/data port = 3306 server_id = 1 socket = /usr/local/mysql/mysql.sock log-error = /usr/local/mysql/data/mysqld.err
6、配置mysql自动启动
cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
修改/usr/lib/system/system/mysqld.service
systemctl daemon-reload
ss -npatl |grep 3306
mysql -u root -p /无密码
alter user root@localhost identified by 'abcD001!'; /密码要满足一定的复杂度,不然不能生效