部署环境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 及必要的软件 —————————————————————————————— 安装 cmake cmake –version ---查看 cmake 版本 安装 ncurses 安装 bison 安装 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源码包: 执行cmake命令进行编译前的配置&编译: 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 的执行路径

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 ---复制模板为新的配置文件, 官网说:从5.7开始不在二进制包中提供my-default.cnf文件。 创建文件中配置选项,如下图所示,添加如下配置项 vim /etc/my.cnf

[mysqld]

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!'; /密码要满足一定的复杂度,不然不能生效