centos7.x编译安装mysql5.7.16

对于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

字符终端处理库


官网的温馨提示:足够的可用内存 如果在编译大型源文件时遇到诸如“ 内部编译器错误 ”等问题 ,可能是内存太少。如果在虚拟机上编译,请尝试增加内存分配。

#其实这个cmake可以不用升级的。。官网说的是make···又多干活了,多折腾了
yumerasecmake

#下载cmake
wget-chttps://cmake.org/files/v3.7/cmake-3.7.2.tar.gz
tarzxvfcmake-3.7.2.tar.gz-C/usr/local/src

#下载boost
wget-c
mkdir-p/usr/local/boost
cpboost_1_59_0.tar.gz/usr/local/boost

#下载mysql5.7.16
wget-c
tar-zxfmysql-5.7.16.tar.gz-C/usr/local/src

yuminstall-yapr*autoconfautomakebisonbzip2bzip2*cloog-pplcppcurlcurl-develfontconfigfontconfig-develfreetypefreetype*freetype-develgccgcc-c++gtk+-develgdgettextgettext-develglibckernelkernel-headerskeyutilskeyutils-libs-develkrb5-devellibcom_err-devellibpnglibpng-devellibjpeg*libsepol-devellibselinux-devellibstdc++-devellibtool*libgomplibxml2libxml2-devellibXpm*libxml*?libXaw-devellibXmu-devellibtifflibtiff*makempfrncurses*ntpopensslopenssl-develpatchpcre-develperlphp-commonphp-gdpolicycoreutilstelnett1libt1lib*nasmnasm*wgetzlib-devel
#编译安装cmkae

cd/usr/local/src/cmake-3.7.2
./configure
make
makeinstall
ln-sf/usr/local/bin/cmake/usr/bin/cmake
#安装mysql数据库
#添加mysql组
groupaddmysql
#创建用户mysql并加入到mysql组,不允许mysql用户直接登录系统
useradd-gmysqlmysql-s/bin/false
#创建MySQL数据库存放目录
mkdir-p/data/mysql
#设置MySQL数据库存放目录权限
chown-Rmysql:mysql/data/mysql
#创建MySQL安装目录
mkdir-p/usr/local/mysql
cd/usr/local/src/mysql-5.7.18
mkdirbld
cdbld
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`grepprocessor/proc/cpuinfo|wc-l`
makeinstall

#安装成功

#如果编译出错,重新编译前要删除编译失败的文件,重新编译时,需要清除旧的对象文件和缓存信息。
#makeclean
#rm-fCMakeCache.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表示不生成密码,密码为空。
##2017-07-05T02:52:50.934379Z1[Note]Atemporarypasswordisgeneratedforroot@localhost:x5fujvwK25:y
#设置开机启动
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加入系统启动
chmod755/etc/init.d/mysqld#增加执行权限
chkconfigmysqldon#加入开机启动
vi/etc/rc.d/init.d/mysqld#编辑
basedir=/usr/local/mysql#MySQL程序安装路径
datadir=/data/mysql#MySQl数据库存放目录
:wq!#保存退出
servicemysqldstart#启动
vi/etc/profile#把mysql服务加入系统环境变量:在最后添加下面这一行
exportPATH=$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密码,输入之前生成的密码回车,根据提示操作。
Pressy|YforYes,anyotherkeyforNo:y#是否安装密码安全插件?选择y
Therearethreelevelsofpasswordvalidationpolicy:#有以下几种密码强度选择
LOWLength>=8
MEDIUMLength>=8,numeric,mixedcase,andspecialcharacters
STRONGLength>=8,specialcharactersanddictionaryfile
Pleaseenter0=LOW,1=MEDIUMand2=STRONG:0#选择0,只要8位数字即可,选1要有大写,小写,特殊字符等
UNINSTALLPLUGINvalidate_password;#卸载密码强度插件
usemysql;
updatemysql.usersetauthentication_string=password('123456')whereuser='root';#登录mysql控制台修改
ALTERUSER'root'@'localhost'IDENTIFIEDWITHmysql_native_passwordAS'123456';#修改密码
#上面登陆mysql控制台和修改密码太过麻烦了,使用下面一条命令即可
#授权root远程访问,密码为root
mysql-uroot-proot
GRANTALLPRIVILEGESON*.*TO'root'@'%'IDENTIFIEDBY'root'WITHGRANTOPTION;
FLUSHPRIVILEGES;



附官网编译安装mysql步骤

#Preconfigurationsetup
shell>groupaddmysql
shell>useradd-r-gmysql-s/bin/falsemysql
#Beginningofsource-buildspecificinstructions
shell>tarzxvfmysql-VERSION.tar.gz
shell>cdmysql-VERSION
shell>mkdirbld
shell>cdbld
shell>cmake..
shell>make
shell>makeinstall
#Endofsource-buildspecificinstructions
#Postinstallationsetup
shell>cd/usr/local/mysql
shell>chown-Rmysql.
shell>chgrp-Rmysql.
shell>bin/mysql_install_db--user=mysql#BeforeMySQL5.7.6
shell>bin/mysqld--initialize--user=mysql#MySQL5.7.6andup
shell>bin/mysql_ssl_rsa_setup#MySQL5.7.6andup
shell>chown-Rroot.
shell>chown-Rmysqldata
shell>bin/mysqld_safe--user=mysql&
#Nextcommandisoptional
shell>cpsupport-files/mysql.server/etc/init.d/mysql.server


附网上的参数配置参考,但是我使用网友这个编译安装是不成功的。这里只是为了参考他备注的参数,备注参数感觉还是可以的。

#
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的readlinelibrary]
-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[允许使用zliblibrary]



#

文档参考:https://dev.mysql.com/doc/refman/5.7/en/source-installation.html

支持平台 https://www.mysql.com/support/supportedplatforms/database.html

相关文章

linux下开机自启: 在/etc/init.d目录下新建文件elasticsear...
1、因为在centos7中/etc/rc.d/rc.local的权限被降低了,所以...
最简单的查看方法可以使用ls -ll、ls-lh命令进行查看,当使用...
ASP.NET Core应用程序发布linux在shell中运行是正常的。可一...
设置时区(CentOS 7) 先执行命令timedatectl status|grep &...
vim /etc/sysconfig/network-scripts/ifcfg-eth0 B...