对于5.7以后的mysql编译安装,我遇到了不少坑,各种问题。mysql5.7.18编译openssl会出错,环境也神奇地报其他问题,即使我安装成功了,却无法以安装模式登陆mysql修改密码。
最后使用前几个版本就解决问题了。我使用的是5.7.16.
#系统安装条件
1> cmake
MySQL使用cmake跨平台工具预编译源码,用于设置mysql的编译参数。如:安装目录、数据存放目录、字符编码、排序规则等。安装最新版本即可。
2> make3.75
mysql源代码是由C和C++语言编写,在Linux下使用make对源码进行编译和构建,要求必须安装make 3.75或以上版本
3> gcc4.4.6
GCC是linux下的C语言编译工具,mysql源码编译完全由C和C++编写,要求必须安装GCC4.4.6或以上版本
4> Boost1.59.0
mysql源码中用到了C++的Boost库,要求必须安装boost1.59.0或以上版本
5> bison2.1
Linux下C/C++语法分析器
6> ncurses
字符终端处理库
官网的温馨提示:足够的可用内存 如果在编译大型源文件时遇到诸如“ 内部编译器错误 ”等问题 ,可能是内存太少。如果在虚拟机上编译,请尝试增加内存分配。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
yum erase cmake
wget -c https: //cmake .org /files/v3 .7 /cmake-3 .7.2. tar .gz
tar zxvf cmake-3.7.2. tar .gz -C /usr/local/src
wget -c
mkdir -p /usr/local/boost
cp boost_1_59_0. tar .gz /usr/local/boost
wget -c
tar -zxf mysql-5.7.16. tar .gz -C /usr/local/src
yum install -y apr* autoconf automake bison bzip2 bzip2 * cloog-ppl cpp curl curl-devel fontconfig fontconfig-devel freetype freetype* freetype-devel gcc gcc-c++ gtk+-devel gd gettext gettext-devel glibc kernel kernel-headers keyutils keyutils-libs-devel krb5-devel libcom_err-devel libpng libpng-devel libjpeg* libsepol-devel libselinux-devel libstdc++-devel libtool* libgomp libxml2 libxml2-devel libXpm* libxml*?libXaw-devel libXmu-devel libtiff libtiff* make mpfr ncurses* ntp openssl openssl-devel patch pcre-devel perl php-common php-gd policycoreutils telnet t1lib t1lib* nasm nasm* wget zlib-devel
|
1
2
3
4
5
6
7
|
cd /usr/local/src/cmake-3 .7.2
. /configure
make
make install
ln -sf /usr/local/bin/cmake /usr/bin/cmake
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
groupadd mysql
useradd -g mysql mysql -s /bin/false
mkdir -p /data/mysql
chown -R mysql:mysql /data/mysql
mkdir -p /usr/local/mysql
cd /usr/local/src/mysql-5 .7.18
mkdir bld
cd bld
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
make -j ` grep processor /proc/cpuinfo | wc -l`
make install
|
1
2
3
4
|
cd /usr/local/mysql
. /bin/mysqld --user=mysql --initialize --basedir= /usr/local/mysql --datadir= /data/mysql
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
cp /usr/local/mysql/support-files/my-default .cnf /usr/local/mysql/my .cnf
ln -s /usr/local/mysql/my .cnf /etc/my .cnf
cp /usr/local/mysql/support-files/mysql .server /etc/rc .d /init .d /mysqld
chmod 755 /etc/init .d /mysqld
chkconfig mysqld on
vi /etc/rc .d /init .d /mysqld
basedir= /usr/local/mysql
datadir= /data/mysql
:wq!
service mysqld start
vi /etc/profile
export PATH=$PATH: /usr/local/mysql/bin
:wq!
source /etc/profile
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
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
Press y|Y for Yes, any other key for No: 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
UNINSTALL PLUGIN validate_password ;
use mysql;
update mysql.user set authentication_string=password( '123456' ) where user= 'root' ;
ALTER USER 'root' @ 'localhost' IDENTIFIED WITH mysql_native_password AS '123456' ;
|
1
2
3
4
5
|
mysql -uroot -proot
GRANT ALL PRIVILEGES ON *.* TO 'root' @ '%' IDENTIFIED BY 'root' WITH GRANT OPTION;
FLUSH PRIVILEGES;
|
附官网编译安装mysql步骤
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
shell> groupadd mysql
shell> useradd -r -g mysql -s /bin/false mysql
shell> tar zxvf mysql-VERSION. tar .gz
shell> cd mysql-VERSION
shell> mkdir bld
shell> cd bld
shell> cmake ..
shell> make
shell> make install
shell> cd /usr/local/mysql
shell> chown -R mysql .
shell> chgrp -R mysql .
shell> bin /mysql_install_db --user=mysql
shell> bin /mysqld --initialize --user=mysql
shell> bin /mysql_ssl_rsa_setup
shell> chown -R root .
shell> chown -R mysql data
shell> bin /mysqld_safe --user=mysql &
shell> cp support-files /mysql .server /etc/init .d /mysql .server
|
附网上的参数配置参考,但是我使用网友这个编译安装是不成功的。这里只是为了参考他备注的参数,备注参数感觉还是可以的。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
cmake \
-DWITH_BOOST= /usr/local/boost_1_59_0 \ [boost目录]
-DCMAKE_INSTALL_PREFIX= /usr/local/mysql \ [MySQL安装的根目录]
-DMYSQL_DATADIR= /mydata/mysql/data \ [MySQL数据库文件存放目录]
-DSYSCONFDIR= /etc \ [MySQL配置文件所在目录]
-DMYSQL_USER=mysql \ [MySQL用户名]
-DWITH_MYISAM_STORAGE_ENGINE=1 \ [MySQL的数据库引擎]
-DWITH_INNOBASE_STORAGE_ENGINE=1 \ [MySQL的数据库引擎]
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \ [MySQL的数据库引擎]
-DWITH_MEMORY_STORAGE_ENGINE=1 \ [MySQL的数据库引擎]
-DWITH_READLINE=1 \ [MySQL的readline library]
-DMYSQL_UNIX_ADDR= /var/run/mysql/mysql .sock \ [MySQL的通讯目录]
-DMYSQL_TCP_PORT=3306 \ [MySQL的监听端口]
-DENABLED_LOCAL_INFILE=1 \ [启用加载本地数据]
-DENABLE_DOWNLOADS=1 \ [编译时允许自主下载相关文件]
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DEXTRA_CHARSETS=all \ [使MySQL支持所有的扩展字符]
-DDEFAULT_CHARSET=utf8 \ [设置默认字符集为utf8]
-DDEFAULT_COLLATION=utf8_general_ci \ [设置默认字符校对]
-DWITH_DEBUG=0 \ [禁用调试模式]
-DMYSQL_MAINTAINER_MODE=0 \
-DWITH_SSL:STRING=bundled \ [通讯时支持ssl协议]
-DWITH_ZLIB:STRING=bundled [允许使用zlib library]
|
#
文档参考:https://dev.mysql.com/doc/refman/5.7/en/source-installation.html
支持平台 https://www.mysql.com/support/supportedplatforms/database.html
本文转自 yanconggod 51CTO博客,原文链接:http://blog.51cto.com/yanconggod/1945644