服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - 源码编译安装MySQL8.0.20的详细教程

源码编译安装MySQL8.0.20的详细教程

2021-01-18 14:44氷泠 Mysql

这篇文章主要介绍了源码编译安装MySQL8.0.20的详细教程,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

在上篇文章给大家介绍了:

MySQL8.0.20安装教程及其安装问题详细教程  http://www.zzvips.com/article/132713.html

mysql8.0.20下载安装及遇到的问题(图文详解)  http://www.zzvips.com/article/132715.html

centos7安装mysql8.0.20步骤:

https://dev.mysql.com/doc/relnotes/mysql/8.0/en/news-8-0-20.html

1 概述

本文章主要讲述了如何从源码编译安装mysql社区版8.0.20,首先会介绍一些编译安装的相关知识,然后开始编译安装

2 源码编译安装的相关知识

2.1 make与configure

make是一个编译的命令,会在当前的目录下寻找makefile这个文件,makefile文件记录了源代码如何编译的详细信息。而configure是由软件开发商编写的一个检测程序检测用户的开发环境,检测完毕后生成makefile文件。通常,configure会检测如下内容:

  • 是否具有合适的编译器
  • 是否具有所需函数库以及其他依赖
  • 是否兼容本系统
  • 是否存在内核头文件

2.2 tarball文件

tarball文件其实就是将源代码以tar打后压缩的文件。通常使用gzip进行压缩,一般扩展名为.tar.gz或.tgz,不过由于bzip2以及xz等技术压缩效果比gzip好,因此文件名也会变成扩展名也会变成.tar.bz2或.tar.xz之类的。通常一个tarball文件有:

  • 源码
  • 检测文件(configure/config)
  • 说明(readme/install)

2.3 源码编译安装相关组件

2.3.1 编译器

需要有编译器才能进行编译操作,通常使用的是gcc。

2.3.2 make+autoconfig

以tarball形式发布的软件,为了简化编译流程,通常需要make来根据目标文件文件的依赖性进行编译,但是由于make需要makefile,因此需要autoconfig生成makefile。

2.3.3 函数库

需要内核提供的库以及相关的include文件。

2.4 静态库与动态库

函数库分为动态库与静态库两种类型,绝大部分放在/lib与/lib64中。

2.4.1 静态库

扩展名为.a,编译时会直接整合到执行程序中,所以利用静态库生成的文件会比较大一些,编译后的可执行文件可以直接运行,无需依赖外部函数库。另外升级难度较大,因为是直接整合进程序中,升级了静态库的话需要重新编译。

2.4.2 动态库

扩展名为.so,在编译时不像静态库一样,动态库在程序中只有一个指针,当可执行程序需要用到函数库的功能时,才会读取函数库来使用,生成的可执行文件会比较小一点,但是不能独立执行编译出来的程序。另外升级比较方便,不需要重新编译,因为执行文件会直接指向新的函数库文件。

2.5 编译安装的一般步骤

  • (1)获取源码:一般使用wget或curl或从浏览器下载。
  • (2)查看帮助文件:解压后查看install或readme等文件相关内容
  • (3)安装依赖:根据官网文档或上一步中得到的信息安装依赖
  • (4)生成makefile:一般使用configure/config进行配置,检测操作环境,指定安装位置,开启/关闭对应的功能,指定相关库位置等,确定依赖关系等,一般需要使用–help获取选项帮助,指定对应选项后配置并生成makefile
  • (5)编译:实际编译步骤,一个简单的make命令,实际包含了头文件预编译,预处理,编译与连接步骤
  • (6)安装:make install,这一步实际进行安装与操作系统连接两个步骤

注意,以上步骤都是有顺序的,而且前一个步骤执行失败则后一个步骤也不能执行,也就是说需要前一个步骤执行成功才能进行下一步的操作。完成以上六步就能编译安装了,一般需要进行一些后续处理,比如,添加可执行文件路径到path,添加头文件与库文件到/usr/include与/etc/ld.so.conf.d中,添加联机帮助文件到/etc/man_db.conf中。

2.6 编译安装前的心理准备

这里是最后的提示了,未安装之前还可以ctrl+w关闭本页面,避免无数的痛苦。
编译安装最常见的问题就是版本与依赖的问题,版本问题容易处理,可以通过包管理器进行升级或者手动升级,至于依赖问题,包管理器安装的话很容易,编译安装的话会非常头疼,因为不知道某个依赖下面还需要安装多少个依赖。
所以,需要准备充足的时间,还有充分的耐心,去解决无数的问题,才能成功进行编译安装mysql与workbench这种大型软件。
不废话了,开始吧。

