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

centos7.x编译安装mysql5.7.16的更多相关文章

  1. .dylib在Debug中链接,在XCode中找不到适用于iPhone的版本

    所以我已经将libxml2.2.dylib库包含在我的iPhoneXCode项目中,以创建一些Xml和XPath解析实用程序.当我编译并运行在模拟器和设备的调试模式时,我没有问题,但是,当我切换到发布模式我得到…

  2. 在编译的iOS应用程序(IPA)中加密内容

    由于IPA结构只是一个压缩文件,包含编译代码媒体内容,如图像&音频,我如何保护内容免受别人的窃取?是否有加密可以添加到IPA?

  3. 从iOS应用程序发送帖子到PHP脚本不工作…简单的解决方案就像

    我之前已经做了好几次了但是由于某些原因我无法通过这个帖子…我尝试了设置为_POST且没有的变量的PHP脚本……当它们未设置为发布时它工作精细.这是我的iOS代码:这里是PHP的一大块,POST变量不在正确的位置?我想这对于更有经验的开发人员来说是一个相当简单的答案,感谢您的帮助!解决方法$_POST是一个数组,而不是一个函数.您需要使用方括号来访问数组索引:

  4. ios – Swift 4向后兼容性

    一起使用.有没有办法在两个版本的Xcode中使这个工作?Swift4是否应该向后兼容?

  5. Swift与OC混合编译

    SWift调用OC新建swift文件此时系统自动生成-Bridging-Header.h文件并且TARGETS->BuildSettings->Objective-CBridgingHeader(搜索bridg)选项中会自动填入以上头文件的路径在-Bridging-Header.h中#import要调用的OC对象头文件OC调用Swift在OC文件中#import“

  6. Swift教程01-使用switfc终端命令编译运行swift程序

    应公司的要求,要我研究swift语言,然后给大家进行swift技术培训,买了4,5本swift相关的书籍就开始研究了.今天来介绍一下,swift相关的终端的命令.1.首先我们在桌面上建一个swift文件夹用来存放.swift源文件,打开终端输入cd加空格拖拽文件夹到终端(使用命令ls,cd目录也是等效)3.使用vi命令创建一个HelloWorld.swift源文件进入swift文件夹后,然后使用如

  7. 驳狗屎文 "我为什么放弃Go语言"

    开门见山地说,我当初放弃Go语言,就是因为两个“不爽”:第一,对Go语言本身不爽;第二,对Go语言社区里的某些人不爽。两年之后,2011年底,Go语言发布1.0的计划被提上日程,相关的报道又多起来,我再次关注它,重新评估之后决定深入参与Go语言。外加Go语言社区里的某些人,其中也包括Google公司负责开发Go语言的某些人,其态度、言行,让我极度厌恶,促使我决绝地离弃Go语言。第1节:我为什么对Go语言不爽?

  8. Swift语法特点

    从它的语法中能看到Ojective-CJavaScriptC#Python等语言的影子swift借鉴了以上几门语言的特点我们可以从swift身上看到这几种语言的影子同时还具备了编译型语言额高能性和脚本语言的灵活交互性OC-C#都是编译型的语言也就是我们写完代码要保证每一行代码编译通过才能跑起来这叫编译型语言一般编译型的语言性能比较高能做的事情比较强大比如说OC能开发手机程序C#能开发服务器程序脚本

  9. Swift思量与初探:我需要学习Swift吗?

    最近,除了N多的基于Swift的服务端开发框架,笔者不由深思,到底该这么评价Swift呢?前两点在Swift的语法和语言特性中已经表现得淋漓尽致:像是尾随闭包,枚举关联值,可选值和强制的类型安全等都是Swift显而易见的优点。综上所述,Swift拥有着被广泛使用以及当做第一学习语言的潜质。Swift在语法层次上会更加高级,并且Swift并没有使用GC机制,因此可以与C更好地相兼容。Swift中的注释与C语言的注释非常相似。

  10. Swift 2 throws 全解析 - 从原理到实践

    Swift2错误处理简介throws关键字和异常处理机制是Swift2中新加入的重要特性。为了解决这个问题,Swift2中在编译器层级就对throws进行了限定。在Swift开源之前,将源码编译到各个阶段是探索Swift原理和实现方式的重要方式。事实上NSError在Swift2中也实现了ErrorType接口,它简单地返回错误的域和错误代码信息,这是Swift1到2的错误处理相关API转换的兼容性的保证。throws的一些实践异步操作中的异常处理带有throw的方法现在只能工作在同步API中,这受限于异

