热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

编译mysql5.7.18_mysql5.7.18源码安装笔记

之所以贴出这样一篇笔记呢?主要是因为很久之前,源码安装MySQL的时候,碰到了太多太多的坎坷。如果你有兴趣进行源码安装,那么

之所以贴出这样一篇笔记呢?主要是因为很久之前,源码安装MySQL的时候,碰到了太多太多的坎坷。

如果你有兴趣进行源码安装,那么请不要以这篇文章为标准,因为每个人的及其环境等其他因素还是差距比较大的。

但可以作为一篇流程参考文档,其中的坑点总结,希望能帮助大家绕过一些不必要的麻烦!

坑点

1 5.7.6以后安装必须有boost支持

2 权限和路径比较坑,步骤较多,如果中间错了,

先检查之前执行命令时权限是否正确,

再检查每一步操作的路径是否符合自己本地要求

3 很多人傻傻的找不到源码包在哪里,两个都是源码包

只不过下一个包含boost依赖

736c0640f747e37bb413e10d4e49df80.png

准备

1、首先安装依赖包

yum install -y gcc gcc-c++ ncurses-devel perl openssl-devel

最最重要的是,不要忘了安装openssl-devel

2、安装cmake

sudo yum install cmake

1 mysql迅雷下载地址:

https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-boost-5.7.18.tar.gz

2 解压:

sudo tar xzvf mysql-boost-5.7.18.tar.gz -C /usr/local/Mysql/

注:稍后我们需要建立/usr/local/mysql,

所以这里要建造一个Mysql,当然建造其他的也可以,

和之后的/usr/local/mysql 能区分开就好

3 先创建用户mysql并将mysql用户添加到mysql组下

groupadd mysql

useradd -g mysql mysql

将解压的文件的权限修改为mysql:mysql

sudo chown mysql:mysql /usr/local/Mysql/mysql-5.7.18

注:创建用户 sudo useradd -M -s /sbin/nologin mysql

4 安装依赖包:

sudo apt install -y build-essential cmake libncurses5-dev bison

编译

1 进入源码解压目录

cd /usr/local/Mysql/mysql-5.7.18/

2 创建编译后的文件存储位置,并进入

(1)sudo mkdir build      //创建build目录

(2)cd build      //进入build目录

3 指定cmake参数

sudo cmake .. -DCMAKE_INSTALL_PREFIX=/usr/local/mysql

-DDEFAULT_CHARSET=utf8mb4 .. -DWITH_BOOST=/usr/local/src/mysql-5.7.18/boost/boost_1_59_0

.. -DMYSQL_DATADIR=/data/mysql/data

安装的路径有点坑, 下面这条命令中有两个 ".."

如果不写的话,会提示没有 "/usr/local/mysql"

"/usr/local/Mysql/mysql-5.7.18/boost/boost_1_59_0"

由于对linux还不是特别熟悉,我估计应该是执行cmake时,会从根目录开始找配置的参数目录,

而".."代表根目录

488f69643bccea1a0d01834469aaa367.png

4 sudo make

编译完成之后,和网上视频教程讲述的一致,效果如下:

87e43700d7f71a5a83b16d86f3636145.png

5 执行 sudo make install

62763c1b9f7a649954c46bc70459c415.png

6 检查是否安装成功:

8b3c6e7839a4d80cbf9730f62e4f4b08.png

文件编译好之后,就需要安装数据库并执行配置了!

安装Mysql

1 配置环境变量(非必须):

创建变量文件,可以创建在profile,也可以创建在profile.d中

38fc5d65a087e99c3b8c01111a1b07ec.png

写入配置信息

87118ac17b5278210461d9c590adae35.png

执行生效环境变量,注意:这一步必须退到根目录下执行,

5a9a5537ca17349aad38915039adc75b.png

2 创建配置文件

在mysql的安装目录下创建配置文件目录/etc,

在/etc下创建my.cnf

4015dc12345934fccf8694fcdfe8b73d.png

3 编辑my.cnf

有些目录 /data /log /run 可能没有,则需要手动创建

my.cnf

[client]

[mysqld]

