MySQL源码部署(rhel7)

1.rhel7的MySQL源码部署

1.1安装编译mysql所需软件包

1.1.1 安装mysql8的依赖软件

bash 复制代码
[root@mysql-master171 ~]# yum install  -y git bison openssl-devel ncurses-devel -y

1.1.2安装cmake3

a.配置epel仓库
bash 复制代码
[root@mysql-master171 ~]# vim  /etc/yum.repos.d/epel.repo
[epel]
name=epel
baseurl=https://mirrors.aliyun.com/epel/7/x86_64/
gpgcheck=0
b.安装cmake3
bash 复制代码
[root@mysql-master171 ~]# yum install  cmake3 -y

1.1.3安装gcc11,找到rpm包上传linux后解压安装

a.通过xtfp上传gcc11
bash 复制代码
[root@mysql-master171 ~]# ls gcc-11.zip
gcc-11.zip
b.解压gcc11
bash 复制代码
[root@mysql-master171 ~]# unzip gcc-11.zip
c.安装gcc11相关rpm包
bash 复制代码
[root@mysql-master171 ~]# cd  gcc-11/
[root@mysql-master171 gcc-11]# yum install ./*.rpm
d.临时启用devtoolset-11环境
bash 复制代码
[root@mysql-master171 ~]# source  /opt/rh/devtoolset-11/enable
e.永久配置gcc11环境
bash 复制代码
[root@mysql-master171 gcc-11]# cat /opt/rh/devtoolset-11/enable  >> ~/.bash_profile
f.查看当前gcc版本
bash 复制代码
[root@master gcc-11]# gcc -v
gcc version 11.2.1 20220127 (Red Hat 11.2.1-9) (GCC)

1.2编译安装mysql8.0.40

1.2.1通过xftp将mysql-boost-8.0.40.tar.gz传到/opt目录下

bash 复制代码
[root@mysql-master171 opt]# ls mysql-boost-8.0.40.tar.gz
mysql-boost-8.0.40.tar.gz

1.2.2解压MySQL源码压缩包到当前目录(/opt)

bash 复制代码
[root@mysql-master171 opt]# tar zxf mysql-boost-8.0.40.tar.gz

1.2.3切换到解压后的mysql源码主目录并创建bld文件夹

bash 复制代码
[root@mysql-master171 opt]# cd  mysql-8.0.40/
[root@mysql-master171 mysql-8.0.40]# mkdir bld
[root@mysql-master171 mysql-8.0.40]# cd bld

1.2.4执行cmake3命令,进行环境检测

bash 复制代码
[root@mysql-master171 bld]#  cmake3 .. \
-DWITH_BOOST=../boost/boost_1_77_0/ \    #指定MySQL 源码编译所依赖的 Boost 库的路径
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \				#指定安装路径
-DMYSQL_DATADIR=/data/mysql \							#指定数据目录
-DMYSQL_UNIX_ADDR=/data/mysql/mysql.sock \				#指定套接字文件
-DWITH_INNOBASE_STORAGE_ENGINE=1 \						#指定启用INNODB存储引擎,默认用myisam
-DWITH_EXTRA_CHARSETS=all \								#扩展字符集
-DDEFAULT_CHARSET=utf8mb4 \								#指定默认字符集
-DDEFAULT_COLLATION=utf8mb4_unicode_ci \				#指定默认校验字符集
-DWITH_SSL=system \										#指定MySQL使用系统已安装的 SSL 库

1.3进行编译

bash 复制代码
#该过程很久,请耐心等待,利用多核CPU资源同时运行4个编译进程
[root@mysql-master171  bld]# make  -j 4 
#把编译生产的二进制文件复制到预安装目录,完成mysql部署
[root@mysql-master171  bld]# make install

1.4将源码编译好的mysql进行配置

1.4.1生成启动脚本

bash 复制代码
[root@mysql-master171 ~]# cp  /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

1.4.2修改环境变量

bash 复制代码
#在空白处插入
[root@mysql-master171 ~]# vim ~/.bash_profile
export PATH=$PATH:/usr/local/mysql/bin
#立即执行
[root@mysql-master171 ~]# source ~/.bash_profile

1.4.3建立数据库程序运行用户

bash 复制代码
[root@mysql-master171 ~]# useradd -M -s /sbin/nologin mysql

1.4.4建立数据库数据目录

bash 复制代码
[root@mysql-master171 ~]# mkdir -p /data/mysql/
[root@mysql-master171 ~]# chown mysql.mysql -R /data/mysql/

1.4.5创建配置文件

bash 复制代码
[root@mysql-master171 ~]# vim /etc/my.cnf
[mysqld]
datadir=/data/mysql   #指定数据目录
socket=/data/mysql/mysql.sock   #指定套接字
server_id=171
log-bin=binlog

1.4.6将数据库初始化建立mysql基本数据,记得看临时密码

bash 复制代码
[root@mysql-master171 ~]# mysqld --initialize --user=mysql

1.4.7启动数据库

bash 复制代码
[root@mysql-master171 ~]# /etc/init.d/mysqld  start
Starting MySQL.Logging to '/data/mysql/master.err'.
. SUCCESS!

1.4.8修改数据库密码,新密码为123

bash 复制代码
[root@mysql-master171 ~]# mysqladmin -uroot -p password  '123'

1.4.9使用新密码登录数据库

bash 复制代码
[root@mysql-master171 ~]# mysql -uroot -p123
相关推荐
666和7776 小时前
Struts2 工作总结
java·数据库
还听珊瑚海吗6 小时前
SpringMVC(一)
数据库
星期天要睡觉8 小时前
MySQL 综合练习
数据库·mysql
Y4090018 小时前
数据库基础知识——聚合函数、分组查询
android·数据库
JosieBook9 小时前
【数据库】MySQL 数据库创建存储过程及使用场景详解
数据库·mysql
处女座_三月9 小时前
改 TDengine 数据库的时间写入限制
数据库·sql·mysql
酷ku的森9 小时前
Redis中的hash数据类型
数据库·redis·哈希算法