千家信息网

centos7手工编译mysql5.7数据库详解(附源码包)

发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,mysql简介:MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司。MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放
千家信息网最后更新 2025年01月19日centos7手工编译mysql5.7数据库详解(附源码包)

mysql简介:
MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司。
MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

实验环境:centos7一台,NAT模式虚拟机挂载编译的目录大小不能小于8G这样,建议添加一块磁盘,挂载到本   地进行编译安装链接:https://pan.baidu.com/s/1XFej_DoR3bXkCiTxFqhVOQ 密码:amv1 boost源码包地址链接:https://pan.baidu.com/s/1L4Saf17boqWTAqmm9mKWrw 密码:dhjkmysql5.7源码包地址注意事项:编译所需要的存储空间不少于7G,建议虚拟机添加磁盘挂载编译

1、安装编译环境包如下:

yum install ncurses ncurses-devel bison cmake gcc gcc-c++ -y

2、创建mysql用户

useradd -s /sbin/nologin mysql

3、挂载宿主机文件夹,解压包

mount.cifs //192.168.60.1/linuxbage /root/abc
tar zxvf mysql-5.7.17.tar.gz -C /abc/
tar zxvf boost_1_59_0.tar.gz -C /usr/local/

4、更改boost目录名,方便编译缩写cd /usr/local/        //到解压的目录下mv boost_1_59_0 boost      /将boost改名

5、到mysql解压的目录下

cd /root/abc
编译参数如下
cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=/usr/local/boost \
-DWITH_SYSTEMD=1

6、make && make install7、chown -R mysql.mysql /usr/local/mysql/         变更mysql属主属组

8、更改配置文件

vim /etc/my.cnf

针对不同区域进行配置
client] 客户端
port = 3306 3306端口
default-character-set=utf8 字符集
socket = /usr/local/mysql/mysql.sock 客户端连接服务端的连接目录

[mysql] 服务端
port = 3306 3306端口
default-character-set=utf8 字符集
socket = /usr/local/mysql/mysql.sock 连接目录

[mysqld] 针对于服务本身而言进行设定
user = mysql 管理用户是mysql
basedir = /usr/local/mysql 工作目录路径
datadir = /usr/local/mysql/data 数据库文件路径,会自动生成
port = 3306 端口3306
character_set_server=utf8 字符集
pid-file = /usr/local/mysql/mysqld.pid pid进程文件
socket = /usr/local/mysql/mysql.sock 连接目录
server-id = 1 server id

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES

9、修改my.cnf的属主属组,添加环境变量

10、初始化数据库

cd /usr/local/mysql/

bin/mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data

11、复制启动脚本

cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service  /usr/lib/systemd/system/

12、启动mysql

systemctl daemon-reload
systemctl start mysqld
netstat -anpt | grep 3306
systemctl enable mysqld

13、设置登陆密码

mysqladmin -u root -p password "abc123"

14、登陆mysql,查看数据库

15、设置权限,实现远程登陆

grant all privileges on . to 'root'@'%' identified by 'abc123' with grant option;

end~

0