basedir=/usr/local/mysql

# this direct impossible is nothing,we need to build!

datadir=/usr/local/mysql/data

# The document was not informed

socket=/tmp/mysql.sock

character_set_filesystem = utf8mb4

character_set_server = utf8mb4

symbolic-links=0

# run and log is must!

log-error=/usr/local/mysql/log/mysqld.log

pid-file=/usr/local/mysql/run/mysqld.pid

4 将mysql目录下的文件权限,全部赋给mysql,

否则会导致初始化后,/data下没有任何内容

5 进行初始化

sudo /usr/local/mysql/bin/mysqld --defaults-file=/usr/local/mysql/etc/my.cnf

--initialize --user=mysql

6 配置启动服务

ad64f2a5e008950e3896c8ae753015c6.png

7 查询mysql的初始密码,在日志文件中随机生成的;

后面的路径需要注意是自己的

sudo grep 'root'@'localhost' /usr/local/mysql/log/mysqld.log

初始密码:7wff5n

200cec889d0978a70700e4ba9e3e9607.png

8 修改root密码

ALTER USER root@localhost IDENTIFIED BY 'new password';

9 连接数据库

mysql -h IP地址 -uroot -p 【回车后输密码】

GRANT ALL PRIVILEGES ON *.* TO 'itoffice'@'%' IDENTIFIED BY 'itoffice' WITH GRANT OPTION;

QQ 群:219537016    虽然没啥人气,群主经常装死中!

同事建立了一个微信讨论群,群主最喜欢能解决问题时,出来冒泡,解决不了时,装死!

4562f9180f83377ce3157d5e2b56fbe7.png



推荐阅读
  • CentOS7.8下编译muduo库找不到Boost库报错的解决方法
    本文介绍了在CentOS7.8下编译muduo库时出现找不到Boost库报错的问题,并提供了解决方法。文章详细介绍了从Github上下载muduo和muduo-tutorial源代码的步骤,并指导如何编译muduo库。最后,作者提供了陈硕老师的Github链接和muduo库的简介。 ... [详细]
  • Centos下安装memcached+memcached教程
    本文介绍了在Centos下安装memcached和使用memcached的教程,详细解释了memcached的工作原理,包括缓存数据和对象、减少数据库读取次数、提高网站速度等。同时,还对memcached的快速和高效率进行了解释,与传统的文件型数据库相比,memcached作为一个内存型数据库,具有更高的读取速度。 ... [详细]
  • 【技术分享】一个 ELF 蠕虫分析
    【技术分享】一个 ELF 蠕虫分析 ... [详细]
  • MySQL5.6.40在CentOS764下安装过程 ... [详细]
  • linux下编译安装lnmp
    2019独角兽企业重金招聘Python工程师标准#######################安装依赖#####################安装必要的包:y ... [详细]
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • imx6ull开发板驱动MT7601U无线网卡的方法和步骤详解
    本文详细介绍了在imx6ull开发板上驱动MT7601U无线网卡的方法和步骤。首先介绍了开发环境和硬件平台,然后说明了MT7601U驱动已经集成在linux内核的linux-4.x.x/drivers/net/wireless/mediatek/mt7601u文件中。接着介绍了移植mt7601u驱动的过程,包括编译内核和配置设备驱动。最后,列举了关键词和相关信息供读者参考。 ... [详细]
  • Jboss的EJB部署描述符standardjaws.xml配置步骤详解
    本文详细介绍了Jboss的EJB部署描述符standardjaws.xml的配置步骤,包括映射CMP实体EJB、数据源连接池的获取以及数据库配置等内容。 ... [详细]
  • 第四讲ApacheLAMP服务器基本配置Apache的编译安装从Apache的官方网站下载源码包:http:httpd.apache.orgdownload.cgi今 ... [详细]
  • 原文地址http://balau82.wordpress.com/2010/02/28/hello-world-for-bare-metal-arm-using-qemu/最开始时 ... [详细]
  • centos6.8 下nginx1.10 安装 ... [详细]
  • Howtobuilda./configure&&make&&makeins ... [详细]
author-avatar
大盗哈喽小马甲_943
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有