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