3 安装mysql

3.1 安装依赖

mysql所需依赖如下:

  • cmake
  • make(推荐3.75以上)
  • 编译器(gcc5.3+或clang4.0+或xcode9+或developer studio12.6+或visual studio2017)
  • ssl库(默认使用系统的openssl)
  • boost c++库,需要用来构建但不需要使用,无需安装,源码即可
  • ncurses库
  • bison2.1+
  • git

3.2 包管理器安装

笔者的debian系,使用apt即可:

?
1
2
3
4
5
6
sudo apt-get install -y bison
 git hostname
libncurses-dev
libssl-dev make
openssl pkg-config
doxygen cmake make

redhat8.x:

?
1
2
3
sudo yum install -y bison bzip2 git hostname ncurses-devel
openssl openssl-devel pkgconfig tar wget zlib-devel
doxygen diffutils rpcgen make libtirpc-devel cmake gcc

redhat7.x:

?
1
2
3
4
sudo yum install -y bison bzip2 git hostname ncurses-devel
openssl openssl-devel
pkgconfig tar wget zlib-devel
doxygen cmake gcc

其他自行搜索。

3.2 编译安装

若不想用包管理器安装,可以使用编译安装的方式。
欢迎来折腾。

3.2.1 安装cmake

?
1
2
3
4
5
6
7
tar -zxvf cmake-3.17.2.tar.gz
cd cmake-3.17.2
./bootstrap --prefix=/usr/local/cmake
make clean
make -j 6 #6为cpu核数,自定义修改,若失败请使用make
make test
sudo make install

3.2.2 安装make

没有编译器的情况下无法编译安装,使用软件包安装即可,笔者的debian系,直接使用apt:

?
1
sudo apt install make

3.2.3 安装gcc

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
tar -xvf gcc-9.3.0.tar.xz
cd gcc-9.3.0
./contrib/download_prerequisites
mkdir build
cd build
../configure --prefix=/usr/local/gcc -enable-checking=release -disable-multilib
make clean
make -j 6
make test
sudo make install
sudo ln -sv /usr/local/gcc/include /usr/include/gcc
#/etc/ld.so.conf.d/gcc.conf加入以下内容
/usr/local/gcc/lib
/usr/local/gcc/lib64

3.2.4 安装openssl

?
1
2
3
4
5
6
7
8
9
10
11
12
tar -zxvf openssl-1.1.1g.tar.gz
cd openssl-1.1.1g
./config --prefix=/usr/local/openssl --openssldir=/usr/local/openssl/ssl
#prefix为安装位置,默认/usr/local
#openssldir为配置文件位置,同时存放证书与密钥对
make clean
make -j 6
make test
sudo make install
sudo ln -sv /usr/local/openssl/include /usr/include/openssl
#/etc/ld.so.conf.d/openssl.conf加上以下内容
/usr/local/openssl/lib

3.2.5 下载boost

官网戳这里

需要的版本为1.70.0。目前最新的版本为1.73.0,理论上来说更新的版本应该可以,这里下载的是1.70.0。如果不手动下载boost库的话可以在使用cmake生成makefile时设置ddownload_boost为1进行下载。

源码编译安装MySQL8.0.20的详细教程

下载后解压既可。

?
1
tar -xvf boost_1_70_0.tar.bz2

3.2.6 安装ncurses

?
1
2
3
4
5
6
7
8
9
tar -zxvf ncurses-6.2.tar.gz
cd ncurses-6.2
./configure --prefix=/usr/local/ncurses
make -j 6
sudo make install
 
sudo ln -sv /usr/local/ncurses/include /usr/include/ncurses
#/etc/ld.so.conf.d/ncurses.conf加入
/usr/local/ncurses/lib

3.2.7 安装bison

?
1
2
3
4
5
6
7
tar -xvf bison-3.4.tar.xz
cd bison-3.4
./configure --prefix=/usr/local/bison
make -j 6
sudo make install
#/etc/ld.so.conf.d/bison.conf加入
/usr/local/bison/lib

3.2.8 安装git

?
1
2
3
4
5
6
7
8
9
10
11
12
13
tar -xvf git-2.26.2.tar.xz
cd git-2.26.2
./configure --prefix=/usr/local/git \
--with-openssl=/usr/local/openssl \
--with-libpcre2=/usr/local/pcre2 \
--with-curl=/usr/local/curl \
--with-expat=/usr/local/expat \
--with-iconv=/usr/local/iconv \
--with-editor=/usr/bin/vim \
--with-zlib=/usr/local/zlib \
--with-tcltk=/usr/local/tcl
make all doc info
sudo make install install-doc install-html install-info

