在CentOS 7上源码编译安装MySQL 5.7

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

1.系统环境

1
[root@szlinux02 ~] # uname -r

3.10.0-514.el7.x86_64 

   

1
[root@szlinux02 ~] # cat /etc/redhat-release

CentOS Linux release 7.3.1611 (Core)     


1
[root@szlinux02 ~] # rpm -qa | grep mariadb

mariadb-libs-5.5.52-1.el7.x86_64    


1
2
3
[root@szlinux02 ~] # rpm -e --nodeps mariadb-libs    
[root@szlinux02 ~] #     
[root@szlinux02 ~] # yum install -y gcc gcc-c++ perl


2.安装依赖包


相关依赖包的作用

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-3.8.1.tar.gz 源码发布包   
http://www.cmake.org/download/     

1
wget https: //cmake .org /files/v3 .8 /cmake-3 .8.1. tar .gz


下载 ncurses-6.0.tar.gz   
ftp://ftp.gnu.org/gnu/ncurses/    

1
wget  ftp : //ftp .gnu.org /gnu/ncurses/ncurses-6 .0. tar .gz


下载 m4-1.4.18.tar.gz   

1
wget http: //mirrors .kernel.org /gnu/m4/m4-1 .4.18. tar .gz


下载 bison-3.0.4.tar.gz    
http://ftp.gnu.org/gnu/bison/    

1
wget http: //ftp .gnu.org /gnu/bison/bison-3 .0.4. tar .gz


下载 mysql-5.7.18.tar.gz   

1
wget https: //dev .mysql.com /get/Downloads/MySQL-5 .7 /mysql-5 .7.18. tar .gz


下载 Boost_1_59_0.tar.gz   

1
wget https: //ncu .dl.sourceforge.net /project/boost/boost/1 .59.0 /boost_1_59_0 . tar .gz



2)安装 CMAKE 及必要的软件


安装 cmake

1
2
3
4
5
6
[root@szlinux02 ~] # tar zxvf cmake-3.8.1.tar.gz   
[root@szlinux02 ~] # cd cmake-3.8.1    
[root@szlinux02 cmake-3.8.1] # ./bootstrap    
[root@szlinux02 cmake-3.8.1] # gmake && gmake install    
[root@szlinux02 cmake-3.8.1] # cmake -version    
[root@szlinux02 cmake-3.8.1] # cd ~


安装m4

1
2
3
4
5
[root@szlinux02 ~] # tar zxvf m4-1.4.18.tar.gz   
[root@szlinux02 ~] # cd m4-1.4.18    
[root@szlinux02 m4-1.4.18] # ./configure    
[root@szlinux02 m4-1.4.18] # make && make install    
[root@szlinux02 m4-1.4.18] # cd ~


安装 bison(注:需要perl和m4支持)

1
2
3
4
5
[root@szlinux02 ~] # tar zxvf bison-3.0.4.tar.gz   
[root@szlinux02 ~] # cd bison-3.0.4    
[root@szlinux02 bison-3.0.4] # ./configure    
[root@szlinux02 bison-3.0.4] # make && make install    
[root@szlinux02 bison-3.0.4] # cd ~


安装 ncurses

1
2
3
4
5
[root@szlinux02 ~] # tar zxvf ncurses-6.0.tar.gz   
[root@szlinux02 ~] # cd ncurses-6.0    
[root@szlinux02 ncurses-6.0] # ./configure    
[root@szlinux02 ncurses-6.0] # make && make install    
[root@szlinux02 ncurses-6.0] # cd ~


安装 boost(注:MySQL 5.7.18需要的boost正确版本为boost_1_59_0)

1
2
[root@szlinux02 ~] # tar zxvf boost_1_59_0.tar.gz   
[root@szlinux02 ~] # mv boost_1_59_0 /usr/local/boost


3.创建mysql用户、用户组及目录

1
2
3
[root@szlinux02 ~] # groupadd -r mysql && useradd -r -g mysql -s /bin/false -M mysql   
[root@szlinux02 ~] # mkdir /usr/local/mysql    
[root@szlinux02 ~] # mkdir -p /data/mysql


4.预编译

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
[root@szlinux02 ~] # tar zxvf mysql-5.7.18.tar.gz    
[root@szlinux02 ~] # cd mysql-5.7.18    
[root@szlinux02 mysql-5.7.18] #cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \    
-DMYSQL_DATADIR= /data/mysql  \    
-DWITH_BOOST= /usr/local/boost  \    
-DSYSCONFDIR= /etc  \    
-DWITH_INNOBASE_STORAGE_ENGINE=1 \    
-DWITH_PARTITION_STORAGE_ENGINE=1 \    
-DWITH_FEDERATED_STORAGE_ENGINE=1 \    
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \    
-DWITH_MYISAM_STORAGE_ENGINE=1 \    
-DENABLED_LOCAL_INFILE=1 \    
-DENABLE_DTRACE=0 \    
-DDEFAULT_CHARSET=utf8mb4 \    
-DDEFAULT_COLLATION=utf8mb4_general_ci \    
-DWITH_EMBEDDED_SERVER=OFF


