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
相关推荐
@游子2 小时前
SQL注入语法和介绍(一)
数据库·oracle
蒋士峰DBA修行之路5 小时前
实验十三 WDR诊断报告
数据库
杂亿稿5 小时前
数据库的约束
数据库
u***32435 小时前
使用python进行PostgreSQL 数据库连接
数据库·python·postgresql
Codingwiz_Joy5 小时前
Day44 盲注、报错注入 & 实战复现
数据库·安全性测试
7***99877 小时前
GaussDB数据库中SQL诊断解析之配置SQL限流
数据库·sql·gaussdb
Wang's Blog8 小时前
MongoDB小课堂: 文档操作核心技术指南:主键机制、CRUD操作与最佳实践
数据库·mongodb
i***t9198 小时前
Linux下MySQL的简单使用
linux·mysql·adb
g***26798 小时前
最新SQL Server 2022保姆级安装教程【附安装包】
数据库·性能优化
风123456789~9 小时前
【OceanBase专栏】OB背景知识
数据库·笔记·oceanbase