Linux 环境下安装 MySQL 8.0.34 二进制 详细教程 附docker+k8s启动

文章目录

  • Linux 环境下安装 MySQL 8.0(二进制)详细教程
  • 准备工作
    • 安装依赖包
  • 下载并解压 MySQL
    • 下载 MySQL 二进制包
    • 解压 MySQL
    • 移动目录并创建 MySQL 用户
  • 配置 MySQL
    • 配置数据目录与日志目录
    • 编辑配置文件 /etc/my.cnf
  • 初始化 MySQL 数据库
  • 配置启动脚本与环境变量
    • 配置系统启动脚本
    • 配置环境变量
  • 启动 MySQL 服务
  • 登录 MySQL 并修改 root 密码
    • 使用初始化密码登录
    • 修改 root 用户密码
    • 允许远程访问(可选)
  • 测试远程连接
  • 总结
  • docker-compose.yml
  • k8s
    • configmap
    • deployment
    • svc


Linux 环境下安装 MySQL 8.0(二进制)详细教程

在生产环境或部分场景下,我们通常不会直接使用 yumapt 安装 MySQL,而是通过官方提供的二进制 tar 包进行安装。本文以 CentOS 7.x 为例,详细记录 MySQL 8.0.34 的安装步骤及配置方法。


准备工作

安装依赖包

MySQL 运行需要依赖一些系统库,因此需要提前安装:

yum -y install tar            # 安装 tar 解压工具
yum -y install libaio         # 异步 I/O 库
yum -y install numactl        # NUMA 支持库

下载并解压 MySQL

下载 MySQL 二进制包

可以到 MySQL 官方下载页面 获取相应的版本。本文以 mysql-8.0.34-linux-glibc2.12-x86_64.tar.xz 为例。
在这里插入图片描述

解压 MySQL

tar xf mysql-8.0.34-linux-glibc2.12-x86_64.tar.xz

移动目录并创建 MySQL 用户

创建 MySQL 专用的用户和用户组:

groupadd mysql
useradd -g mysql mysql

将解压后的文件移动至 /usr/local/mysql