3.2.9 后续处理

修改path:

?
1
2
3
4
5
6
7
8
#在~/.bash_profile 或 ~/.bashrc加入
export path=$path:\
/usr/local/cmake/bin:\
/usr/local/gcc/bin:\
/usr/local/openssl/bin:\
/usr/local/bison/bin:\
/usr/local/ncurses/bin:\
/usr/local/git/bin:\

使动态库生效:

?
1
ldconfig

权限不足请加sudo。

3.3 下载mysql社区版

官网这里。

源码编译安装MySQL8.0.20的详细教程

这里不知道第一个与第二个有什么区别,因为笔者两个都试过都能编译安装成功。虽然上面写着第二个带boost头,但是貌似没什么用。这里用的是第一个。
校验(可选):

?
1
md5sum mysql-boost-8.0.20.tar.gz

源码编译安装MySQL8.0.20的详细教程

3.4 生成makefile

?
1
2
3
4
5
6
7
8
9
10
sudo cmake .. \
-ddefault_charset=utf8mb4 \
-ddefault_collation=utf8mb4_unicode_ci \ #
-denabled_local_infile=on \
-dwith_ssl=system \
-dcmake_install_prefix=/usr/local/mysql/server \
-dmysql_datadir=/usr/local/mysql/data \
-dmysql_tcp_port=3306 \
-ddownload_boost=0 \
-dwith_boost=~/desktop/boost
  • ddefault_charset:指定默认字符集为utf8mb4,因为历史遗留问题,mysql中的utf8不是真正的utf8,而是阉割版的,最长只有三个字节,当遇到四个字节的utf8编码时,会导致存储异常。从5.5.3开始,使用utf8mb4实现完整的utf8。
  • ddefault_collation:排序规则,默认为utf8mb4_0900_ai_ci,属于utf8mb4_unicode_ci的一种。0900指的是unicode校对算法版本,ai是指口音不敏感(as表示敏感),ci指不区分大小写(cs表示区分)。utf8mb4_unicode_ci表示基于标准的的unicode来排序和比较,能够在各种语言之间精确排序,而utf8mb4_general_ci遇到某些特殊的字符集时排序结果可能不一致,准确性较差,但是性能较好,比较和排序时候更快。
  • denabled_local_infile表示能否使用load data命令。
  • dwith_ssl表示使用系统的ssl库,若不使用系统的请自定义路径。
  • dcmake_install_prefix:mysql安装目录。
  • dmysql_datadir:mysql数据目录,初始时为空。
  • dmysql_tcp_port:端口,默认3306。
  • ddownload_boost:取值0或1,是否下载boost库。
  • dwith_boost:若不下载boost库的话,是本地boost库的位置,若下载boost表示下载位置。

其他更多参数请使用

?
1
sudo cmake .. -lh

查看。

3.5 编译与安装

?
1
sudo make

?
1
sudo make -j n

笔者试过了make -j 6,失败,无奈换成了make。
make的速度和make -j还是很大差距的。
编译好之后,建议测试一下:

?
1
make test

然后安装:

?
1
sudo make install

3.6 后续配置

3.6.1 用户组与用户

新建用户组与用户,同时修改用户数据目录权限:

?
1
2
3
4
sudo groupadd mysql
sudo useradd -r -g mysql -s /bin/false mysql
sudo chown mysql:mysql /usr/local/mysql/data
sudo chmod 750 /usr/local/mysql/data

数据目录根据需要修改,若后面出现不可写错误请把权限改为777。

3.6.2 配置文件

配置文件为my.cnf,可以放在

?
1
2
3
4
/etc/
/etc/mysql/
安装目录/etc/
~/

下,读取顺序从上到下。笔者安装后默认在/etc/mysql/my.cnf,这个是全局配置,~/.my.cnf是用户特定配置,这里直接修改/etc/mysql/my.cnf:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
[client-server]
 
# import all .cnf files from configuration directory
!includedir /etc/mysql/conf.d/
!includedir /etc/mysql/mariadb.conf.d/
 
[mysqld]
port=3306
basedir=/usr/local/mysql/server
datadir=/usr/local/mysql/data
character-set-server=utf8mb4
[mysql]
default-character-set=utf8mb4
[client]
port=3306
default-character-set=utf8mb4