5.编译安装

1
2
[root@szlinux02 mysql-5.7.18] # make -j `grep processor /proc/cpuinfo | wc -l`   
[root@szlinux02 mysql-5.7.18] # make install

-j 参数表示根据 CPU 核数指定编译时的线程数,可以加快编译速度。默认为 1 个线程编译。


6.设置权限并初始化 MySQL 系统授权表

1
2
3
4
5
6
[root@szlinux02 mysql-5.7.18] # cd /usr/local/mysql   
[root@szlinux02 mysql] # chown -R mysql:mysql .    
[root@szlinux02 mysql] # mkdir temp    
[root@szlinux02 mysql] # chmod 777 ./temp    
[root@szlinux02 mysql] # cd /data/mysql    
[root@szlinux02 mysql] # chown -R mysql:mysql .


MySQL 5.7.6之前的版本执行这个脚本初始化系统数据库   

1
. /bin/mysql_install_db  --user=mysql --basedir= /usr/local/mysql  --datadir= /data/mysql


5.7.6之后版本初始系统数据库脚本   

1
2
[root@szlinux02 mysql] # cd /usr/local/mysql    
[root@szlinux02 mysql] # ./bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql


注意:   
MySQL之前版本mysql_install_db是在mysql_basedir/script下,MySQL 5.7直接放在了mysql_basedir/bin目录下。    
"--initialize"已废弃,生成一个随机密码(~/.mysql_secret)    
"--initialize-insecure"不会生成密码    
"--datadir"目录下不能有数据文件

1
[root@szlinux02 mysql] # ./bin/mysql_ssl_rsa_setup


7.创建配置文件

[root@szlinux02 mysql]# cat > /etc/my.cnf << EOF


[client]    
port=3306    
socket=/usr/local/mysql/mysql.sock    
[mysqld]    
character-set-server=utf8    
collation-server=utf8_general_ci

skip-external-locking   
skip-name-resolve

user=mysql   
port=3306    
basedir=/usr/local/mysql    
datadir=/data/mysql    
tmpdir=/usr/local/mysql/temp    
# server_id = .....    
socket=/usr/local/mysql/mysql.sock    
log-error=/usr/local/mysql/logs/mysql_error.log    
pid-file=/usr/local/mysql/mysql.pid    
open_files_limit=10240    
back_log=600    
max_connections=500    
max_connect_errors=6000    
wait_timeout=605800    
#open_tables=600    
#table_cache = 650    
#opened_tables = 630

max_allowed_packet=32M   
sort_buffer_size=4M    
join_buffer_size=4M    
thread_cache_size=300    
query_cache_type=1    
query_cache_size=256M    
query_cache_limit=2M    
query_cache_min_res_unit=16k

tmp_table_size=256M   
max_heap_table_size=256M

key_buffer_size=256M   
read_buffer_size=1M    
read_rnd_buffer_size=16M    
bulk_insert_buffer_size=64M

lower_case_table_names=1

default-storage-engine=INNODB

innodb_buffer_pool_size=2G   
innodb_log_buffer_size=32M    
innodb_log_file_size=128M    
innodb_flush_method=O_DIRECT    
#####################    
thread_concurrency=32    
long_query_time=2    
slow-query-log=on    
slow-query-log-file=/usr/local/mysql/logs/mysql-slow.log

[mysqldump]   
quick    
max_allowed_packet=32M

[mysqld_safe]   
log-error=/var/log/mysqld.log    
pid-file=/var/run/mysqld/mysqld.pid    
EOF


8.配置MySQL服务

1
2
3
[root@szlinux02 mysql] # cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld   
[root@szlinux02 mysql] # chkconfig --add mysqld    
[root@szlinux02 mysql] # chkconfig mysqld on


9.启动服务

1
2
[root@szlinux02 mysql] # service mysqld start   
[root@szlinux02 mysql] # netstat -anpt | grep mysqld


10. 配置MySQL环境变量   

1
[root@szlinux02 mysql] # echo -e '\n\nexport PATH=/usr/local/mysql/bin:$PATH\n' >> /etc/profile && source /etc/profile


11.设置数据库root用户密码

1
[root@szlinux02 mysql] # ./bin/mysql_secure_installation


12.创建其他MySQL数据库用户

1
2
3
4
5
[root@szlinux02 mysql] # mysql -uroot -p   
mysql> CREATE DATABASE `testdb` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;    
mysql> grant all privileges on testdb.* to  'ryanxu' @ '%'  identified by  'ABCabc123!@#' ;    
mysql> flush privileges;    
myqsl>  exit

 

 