mkdir -p /usr/local/mysql
mv mysql-8.0.34-linux-glibc2.12-x86_64/* /usr/local/mysql/

配置 MySQL

配置数据目录与日志目录

创建 MySQL 数据和日志存储目录,并授权给 mysql 用户:

mkdir -p /data/app/mysql/
chown -R mysql:mysql /data/app/mysql/mkdir -p /usr/local/mysql/log
touch /usr/local/mysql/log/mysql_error.log
chown -R mysql:mysql /usr/local/mysql

编辑配置文件 /etc/my.cnf

根据实际需求编写配置文件,例如:

[mysql]
# MySQL客户端默认字符集
default-character-set=utf8mb4
socket=/tmp/mysql.sock[mysqld]
skip_ssl
skip_name_resolve# 端口与时区
port=3306
default_time_zone='+08:00'# 表名大小写(Linux默认区分大小写,若跨平台建议设置为1)
lower_case_table_names=1# 二进制日志
log_bin=master-bin
server_id=10
binlog_format=ROW
sync_binlog=1
expire_logs_days=10
max_binlog_size=500M# 目录
basedir=/usr/local/mysql
datadir=/data/app/mysql
socket=/tmp/mysql.sock# 字符集
character-set-server=utf8mb4
collation-server=utf8mb4_general_ci# 存储引擎
default_storage_engine=INNODB
max_allowed_packet=64M
key_buffer_size=32M# InnoDB优化
innodb_buffer_pool_size=2G          # (2C4G改成1G,8C16G改成8G)
innodb_buffer_pool_instances=2
innodb_buffer_pool_dump_at_shutdown=1
innodb_buffer_pool_load_at_startup=1
innodb_flush_method=O_DIRECT
innodb_log_file_size=512M           # (2C4G可改256M,8C16G可改2G)
innodb_log_buffer_size=64M
innodb_lock_wait_timeout=50
innodb_io_capacity=2000
innodb_io_capacity_max=4000# 慢查询日志
slow_query_log=1
slow_query_log_file=/usr/local/mysql/log/master.slow
long_query_time=2# 错误日志
log_error=/usr/local/mysql/log/mysql_error.log# SQL模式(MySQL8推荐严格模式)
sql_mode=STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION,NO_ZERO_DATE,NO_ZERO_IN_DATE,ONLY_FULL_GROUP_BY# GTID复制
gtid_mode=ON
enforce_gtid_consistency=TRUE
log_slave_updates=ON
binlog_checksum=NONE# 连接与超时
max_connections=500                # (2C4G改200,8C16G可到2000)
max_connect_errors=1000
wait_timeout=120
interactive_timeout=120# Performance Schema
performance_schema=ON# 线程池(需要企业版/社区版Percona才支持,官方MySQL可忽略)
# thread_handling=pool-of-threads

初始化 MySQL 数据库

执行初始化操作,生成数据文件和 root 初始密码:

cd /usr/local/mysql/bin/
./mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/data/app/mysql

初始化完成后,可通过以下命令查看初始 root 密码:

cat ../log/mysql_error.log

日志中会出现类似以下内容:

A temporary password is generated for root@localhost: y_U(lb-D/3Lj

请记下该密码,用于首次登录。


配置启动脚本与环境变量

配置系统启动脚本

复制官方提供的启动脚本并赋予执行权限:

cp /usr/local/mysql/support-files/mysql.server /etc/rc.d/init.d/mysqld
chmod +x /etc/rc.d/init.d/mysqld

如有需要,可编辑 /etc/rc.d/init.d/mysqld 中的 basedirdatadir

配置环境变量

为了方便直接使用 mysql 命令,将 MySQL 的 bin 目录加入系统 PATH:

echo 'export PATH=$PATH:/usr/local/mysql/bin/' >> /etc/profile
source /etc/profile

启动 MySQL 服务

检查 MySQL 状态并启动服务:

/etc/rc.d/init.d/mysqld status
/etc/rc.d/init.d/mysqld start

登录 MySQL 并修改 root 密码

使用初始化密码登录

mysql -u root -p'y_U(lb-D/3Lj'

注意:如果出现 libtinfo.so.5 缺失,可通过以下方法解决:

[root@test ~]# mysql -uroot -p
mysql: error while loading shared libraries: libtinfo.so.5: cannot open shared object file: No such file or directory
[root@test ~]# find / -name libtinfo.so*
/usr/lib64/libtinfo.so.6
/usr/lib64/libtinfo.so.6.2
[root@test ~]# ln -s /usr/lib64/libtinfo.so.6.2 /usr/lib64/libtinfo.so.5
[root@test ~]# 
find / -name libtinfo.so*
ln -s /usr/lib64/libtinfo.so.6.2 /usr/lib64/libtinfo.so.5

修改 root 用户密码

进入 MySQL 后执行以下语句:

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123.com';
FLUSH PRIVILEGES;

允许远程访问(可选)

如果需要远程登录,可将 root 用户的 host 设置为 %

USE mysql;
UPDATE user SET host='%' WHERE user='root';
FLUSH PRIVILEGES;

测试远程连接

mysql -u root -p'123.com' -h <server_ip> -P3306

如果连接正常,说明 MySQL 已安装并配置成功。


总结

以上就是在 Linux 下通过 tar 包安装 MySQL 8.0 的完整步骤。总结下关键点:

  • 选择二进制包安装的原因:可控性更强、版本灵活、适合生产环境定制化需求。
  • 注意初始化密码:安装后第一次必须使用日志中的临时密码。
  • 安全建议:不要直接暴露 root 用户远程访问,建议新建具有相应权限的业务账户。

docker-compose.yml

注: 官方镜像

version: '3.8'services:mysql:image: mysql:8.0.34container_name: mysql-testrestart: alwaysenvironment:MYSQL_ROOT_PASSWORD: "123.com"  # 初始化 root 密码(需要 Dockerfile 中支持此变量)ports:- "3307:3306"                  # 宿主机端口映射volumes:- ./data:/var/lib/mysql        # 数据持久化到当前目录- ./my.cnf:/etc/my.cnf         # 自定义 my.cnf(可选)networks:- mysql-netnetworks:mysql-net:driver: bridge

my.cnf

[mysqld]
# 基本配置
user=mysql
port=3306
basedir=/usr/local/mysql
datadir=/var/lib/mysql
socket=/var/run/mysqld/mysqld.sock# 字符集
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci# 日志相关
slow_query_log=1
slow_query_log_file=/var/lib/mysql/mysql-slow.log
long_query_time=2# 缓存大小示例
innodb_buffer_pool_size=256M# 其他根据需求定制

k8s

configmap

apiVersion: v1
kind: ConfigMap
metadata:name: mysql-confignamespace: test
data:my.cnf: |[mysqld]character-set-server=utf8mb4collation-server=utf8mb4_unicode_cislow_query_log=1slow_query_log_file=/var/lib/mysql/mysql-slow.loglong_query_time=2log-error=/var/lib/mysql/mysql-error.logmax_connections=1000max_connect_errors=1000wait_timeout=28800# 时区设置default_time_zone='+08:00'

deployment

apiVersion: apps/v1
kind: Deployment
metadata:name: mysqlnamespace: test
spec:replicas: 1selector:matchLabels:app: mysqltemplate:metadata:labels:app: mysqlspec:containers:- name: mysqlimage: harbor-ioscar.cbf.com/hawk/mysql:8.0.34env:- name: MYSQL_ROOT_PASSWORDvalue: "123.com"ports:- containerPort: 3306volumeMounts:- name: mysql-datamountPath: /var/lib/mysql- name: mysql-configmountPath: /etc/mysql/conf.dreadOnly: truevolumes:- name: mysql-datahostPath:path: /data/mysql/testtype: DirectoryOrCreate- name: mysql-configconfigMap:name: mysql-config

svc

apiVersion: v1
kind: Service
metadata:name: mysqlnamespace: test
spec:selector:app: mysqlports:- protocol: TCPport: 3306targetPort: 3306nodePort: 30505 # 可以换成自己的端口type: NodePort

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/90276.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/90276.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HTML ISO-8859-1: 完全解析

HTML ISO-8859-1: 完全解析 引言 ISO-8859-1,又称为 Latin-1,是一种广泛使用的字符编码标准,特别是在HTML文档中。本文将详细介绍ISO-8859-1编码的特点、应用场景以及如何在使用HTML时正确地使用ISO-8859-1编码。 ISO-8859-1编码概述 定义 ISO-8859-1编码是一种单字节编…

c++学习第3篇编辑器——centos7.9.2009系统离线安装clion软件并成功调试c++程序

远程linux服务器安装clion0 前提2个&#xff1a;1 下载CLion-2021.1.1.tar.gz安装包2 上传到linux系统并解压3 修改linux系统里的/etc/ssh/sshd_config文件中的X11UseLocalhost 注释去掉并设为no4 安装xauth5 安装MobaXterm软件并使用ssh组件打开clion5.1 如果打不开clion,报错…

20250722解决在Ubuntu 24.04.2下编译RD-RK3588开发板的Android13出现找不到lz4的问题

20250722解决在Ubuntu 24.04.2下编译RD-RK3588开发板的Android13出现找不到lz4的问题 2025/7/22 15:21缘起&#xff1a;在Ubuntu 24.04.2下编译RD-RK3588开发板的Android13。 报错&#xff1a;/bin/sh: 1: lz4: not found为了简单起见&#xff0c;直接在 荣品的技术支持QQ群的 …

加载用户设置时遇到错误找到一个带有无效“icon“的配置文件。将该配置文件默认为无图标。确保设置“icon“时,该值是图像的有效文件路径“

"C:\Users\Yourname\AppData\Local\Packages\Microsoft.WindowsTerminal_8wekyb3d8bbwe\LocalState\settings.json 修改所有icon字段位none 如&#xff1a;{"guid": "{bf61c995-08cc-4a56-b781-5dba411ef19c}","hidden": false,"icon&…

如何提升连带消费?从新零售“人-货-场”模型拆解

目录 一、分析背景 二、新零售分析思路和分析方法 1.具体分析思路 2.分析方法 三、新零售“人-货-场”分析的实操步骤 1.数据收集 2.数据处理 3.图表制作 四、总结 想让线上引来的顾客&#xff0c;在店里多买几件&#xff1f; 连带消费可是实体店赚钱的“秘密武器”&a…

Java异常处理核心原理与最佳实践

Java异常处理核心原理与最佳实践 场景&#xff1a; 你开发的文件处理工具在读取用户上传的文件时突然崩溃&#xff0c;控制台抛出FileNotFoundException。用户的操作被中断&#xff0c;数据丢失。这种糟糕的体验正是异常处理机制要解决的核心问题——如何在程序出错时优雅地恢复…

Ubuntu 安装 Odoo 17 详细教程

Ubuntu 安装 Odoo 17 详细教程 本教程将指导您在 Ubuntu 系统上从源代码安装 Odoo 17。Odoo 是一款功能强大的开源 ERP 和 CRM 软件套件。本教程适用于希望自行配置和管理 Odoo 环境的用户&#xff0c;尤其适合开发者和系统管理员。 教程概述 本教程将涵盖以下步骤&#xff…

鲲鹏·卓识系列2.45G传感器型有源标签:以国产化技术重塑安全监测与人员管理新标准

标题&#xff1a;鲲鹏卓识系列2.45G传感器型有源标签&#xff1a;以国产化技术重塑安全监测与人员管理新标准 随着工业4.0和智慧城市建设的加速推进&#xff0c;安全生产、环境监测和人员管理成为各行业的核心需求。在军事、工业、仓储、能源等领域&#xff0c;温湿度、烟雾、油…

腾讯云推出CodeBuddy:革新AI全栈开发体验

文章目录一、前言二、安装流程三、CodeBuddy 核心功能3.1 AI辅助开发3.2 Coding Design Chat 三大模式3.3 Boost Prompt3.4 Figma 集成3.5 Componen 控件库3.6 Config MCP3.7 Upload Images 图片上传和管理3.8 Preview功能3.9 Deploy 一键部署3.10 项目展示 | MCP生成小红书卡片…

龙虎榜——20250723

上证指数放量收上影线&#xff0c;未站上3600点&#xff0c;个股下跌明显多于上涨&#xff0c;指数有调整需求&#xff0c;注意短线风险。深证指数较昨日缩量收阴线&#xff0c;依然在5日均线上方运行&#xff0c;打到前期平台高点有震荡调整需求&#xff0c;注意风险。2025年7…

SpringBoot06-@ConfigurationProperties注解

ConfigurationProperties注解用于将配置文件&#xff08;application.properties 或 application.yml&#xff09;中的配置值&#xff0c;自动绑定到 Java Bean 对象上。1-1、基本用途比如我们在 application.yml 中有这样一段配置&#xff1a;app:name: myAppversion: 1.0.0au…

oracle里面concat函数用法,oracle wm_concat函数用法-

wmsys.wm_concat函数&#xff0c;它的作用是以’,’链接字符 例子如下&#xff1a; SQL> create table idtable (id number,name varchar2(30)); Table created SQL> insert into idtable values(10,’ab’); 1 row inserted SQL> insert into idtable values(10,’bc…

C++中的list(2)简单复现list中的关键逻辑

C中的list&#xff08;2&#xff09;//简单复现list中的关键逻辑 前言 这一节的主要内容就是&#xff1a;简单复现list中的关键逻辑。同样的&#xff0c;我们这一节也是先粗略的看一眼源码&#xff0c;结合源码&#xff0c;边理解边复现。源码我已经上传到gitee&#xff0c;网…

Linux——System V 共享内存 IPC

文章目录一、共享内存的原理二、信道的建立1.创建共享内存1.key的作用2.key的选取3.shmid的作用4.key和shmid的区别5.内存设定的特性6.shmflg的设定2.绑定共享内存3.代码示例三、利用共享内存通信1.通信2.解除绑定3.销毁共享内存1.命令行销毁2.程序中销毁四、共享内存的生命周期…

Python 程序设计讲义(9):Python 的基本数据类型——复数

Python 程序设计讲义&#xff08;9&#xff09;&#xff1a;Python 的基本数据类型——复数 复数与数学中的复数概念类似。在 Python 中&#xff0c;复数表示为 abj&#xff0c;其中&#xff1a;a为实数部分&#xff0c;b为虚数部分&#xff0c;j称为虚数单位。复数必须包含虚数…

leetcode_121 买卖股票的最佳时期

1. 题意 有一个股价变化图&#xff0c;你可以在一天买入&#xff0c;在未来一天卖出。 求通过这样一次操作的最大获利。 2. 题解 2.1 枚举 直接枚举&#xff0c;买入卖出的时间&#xff0c;肯定会超时啦~ 时间复杂度为O(n2)O(n^2)O(n2) 空间复杂度为O(1)O(1)O(1) class …

ToBToC的定义与区别

B 端和 C 端主要是从产品所面向的用户群体角度来区分的&#xff0c;B 端指的是企业用户&#xff08;Business&#xff09;&#xff0c;C 端指的是个人消费者&#xff08;Consumer&#xff09;&#xff0c;它们在多个方面存在明显区别&#xff0c;具体如下&#xff1a;用户特征B…

Python 程序设计讲义(8):Python 的基本数据类型——浮点数

Python 程序设计讲义&#xff08;8&#xff09;&#xff1a;Python 的基本数据类型——浮点数 目录Python 程序设计讲义&#xff08;8&#xff09;&#xff1a;Python 的基本数据类型——浮点数一、浮点数的表示形式1、小数形式2、指数形式二、浮点数的精确度浮点数也称小数&am…

MCP客户端架构与实施

前言:从模型到生产力 — MCP的战略价值 在过去的一年里,我们团队见证了大型语言模型(LLM)从技术奇迹向企业核心生产力工具的演变。然而,一个孤立的LLM无法解决实际的业务问题。真正的价值释放,源于将模型的认知能力与企业现有的数据、API及工作流进行无缝、安全、可扩展…

白盒测试核心覆盖率标准详解文档

白盒测试核心覆盖率标准详解文档 1. 什么是白盒测试与覆盖率&#xff1f; 白盒测试&#xff08;White-box Testing&#xff09;&#xff0c;又称结构测试或逻辑驱动测试&#xff0c;是一种测试方法&#xff0c;测试人员能够访问并了解被测软件的内部结构、代码和实现逻辑。测试…