随机推荐

  1. 在airgapped(离线)CentOS 6系统上安装yum软件包

    我有一个CentOS6系统,出于安全考虑,它已经被空气泄漏.它可能从未连接到互联网,如果有,它很长时间没有更新.我想将所有.rpm软件包放在一个驱动器上,这样它们就可以脱机安装而无需查询互联网.但是,我在测试VM上遇到的问题是,即使指定了本地路径,yum仍然会挂起并尝试从在线存储库进行更新.另外,有没有办法使用yum-utils/yumdownloader轻松获取该包的所有依赖项和所有依赖项?目前

  2. centos – 命名在日志旋转后停止记录到rsyslog

    CentOS6.2,绑定9.7.3,rsyslog4.6.2我最近设置了一个服务器,我注意到在日志轮换后,named已停止记录到/var/log/messages.我认为这很奇怪,因为所有日志记录都是通过rsyslog进行的,并且named不会直接写入日志文件.这更奇怪,因为我在更新区域文件后命名了HUPed,但它仍然没有记录.在我停止并重新启动命名后,记录恢复.这里发生了什么?

  3. centos – 显示错误的磁盘大小

    对于其中一个磁盘,Df-h在我的服务器上显示错误的空白区域:Cpanel表明它只有34GB免费,但还有更多.几分钟前,我删除了超过80GB的日志文件.所以,我确信它完全错了.fdisk-l/dev/sda2也显示错误:如果没有格式化,我该怎么做才能解决这个问题?并且打开文件描述符就是它需要使用才能做到这一点.所以…使用“lsof”并查找已删除的文件.重新启动写入日志文件的服务,你很可能会看到空间可用.

  4. 如何在centos 6.9上安装docker-ce 17?

    我目前正在尝试在centOS6.9服务器上安装docker-ce17,但是,当运行yuminstalldocker-ce时,我收到以下错误:如果我用跳过的标志运行它我仍然得到相同的消息,有没有人知道这方面的方法?

  5. centos – 闲置工作站的异常负载平均值

    我有一个新的工作站,具有不寻常的高负载平均值.机器规格是:>至强cpu>256GB的RAM>4x512GBSSD连接到LSI2108RAID控制器我从livecd安装了CentOS6.564位,配置了分区,网络,用户/组,并安装了一些软件,如开发工具和MATLAB.在启动几分钟后,工作站负载平均值的值介于0.5到0.9之间.但它没有做任何事情.因此我无法理解为什么负载平均值如此之高.你能帮我诊断一下这个问题吗?

  6. centos – Cryptsetup luks – 检查内核是否支持aes-xts-plain64密码

    我在CentOS5上使用cryptsetupluks加密加密了一堆硬盘.一切都很好,直到我将系统升级到CentOS6.现在我再也无法安装磁盘了.使用我的关键短语装载:我收到此错误:在/var/log/messages中:有关如何装载的任何想法?找到解决方案问题是驱动器使用大约512个字符长的交互式关键短语加密.出于某种原因,CentOS6中的新内核模块在由旧版本创建时无法正确读取512个字符的加密密钥.似乎只会影响内核或cryptsetup的不同版本,因为在同一系统上创建和打开时,512字符的密钥将起作用

  7. centos – 大量ssh登录尝试

    22个我今天登录CentOS盒找到以下内容这是过去3天内的11次登录尝试.WTF?请注意,这是我从我的提供商处获得的全新IP,该盒子是全新的.我还没有发布任何关于此框的内容.为什么我会进行如此大量的登录尝试?是某种IP/端口扫描?基本上有4名匪徒,其中2名来自中国,1名来自香港,1名来自Verizon.这只发生在SSH上.HTTP上没有问题.我应该将罪魁祸首子网路由吗?你们有什么建议?

  8. centos – kswap使用100%的CPU,即使有100GB的RAM也可用

    >Linux内核是否应该足够智能,只需从内存中清除旧缓存页而不是启动kswap?

  9. centos – Azure将VM从A2 / 3调整为DS2 v2

    我正在尝试调整前一段时间创建的几个AzureVM,从基本的A3和标准A3到标准的DS2v2.我似乎没有能力调整到这个大小的VM.必须从头开始重建服务器会有点痛苦.如果它有所不同我在VM中运行CentOS,每个都有一个带有应用程序和操作系统的磁盘.任何人都可以告诉我是否可以在不删除磁盘的情况下删除VM,创建新VM然后将磁盘附加到新VM?

  10. centos – 广泛使用RAM时服务器计算速度减慢

    我在非常具体的情况下遇到服务器速度下降的问题.事实是:>1)我使用计算应用WRF>2)我使用双XeonE5-2620v3和128GBRAM(NUMA架构–可能与问题有关!

返回
顶部