其中[mysqld]下面是新添加的字段,数据目录自行修改。
建议字符集改为utf8mb4,因为utf8在mysql中指的是utf8mb3,支持的utf8编码最大字符长度为3字节,如果遇到4字节的宽字符就会插入异常。三字节的utf8最大能编码的unicode字符为0xffffff,也就是基本多文种平面,emoji和很多不常用的汉字都不能存储。而utf8mb4是5.5.3之后才支持的,为了兼容性考虑应该统一使用utf8mb4。

3.7 初始化

修改环境变量:

?
1
2
#.bashrc或.bash_profile加上
export path=$path:/usr/local/mysql/server/bin

使用

?
1
mysqld --initialize --user=mysql

?
1
mysqld --initialize-insecure --user=mysql

然后开启ssl与rsa支持(可选):

?
1
mysql_ssl_rsa_setup

最后开启服务:

?
1
mysqld_safe --user=mysql &

3.8 修改密码

使用root登录,如果使用insecure初始化:

?
1
mysql -u --skip-password

使用initialize初始化:

?
1
mysql -u root -p

输入初始化出现的密码即可。
然后修改密码:

?
1
alter user root@localhost identified by 'xxx';

3.9 测试

使用自带的mysqlshow与mysqladmin:

?
1
mysqladmin -u root -p versionmysqlshow -u root -p

源码编译安装MySQL8.0.20的详细教程

3.10 收尾工作

3.10.1 别名

?
1
alias md='mysqld -u mysql &'

这样输入md就可以启动mysql服务了。

3.10.2 安装mycli

mycli是一个mysql命令行客户端工具,具有自动补全和语法高亮的功能。
使用pip安装即可,python2请使用

?
1
pip install mycli

python3请使用

?
1
pip3 install mycli

找不到pip请安装:

?
1
2
sudo apt install python-pip#python2
sudo apt install python3-pip

然后使用mycli进入数据库:

?
1
mycli -u root

愉快地使用补全吧!

4 参考

1.Linux下安装mysql的方式(yum和源码编译两种方式)
2.utf8 与 utf8mb4,utf8mb4_unicode_ci 与 utf8mb4_general_ci
3.MySQL-官网安装文档

总结

到此这篇关于源码编译安装mysql8.0.20的详细教程的文章就介绍到这了,更多相关源码编译安装mysql8.0.20内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_27525611/article/details/105902643

延伸 · 阅读

精彩推荐
  • MysqlMySQL 数据备份与还原的示例代码

    MySQL 数据备份与还原的示例代码

    这篇文章主要介绍了MySQL 数据备份与还原的相关知识,本文通过示例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下...

    逆心2962019-06-23
  • Mysqlmysql 不能插入中文问题

    mysql 不能插入中文问题

    当向mysql5.5插入中文时,会出现类似错误 ERROR 1366 (HY000): Incorrect string value: '\xD6\xD0\xCE\xC4' for column ...

    MYSQL教程网5722019-11-25
  • MysqlMySQL数据库varchar的限制规则说明

    MySQL数据库varchar的限制规则说明

    本文我们主要介绍了MySQL数据库中varchar的限制规则,并以一个实际的例子对限制规则进行了说明,希望能够对您有所帮助。 ...

    mysql技术网4192019-11-23
  • Mysql解决MySQl查询不区分大小写的方法讲解

    解决MySQl查询不区分大小写的方法讲解

    今天小编就为大家分享一篇关于解决MySQl查询不区分大小写的方法讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起...

    Veir_dev5592019-06-25
  • MysqlERROR: Error in Log_event::read_log_event()

    ERROR: Error in Log_event::read_log_event()

    ERROR: Error in Log_event::read_log_event(): read error, data_len: 438, event_type: 2 ...

    MYSQL教程网6402020-03-13
  • Mysql浅谈mysql 树形结构表设计与优化

    浅谈mysql 树形结构表设计与优化

    在诸多的管理类,办公类等系统中,树形结构展示随处可见,本文主要介绍了mysql 树形结构表设计与优化,具有一定的参考价值,感兴趣的小伙伴们可以参...

    小码农叔叔5242021-11-16
  • Mysql详解MySQL中的分组查询与连接查询语句

    详解MySQL中的分组查询与连接查询语句

    这篇文章主要介绍了MySQL中的分组查询与连接查询语句,同时还介绍了一些统计函数的用法,需要的朋友可以参考下 ...

    GALAXY_ZMY5432020-06-03
  • MysqlMySQL锁的知识点总结

    MySQL锁的知识点总结

    在本篇文章里小编给大家整理了关于MySQL锁的知识点总结以及实例内容,需要的朋友们学习下。...

    别人放弃我坚持吖4362020-12-14