错误汇总:

1.如果中途编译失败了,需要删除cmake生成的预编译配置参数的缓存文件和make编译后生成的文件,再重新编译。  

1
2
[root@szlinux02 mysql-5.7.18] # make clean    
[root@szlinux02 mysql-5.7.18] # rm -f CMakeCache.txt


2.如果报错

    make[2]: *** [libmysqld/examples/mysql_client_test_embedded] 错误 1   
    make[1]: *** [libmysqld/examples/CMakeFiles/mysql_client_test_embedded.dir/all] 错误 2

加上

    -DWITH_EMBEDDED_SERVER=OFF


















本文转自UltraSQL51CTO博客,原文链接:本文转自UltraSQL51CTO博客,原文链接: ,如需转载请自行联系原作者

 ,如需转载请自行联系原作者



相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
15天前
|
应用服务中间件 Linux 网络安全
CentOS 7.4源码编译nginx1.12 并且隐藏nginx的版本
CentOS 7.4源码编译nginx1.12 并且隐藏nginx的版本
14 0
|
1天前
|
Linux
centos 6.5安装yum
centos 6.5安装yum
7 0
|
1天前
|
运维 网络协议 Linux
【运维系列】Centos7安装并配置PXE服务
PXE是Intel开发的预启动执行环境,允许工作站通过网络从远程服务器启动操作系统。它依赖DHCP分配IP,DNS服务分配主机名,TFTP提供引导程序,HTTP/FTP/NFS提供安装源。要部署PXE服务器,需关闭selinux和防火墙,安装dhcpd、httpd、tftp、xinetd及相关服务,配置引导文件和Centos7安装源。最后,通过syslinux安装引导文件,并创建pxelinux.cfg/default配置文件来定义启动参数。
5 0
|
1天前
|
运维 网络协议 Linux
【运维系列】Centos7安装并配置postfix服务
安装CentOS7的Postfix和Dovecot,配置Postfix的`main.cf`文件,包括修改完全域名、允许所有IP、启用邮箱等。然后,配置Dovecot的多个配置文件以启用auth服务和调整相关设置。重启Postfix和Dovecot,设置开机自启,并关闭防火墙进行测试。最后,创建邮箱账户并在Windows邮箱客户端中添加账户设置。
8 0
|
1天前
|
Linux 网络安全
Centos6.5安装并配置NFS服务
该内容描述了在Linux系统中设置NFS服务的步骤。首先挂载yum源,然后安装NFS服务,并编辑配置文件。接着,重启rpcbind和NFS服务,可能需要重复此过程以解决初始可能出现的问题。此外,关闭防火墙策略,并再次重启服务。最终,根目录被共享,特定IP网段被允许访问。
6 0
|
2天前
|
存储 Linux 网络安全
centos7使用yum网络安装
这些是使用Yum进行网络安装的基本步骤。根据你的需求,你可以重复步骤3和4来安装其他软件包。请注意,执行Yum操作需要root或具有sudo权限的用户。
14 1
|
6天前
|
Java 关系型数据库 MySQL
一套java+ spring boot与vue+ mysql技术开发的UWB高精度工厂人员定位全套系统源码有应用案例
UWB (ULTRA WIDE BAND, UWB) 技术是一种无线载波通讯技术,它不采用正弦载波,而是利用纳秒级的非正弦波窄脉冲传输数据,因此其所占的频谱范围很宽。一套UWB精确定位系统,最高定位精度可达10cm,具有高精度,高动态,高容量,低功耗的应用。
一套java+ spring boot与vue+ mysql技术开发的UWB高精度工厂人员定位全套系统源码有应用案例
|
8天前
|
关系型数据库 MySQL Linux
centos7安装mysql-带网盘安装包
centos7安装mysql-带网盘安装包
52 2
|
14天前
|
监控 数据可视化 安全
智慧工地SaaS可视化平台源码,PC端+APP端,支持二开,项目使用,微服务+Java++vue+mysql
环境实时数据、动态监测报警,实时监控施工环境状态,有针对性地预防施工过程中的环境污染问题,打造文明生态施工,创造绿色的生态环境。
12 0
智慧工地SaaS可视化平台源码,PC端+APP端,支持二开,项目使用,微服务+Java++vue+mysql
|
14天前
|
监控 安全 关系型数据库
基于vue2 + element +mysql医院不良事件上报系统源码
不良事件管理系统从时间上报、PDCA分析、事件整改、评估效果实行闭环管理和分析,满足医院追根溯源,全流程闭环管理,提高不良事件上报率,减少同类不良事件发生,提高医疗安全。通过报告不良事件,及时发现潜在的不安全因素
19 1