Rocky Linux 9 源码包安装Mysql8
liuian 2025-08-03 06:02 2 浏览
Rocky Linux 9 源码包安装Mysql8
大家好我是星哥,之前介绍了,Rocky Linux 9 源码包安装Mysql5.7。
本文将介绍如何在Rocky Linux 9操作系统上,从源码一步步安装MySQL 8,为您提供一个稳定、高效且可控的数据库解决方案。
为什么选择源码编译安装MySQL 8?
尽管通过包管理器安装MySQL更为便捷,但源码编译安装提供了无与伦比的优势:
- o 极致性能优化:您可以根据硬件架构和特定工作负载进行编译优化,例如调整编译参数,开启或禁用特定功能,从而压榨出MySQL的最佳性能。
- o 高度定制化:您可以选择性地编译所需的存储引擎、功能模块,去除不必要的功能,减小安装包体积,降低潜在的安全风险。
- o 最新版本与补丁:源码编译允许您第一时间体验到MySQL的最新版本或应用最新的安全补丁,无需等待发行版官方的更新。
- o 透明化与控制:整个安装过程完全可控,您可以清楚地了解每个组件的安装路径、依赖关系,便于后续的维护和故障排除。
快速安装
# 使用:
# gitee:
# wget https://gitee.com/funet8/Rocky-Linux-Shell/raw/main/shell/Rocky_Linux_9_Install_MySQL8.sh
# sh Rocky_Linux_9_Install_MySQL8.sh
# github:
# wget https://raw.githubusercontent.com/funet8/Rocky-Linux-Shell/refs/heads/main/shell/Rocky_Linux_9_Install_MySQL8.sh
# sh Rocky_Linux_9_Install_MySQL8.sh
功能介绍
功能:Rocky Linux 9系统中源码包安装 mysql8
- o mysql安装的目录:/data/app/mysql8/install
- o mysql数据库目录:/data/app/mysql8/data
- o mysql数据库配置目录:/data/app/mysql8/etc
- o mysql数据库binlog目录:/data/app/mysql8/binlog
- o mysql端口为: 61800
- o mysql root密码为: CQ12345678
安装依赖
dnf安装依耐
安装MySQL8.0.39需要的gcc工具集,安装前,需要升级软件包libsemanage为高版本,同样需要下载软件包到本地,然后rpm -Uvh更新
dnf install -y make cmake gcc gcc-c++ ncurses-devel openssl-devel libtirpc wget
mkdir /data/software/
cd /data/software/
wget https://dl.rockylinux.org/pub/rocky/9/devel/x86_64/os/Packages/l/libtirpc-devel-1.3.3-9.el9.x86_64.rpm
wget https://dl.rockylinux.org/pub/rocky/9/AppStream/x86_64/os/Packages/r/rpcgen-1.4-9.el9.x86_64.rpm
# 安装依赖包
rpm -ivh libtirpc-devel-1.3.3-9.el9.x86_64.rpm
rpm -ivh rpcgen-1.4-9.el9.x86_64.rpm
然后再安装MySQL8.0.39需要的gcc工具集,安装前,需要升级软件包libsemanage为高版本,同样需要下载软件包到本地,然后rpm -Uvh更新
wget http://js.funet8.com/rocky-linux/mysql/libsemanage-3.6-5.el9_6.x86_64.rpm
rpm -Uvh libsemanage-3.6-5.el9_6.x86_64.rpm
yum install -y gcc-toolset-12-gcc gcc-toolset-12-gcc-c++ gcc-toolset-12-binutils gcc-toolset-12-annobin-annocheck gcc-toolset-12-annobin-plugin-gcc
新建目录
mkdir -p /data/app/mysql8 /data/app/mysql8/install /data/app/mysql8/data /data/app/mysql8/etc /data/app/mysql8/binlog
下载Mysql并安装
下载mysql
cd /data/software/
wget http://js.funet8.com/rocky-linux/mysql/mysql-boost-8.0.39.tar.gz
tar -zxvf mysql-boost-8.0.39.tar.gz
cd mysql-8.0.39
安装
cmake \
-DCMAKE_INSTALL_PREFIX=/data/app/mysql8/install \
-DINSTALL_DATADIR=/data/app/mysql8/data \
-DMYSQL_USER=mysql \
-DMYSQL_UNIX_ADDR=/data/app/mysql8/etc/mysql.sock \
-DDEFAULT_CHARSET=utf8mb4 \
-DDEFAULT_COLLATION=utf8mb4_general_ci \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_EMBEDDED_SERVER=1 \
-DFORCE_INSOURCE_BUILD=1 \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DENABLED_LOCAL_INFILE=1 \
-DEXTRA_CHARSETS=all \
-DWITH_BOOST=boost/boost_1_77_0/
# 编译(j1避免内存被杀)
make -j1 && make install
配置mysql文件
vi /data/app/mysql8/etc/my.cnf
填写以下内容:
[client]
default-character-set = utf8mb4
[mysqld]
### 基本属性配置
port = 61800
datadir=/data/app/mysql8/data
socket=/data/app/mysql8/etc/mysql.sock
# 禁用主机名解析
skip-name-resolve
# 默认的数据库引擎
default-storage-engine = InnoDB
### 字符集配置
#character-set-client-handshake = FALSE(弃用)
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'
### GTID
# server_id来唯一的标识某个数据库实例,并在链式或双主复制结构中用它来避免sql语句的无限循环
server_id = 1
# 开启 gtid 功能
gtid_mode = on
# 保障 GTID 事务安全
# 当启用enforce_gtid_consistency功能的时候,
# MySQL只允许能够保障事务安全, 并且能够被日志记录的SQL语句被执行,
# 像create table ... select 和 create temporarytable语句,
# 以及同时更新事务表和非事务表的SQL语句或事务都不允许执行
enforce-gtid-consistency = true
# 以下两条配置为主从切换, 数据库高可用的必须配置
# 开启 binlog 日志功能
log_bin = on
binlog_format=ROW
log-bin=/data/app/mysql8/binlog/mysql-bin
#10天
binlog_expire_logs_seconds = 864000
#expire_logs_days=10 (弃用)
max_binlog_size=500m
binlog_cache_size=4m
max_binlog_cache_size=512m
# 开启从库更新 binlog 日志
#log-slave-updates = on
### 慢查询日志
# 打开慢查询日志功能
slow_query_log = 1
# 超过2秒的查询记录下来
long_query_time = 2
# 记录下没有使用索引的查询
#log_queries_not_using_indexes = 1
slow_query_log_file = /data/app/mysql8/etc/slow-61800.log
### 自动修复
# 记录 relay.info 到数据表中
relay_log_info_repository = TABLE
# 记录 master.info 到数据表中
master_info_repository = TABLE
# 启用 relaylog 的自动修复功能
relay_log_recovery = on
# 在 SQL 线程执行完一个 relaylog 后自动删除
relay_log_purge = 1
### 数据安全性配置
# 关闭 master 创建 function 的功能
log_bin_trust_function_creators = off
# 每执行一个事务都强制写入磁盘
sync_binlog = 1
# timestamp 列如果没有显式定义为 not null, 则支持null属性
# 设置 timestamp 的列值为 null, 不会被设置为 current timestamp
explicit_defaults_for_timestamp=true
### 优化配置
# 优化中文全文模糊索引
ft_min_word_len = 1
# 默认库名表名保存为小写, 不区分大小写
lower_case_table_names = 1
# 单条记录写入最大的大小限制
# 过小可能会导致写入(导入)数据失败
max_allowed_packet = 256M
# 半同步复制开启
#rpl_semi_sync_master_enabled = 1
#rpl_semi_sync_slave_enabled = 1
# 半同步复制超时时间设置
#rpl_semi_sync_master_timeout = 1000
# 复制模式(保持系统默认)
#rpl_semi_sync_master_wait_point = AFTER_SYNC
# 后端只要有一台收到日志并写入 relaylog 就算成功
#rpl_semi_sync_master_wait_slave_count = 1
# 多线程复制
#slave_parallel_type = logical_clock
#slave_parallel_workers = 4
### 连接数限制
max_connections = 3000
# 验证密码超过20次拒绝连接
max_connect_errors = 20
# back_log值指出在mysql暂时停止回答新请求之前的短时间内多少个请求可以被存在堆栈中
# 也就是说,如果MySql的连接数达到max_connections时,新来的请求将会被存在堆栈中
# 以等待某一连接释放资源,该堆栈的数量即back_log,如果等待连接的数量超过back_log
# 将不被授予连接资源
back_log = 500
open_files_limit = 65535
# 服务器关闭交互式连接前等待活动的秒数
interactive_timeout = 3600
# 服务器关闭非交互连接之前等待活动的秒数
wait_timeout = 3600
### 内存分配
# 指定表高速缓存的大小。每当MySQL访问一个表时,如果在表缓冲区中还有空间
# 该表就被打开并放入其中,这样可以更快地访问表内容
table_open_cache = 1024
# 为每个session 分配的内存, 在事务过程中用来存储二进制日志的缓存
binlog_cache_size = 2M
# 在内存的临时表最大大小
tmp_table_size = 128M
# 创建内存表的最大大小(保持系统默认, 不允许创建过大的内存表)
# 如果有需求当做缓存来用, 可以适当调大此值
max_heap_table_size = 16M
# 顺序读, 读入缓冲区大小设置
# 全表扫描次数多的话, 可以调大此值
read_buffer_size = 1M
# 随机读, 读入缓冲区大小设置
read_rnd_buffer_size = 8M
# 高并发的情况下, 需要减小此值到64K-128K
sort_buffer_size = 1M
# 每个查询最大的缓存大小是1M, 最大缓存64M 数据
#query_cache_size = 64M
#query_cache_limit = 1M
# 提到 join 的效率
join_buffer_size = 16M
# 线程连接重复利用
thread_cache_size = 64
### InnoDB 优化
## 内存利用方面的设置
# 数据缓冲区
innodb_buffer_pool_size=2G
## 日志方面设置
# 事务日志大小
#innodb_log_file_size = 256M
# 日志缓冲区大小
innodb_log_buffer_size = 4M
# 事务在内存中的缓冲
#innodb_log_buffer_size = 3M
# 主库保持系统默认, 事务立即写入磁盘, 不会丢失任何一个事务
innodb_flush_log_at_trx_commit = 1
# mysql 的数据文件设置, 初始100, 以10M 自动扩展
innodb_data_file_path = ibdata1:10M:autoextend
# 为提高性能, MySQL可以以循环方式将日志文件写到多个文件
#innodb_log_files_in_group = 3
##其他设置
# 如果库里的表特别多的情况,请增加此值
innodb_open_files = 800
# 为每个 InnoDB 表分配单独的表空间
innodb_file_per_table = 1
# InnoDB 使用后台线程处理数据页上写 I/O(输入)请求的数量
innodb_write_io_threads = 8
# InnoDB 使用后台线程处理数据页上读 I/O(输出)请求的数量
innodb_read_io_threads = 8
# 启用单独的线程来回收无用的数据
innodb_purge_threads = 1
# 脏数据刷入磁盘(先保持系统默认, swap 过多使用时, 调小此值, 调小后, 与磁盘交互增多, 性能降低)
# innodb_max_dirty_pages_pct = 90
# 事务等待获取资源等待的最长时间
innodb_lock_wait_timeout = 120
# 开启 InnoDB 严格检查模式, 不警告, 直接报错
innodb_strict_mode=1
# 允许列索引最大达到3072
#innodb_large_prefix = on
[mysqldump]
# 开启快速导出
quick
default-character-set = utf8mb4
max_allowed_packet = 256M
[mysql]
# 开启 tab 补全
auto-rehash
default-character-set = utf8mb4
mysql初始化
chown mysql.mysql -R /data/app/mysql8
初始化数据库
/data/app/mysql8/install/bin/mysqld --defaults-file=/data/app/mysql8/etc/my.cnf --initialize --user=mysql > /data/app/mysql8/etc/mysql_install.log 2>&1
查看初始密码
mysql_passwd_init=`cat /data/app/mysql8/etc/mysql_install.log | grep password |awk '{print $NF}'`
cat $mysql_passwd_init
启动mysql
/data/app/mysql8/install/bin/mysqld_safe --defaults-file=/data/app/mysql8/etc/my.cnf --user=mysql &
修改初始密码
/data/app/mysql8/install/bin/mysqladmin -u root -hlocalhost -P"61800" -p"${mysql_passwd_init}" password "CQ12345678"
关闭mysql
/data/app/mysql8/install/bin/mysqladmin -uroot -p"CQ12345678" -S /data/app/mysql8/etc/mysql.sock shutdown
设置文件权限
chown -R mysql:mysql -R /data/app/mysql8
开机自启动mysql服务
echo "添加Mysql8开机自启动脚本" >> /etc/rc.local
echo "nohup /data/app/mysql8/install/bin/mysqld_safe --defaults-file=/data/app/mysql8/etc/my.cnf --user=mysql > /dev/null 2>&1 &">> /etc/rc.local
#启用rc-local
systemctl enable rc-local
systemctl start rc-local
chmod +x /etc/rc.d/rc.local
开启防火墙
firewall-cmd --zone=public --add-port=61800/tcp --permanent
firewall-cmd --reload
# 查看所有端口
firewall-cmd --zone=public --list-ports
创建管理员账号
创建一个名字star账号,密码为 PASs5566a ,管理员权限的账号
进入mysql
/data/app/mysql8/install/bin/mysql -u root -h localhost -P61800 -pCQ12345678
#-- 1. 创建用户(支持本地和远程登录)
# CREATE USER 'star'@'%' IDENTIFIED BY 'PASs5566a';
#-- 2. 授予所有权限(包括所有数据库 + 所有操作)
# GRANT ALL PRIVILEGES ON *.* TO 'star'@'%' WITH GRANT OPTION;
#-- 3. 立即刷新权限
# FLUSH PRIVILEGES;
最后
以上就是Rocky Linux 9系统上从源码编译安装了MySQL 8。这种方式不仅为您提供了高度定制化的数据库环境,更让您对整个系统的运行机制有了更深入的理解和掌控。在生产环境中,源码编译的MySQL将为您的应用提供更稳定、更高效的后端支持。
写文不易,如果你都看到了这里,请点个赞和在看,分享给更多的朋友;也别忘了关注星哥玩云!这里有满满的干货分享,还有轻松有趣的技术交流~点个赞、分享给身边的小伙伴,一起成长,一起玩转技术世界吧!
相关推荐
- 快速上手maven
-
Maven的作用在开发过程中需要用到各种各样的jar包,查找和下载这些jar包是件费时费力的事,特别是英文官方网站,可以将Maven看成一个整合了所有开源jar包的合集,我们需要jar包只需要从Mav...
- Windows系统——配置java环境变量
-
怎么配置java环境变量呢?首先是安装好jdk然后我的电脑右键选择属性然后选择左侧高级系统设置高级然后点环境变量然后在用户变量或系统变量中配置,用户变量指的是只有当前用户可用,系统变量指的是系统中...
- ollama本地部署更改默认C盘,Windows配置环境变量方法
-
ollama是一个大语言模型(LLM——LargeLanguageModel),本地电脑安装网上也要很多教程,看上去非常简单,一直下一步,然后直接就可以使用了。但是我在实操的时候并不是这样,安装完...
- # Windows 环境变量 Path 显示样式更改
-
#怎样学习Java##Windows环境变量Path显示样式更改##1、传统Path环境变量显示:```---》键盘上按【WIN+I】打开系统【设置】---》依次点击---》【系统...
- 如何在Windows中创建用户和系统环境变量
-
在Windows中创建环境变量之前您应该了解的事情在按照本指南中所示的任何步骤创建指向文件夹、文件或其他任何内容的用户和系统变量之前,您应该了解两件事。第一个也是最重要的一个是了解什么是环境变量。...
- Windows 中的环境变量是什么?
-
Windows中的环境变量是什么?那么,Windows中的环境变量是什么?简而言之,环境变量是描述应用程序和程序运行环境的变量。所有类型的程序都使用环境变量来回答以下问题:我安装的计算机的名称是什么...
- 【Python程序开发系列】谈一谈Windows环境变量:系统和用户变量
-
这是我的第350篇原创文章。一、引言环境变量(environmentvariables)一般是指在操作系统中用来指定操作系统运行环境的一些参数,如:临时文件夹位置和系统文件夹位置等。环境变量是在操作...
- 系统小技巧:还原Windows10路径环境变量
-
有时,我们在Windows10的“运行”窗口中执行一些命令或运行一些程序,这时即便没有指定程序的具体路径,只输入程序的名称(如notepad.exe),便可以迅速调用成功。这是因为Windows默认...
- Windows10系统的“环境变量”在哪里呢?
-
当我们在操作系统是Windows10的电脑里安装了一些软件,要通过配置环境变量才能使用软件时,在哪里能找到“环境变量”窗口呢?可以按照下面的步骤找到“环境变量”。说明:下面的步骤和截图是在Window...
- 系统小技巧:彻底弄懂Windows 10环境变量
-
每当我们进行系统清理时,清理软件总能自动找到Windows的临时文件夹之所在,然后加以清理,即便是我们重定向了TEMP目录也是如此。究其原因,是因为清理软件会根据TEMP环境变量来判断现有临时文件夹的...
- MySQL 5.7 新特性大全和未来展望
-
本文转自微信公众号:高可用架构作者:杨尚刚引用美图公司数据库高级DBA,负责美图后端数据存储平台建设和架构设计。前新浪高级数据库工程师,负责新浪微博核心数据库架构改造优化,以及数据库相关的服务器存...
- MySQL系列-源码编译安装(v8.0.25)
-
一、前言生产环境建议使用二进制安装法,其优点是部署简单、快速、方便,并且相对"yum/rpm安装"方法能更方便地自定义文件存放的目录结构,方便用脚本批量部署,方便日后运维管理。在生产...
- MySQL如何实时同步数据到ES?试试这款阿里开源的神器!
-
前几天在网上冲浪的时候发现了一个比较成熟的开源中间件——Canal。在了解了它的工作原理和使用场景后,顿时产生了浓厚的兴趣。今天,就让我们跟随我的脚步,一起来揭开它神秘的面纱吧。简介canal翻译为...
- 技术老兵十年专攻MySQL:编写了763页核心总结,90%MySQL问题全解
-
MySQL是开放源码的关系数据库管理系统,由于性能高、成本低、可靠性好,成为现在最流行的开源数据库。MySQL学习指南笔记领取方式:关注、转发后私信小编【111】即可免费获得《MySQL进阶笔记》的...
- Mysql和Hive之间通过Sqoop进行数据同步
-
文章回顾理论大数据框架原理简介大数据发展历程及技术选型实践搭建大数据运行环境之一搭建大数据运行环境之二本地MAC环境配置CPU数和内存大小查看CPU数sysctl machdep.cpu...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
系统C盘清理:微信PC端文件清理,扩大C盘可用空间步骤
-
飞牛OS入门安装遇到问题,如何解决?
-
10款高性能NAS丨双十一必看,轻松搞定虚拟机、Docker、软路由
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)