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
相关推荐
老华带你飞5 分钟前
工会管理|基于springboot 工会管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·spring
自在极意功。5 分钟前
MyBatis配置文件详解:environments、transactionManager与dataSource全面解析
java·数据库·tomcat·mybatis
紫金桥软件5 分钟前
紫金桥软件 | 赋能工业数字化转型
数据库·国产化
Navicat中国9 分钟前
Navicat x 达梦技术指引 | 模型转换
数据库·达梦·navicat·概念模型·物理模型·逻辑模型·模型转换
邂逅星河浪漫10 分钟前
【MySQL 事务】详细介绍+实例
数据库·mysql·事务
tianyuanwo13 分钟前
RPM数据库锁竞争:原理、诊断与根治方案
数据库·rpm·bdb·命令挂起
TG:@yunlaoda360 云老大15 分钟前
如何评估华为云国际站代理商跨境合规要求?
大数据·数据库·华为云·云计算
志凌海纳SmartX16 分钟前
银行核心系统备库“降本增效”探索:超融合承载Oracle ADG备库的测试验证
数据库·oracle
木卫二号Coding19 分钟前
POSTGRESQL+数据库备份与还原
数据库·postgresql·oracle
Lvan的前端笔记20 分钟前
python:用 dotenv 管理环境变量&生产环境怎么管理环境变量
网络·数据库·python