当前位置:   article > 正文

MySQL源码编译安装启动教程及其预编译参数详解_-ddownload_boost=1 -dwith_boost=

-ddownload_boost=1 -dwith_boost=

一、MySQL源码编译安装教程

1、下载boost_1_59_0.tar.gz、mysql-5.7.20.tar.gz源码包

wget https://nchc.dl.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz;wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.20.tar.gz
  • 1

***注:***Boost库是为C++语言标准库提供扩展的一些C++程序库的总称,由Boost社区组织开发、维护

2、yum安装必要的软件

yum -y install gcc-c++ ncurses-devel cmake make perl gcc autoconf automake zlib libxml libgcrypt libtool bison
  • 1

3、将刚刚下载的两个源码包移到/usr/local/下

[root@proxy-server ~]# mv mysql-5.7.20.tar.gz /usr/local/
[root@proxy-server ~]# mv boost_1_59_0.tar.gz /usr/local/
  • 1
  • 2

4、解压boost_1_59_0.tar.gz、mysql-5.6.35.tar.gz

[root@proxy-server local]# tar -xvf mysql-5.7.20.tar.gz 
[root@proxy-server local]# tar -xvf boost_1_59_0.tar.gz
  • 1
  • 2

5、把解压得到的boost_1_59_0这个目录移到/usr/local/boost

[root@proxy-server local]# mv boost_1_59_0 /usr/local/boost
  • 1

6、cmake预编译

[root@proxy-server local]# cd mysql-5.7.20/
[root@proxy-server local]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \
-DMYSQL_DATADIR=/data/mysql \
-DSYSCONFDIR=/etc \
-DMYSQL_USER=mysql \
-DMYSQL_TCP_PORT=3306 \
-DWITH_XTRADB_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_EXTRA_CHARSETS=1 \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DEXTRA_CHARSETS=all \
-DWITH_BIG_TABLES=1 \
-DWITH_DEBUG=0 \
-DENABLE_DTRACE=0 \
-DDOWNLOAD_BOOST=1 \
-DWITH_BOOST=/usr/local/boost
***  #注意上面这个就是指定的那个boost库的位置,所以必须要进行第五步***
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24

6、编译安装

[root@proxy-server mysql-5.6.35]# make&&make install
#不建议使用make -j4这个参数,因为非常容易出现错误,比如
c++: 编译器内部错误:已杀死(程序 cc1plus) Please submit a full bug report
#根据网上的说法是出现了内存不足,用如下命令添加交换内存:
dd if=/dev/zero of=/home/swap bs=64M count=16 
mkswap /home/swap 
swapon /home/swap 

关闭并删除交换内存/home/swap:
swapoff /home/swap
rm /home/swap
但是我无论添加多少的交换内存都无法解决这个报错。后面不使用-j这个参数才成功了。
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

二、预编译参数详解

cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql  	Cmake预编译;
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock 			MYSQL Socket通信文件位置;
-DMYSQL_DATADIR=/data/mysql 						MYSQL数据存放路径;
-DSYSCONFDIR=/etc 									配置文件路径;	
-DMYSQL_USER=mysql 								MYSQL运行用户;	
-DMYSQL_TCP_PORT=3306 							MYSQL监听端口;
-DWITH_XTRADB_STORAGE_ENGINE=1 				开启xtradb引擎支持;
-DWITH_INNOBASE_STORAGE_ENGINE=1  			开启innodb引擎支持;
-DWITH_PARTITION_STORAGE_ENGINE=1 			开启partition引擎支持;
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 			开启blackhole引擎支持;
-DWITH_MYISAM_STORAGE_ENGINE=1 				开启MyISAM引擎支持;
-DWITH_READLINE=1 								启用快捷键功能;	
-DENABLED_LOCAL_INFILE=1 						允许从本地导入数据;
-DWITH_EXTRA_CHARSETS=1 						支持额外的字符集;	
-DDEFAULT_CHARSET=utf8 							默认字符集UTF-8;	
-DDEFAULT_COLLATION=utf8_general_ci 				检验字符;	
-DEXTRA_CHARSETS=all 							安装所有扩展字符集;
-DWITH_BIG_TABLES=1 								将临时表存储在磁盘上;
-DWITH_DEBUG=0									禁止调试模式支持;	
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

三、mysql的配置及启动

1、创建mysql用户的账号

[root@proxy-server ~]# groupadd mysql
[root@proxy-server ~]# useradd -s /sbin/nologin -g mysql -M mysql
useradd 命令的参数参数简要说明:
-s /sbin/nologin 表示禁止该用户登录,只需要用户存在即可,加强安全
-g mysql 指定mysql用户属于mysql组
-M 表示不创建用户家目录,因为没有需要

检查创建的mysql用户及组:
tail -l /etc/passwd
id mysql
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

2、将安装目录所有者及所属组改为mysql,创建/data/mysql/

chown -R mysql.mysql /usr/local/mysql
mkdir -p /data/mysql && chown mysql:mysql -R /data/mysql/
  • 1
  • 2

3、配置my.cnf文件

[client]
port=3306
socket=/tmp/mysql.sock
[mysqld]
basedir=/usr/local/mysql
datadir=/data/mysql
socket=/tmp/mysql.sock
symbolic-links=0
[mysqld_safe]
log-error=/data/mysql/mysql-error.log
pid-file=/data/mysql/mysql.pid
!includedir /etc/my.cnf.d
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

4、初始化

[root@localhost mysql]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --datadir=/data/mysql --basedir=/usr/local/mysql
  • 1

在这里插入图片描述注:mysql 程序初始化的内容,mysql的默认程序表,系统表,用户表,都是在初始化的时进行创建的。

6、将启动文件copy到/etc/init.d/mysqld

[root@localhost mysql]# \cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

//mysql.server这个是mysql的启动文件。
目录/etc/init.d/的作用:init.d目录包含许多系统各种服务的启动和停止脚本
要想加入系统服务必须把启动文件copy到这个目录下
  • 1
  • 2
  • 3
  • 4
  • 5

7、加入系统服务,开机自启动

chkconfig --add mysqld
chkconfig mysqld on
  • 1
  • 2

8、启动mysqld服务

[root@localhost mysql]# systemctl restart mysqld
  • 1

9、加入到环境变量,方便使用mysql命令登录

[root@localhost mysql]# vim /etc/profile
  • 1

编辑内容如下:
在这里插入图片描述

[root@localhost mysql]# source /etc/profile //使文件配置生效
使用下面命令进入到mysql
[root@localhost mysql]# mysql -uroot -p
//注意要想登录,先要启动mysql
//这里会提示输入密码,输入之前第四步的密码即可
//也可以在my.cnf中的[mysqld]下加入--skip-grant-tables这个参数即可跳过密码登录
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

10、启动mysql,修改root用户密码

service mysqld start
mysql -uroot -p
alter user 'root'@'localhost' identified by 'mysql';
  • 1
  • 2
  • 3

在这里插入图片描述***注:***第一次进数据库,第一个操作就是采用上面指令修改密码,不然会报错:

ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
  • 1
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/425528
推荐阅读
相关标签
  

闽ICP备14008679号