Ubuntu 22.04 安装 MySQL 8.0 完整步骤文档

1、安装

1.1、下载
cd /usr/local/

/usr/local/ 下执行,下载资源包,可以本地下载上传

wget https://downloads.mysql.com/archives/get/p/23/file/mysql-8.0.32-linux-glibc2.12-x86_64.tar.xz
1.2、解压安装
tar -Jxvf mysql-8.0.32-linux-glibc2.12-x86_64.tar.xz

2、配置工作

2.1、基本设置
2.1.1、文件夹重命名

重命名 MySQL 文件夹

mv mysql-8.0.32-linux-glibc2.12-x86_64 mysql8
2.1.2、PATH 变量
vim /etc/profile# 在最下面追加
export PATH=$PATH:/usr/local/mysql8/bin# 重载环境变量
source /etc/profile
2.1.3、确认安装
mysql --version

如果有报错:

img

Ubuntu 24.04 通常已经安装了 libtinfo.so.6,我们手动为旧程序创建一个兼容链接:

sudo ln -s /lib/x86_64-linux-gnu/libtinfo.so.6 /lib/x86_64-linux-gnu/libtinfo.so.5

这个命令会让系统中的 libtinfo.so.5 “伪装”为 libtinfo.so.6,大多数老程序会正常运行。

⚠️ 如果你不确定 libtinfo.so.6 是否存在,可以先执行:

ls /lib/x86_64-linux-gnu/libtinfo*

img

2.2、创建用户组、用户

注:需要进入 /usr/local

创建用户组groupadd

groupadd mysql

创建用户useradd-r 创建系统用户,-g 指定用户组)

useradd -r -g mysql mysql
2.3、数据目录

创建目录

mkdir -p /data/mysql8_data

赋予权限

更改属主和数组

chown -R mysql:mysql /data/mysql8_data

更改模式 只有具有 root 权限的用户和 mysql 用户可以读取、写入和执行

chmod -R 700 /data/mysql8_data

3、初始化 & 启动

3.1、配置文件

/usr/local/etc/ 下创建 my.cnf 配置文件用于初始化 MySQL 数据库

vim /usr/local/etc/my.cnf
[mysql]
# 默认字符集
default-character-set=utf8mb4[client]
# 客户端使用的端口号
port=3306
# 客户端连接的 socket 路径
socket=/tmp/mysql.sock[mysqld]
# 服务端使用的端口号
port=3306
# 服务器 ID
server-id=3306
# MySQL 运行用户
user=mysql
# 日志时间系统时间
log_timestamps=SYSTEM
# 默认时区东八区
default-time_zone='+8:00'
# 服务器连接的 socket 路径
socket=/tmp/mysql.sock
# MySQL 安装目录
basedir=/usr/local/mysql8
# 数据存放目录
datadir=/data/mysql8_data/mysql
# 开启二进制日志功能
log-bin=/data/mysql8_data/mysql/mysql-bin
# InnoDB 数据文件存放目录
innodb_data_home_dir=/data/mysql8_data/mysql
# InnoDB 日志文件存放目录
innodb_log_group_home_dir=/data/mysql8_data/mysql
# MySQL 错误日志文件路径
log-error=/data/mysql8_data/mysql/mysql.log
# 存放 MySQL 进程 ID 的文件路径
pid-file=/data/mysql8_data/mysql/mysql.pid
# 表名大小写不敏感
lower_case_table_names=1
# 服务端字符集
character-set-server=utf8mb4
# SQL 模式设置
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
# 自动提交所有事务
autocommit=1
# 跳过排它锁定
skip-external-locking
# 键缓存大小
key_buffer_size=256M
# 允许的最大数据包大小
max_allowed_packet=1M
# 表缓存
table_open_cache=1024
# 排序缓存大小
sort_buffer_size=4M
# 网络缓冲区长度
net_buffer_length=8K
# 读取缓冲区大小
read_buffer_size=4M
# 随机读取缓冲区大小
read_rnd_buffer_size=512K
# MyISAM 排序缓冲区大小
myisam_sort_buffer_size=64M
# 线程缓存大小
thread_cache_size=128
# 临时表大小
tmp_table_size=128M
# 启用显式默认时间戳
explicit_defaults_for_timestamp=true
# 最大连接数
max_connections=500
# 连接错误最大数量
max_connect_errors=100
# 打开文件限制
open_files_limit=65535
# 二进制日志格式
binlog_format=mixed
# 二进制日志过期时间(秒)
binlog_expire_logs_seconds=864000
# 创建表时使用的默认存储引擎
default_storage_engine=InnoDB
# InnoDB 数据文件路径设置
innodb_data_file_path=ibdata1:10M:autoextend
# InnoDB 缓冲池大小
innodb_buffer_pool_size=1024M
# InnoDB 日志文件大小
innodb_log_file_size=256M
# InnoDB 日志缓冲区大小
innodb_log_buffer_size=8M
# InnoDB 每次提交时刷新日志
innodb_flush_log_at_trx_commit=1
# InnoDB 加锁等待超时时间(秒)
innodb_lock_wait_timeout=50
# 事务隔离级别为读已提交
transaction-isolation=READ-COMMITTED[mysqldump]
# 快速导出数据
quick
# 允许的最大数据包大小
max_allowed_packet=16M[myisamchk]
# 键缓存大小
key_buffer_size=256M
# 排序缓冲区大小
sort_buffer_size=4M
# 读取缓冲区大小
read_buffer=2M
# 写入缓冲区大小
write_buffer=2M[mysqlhotcopy]
# 交互式超时时间
interactive-timeout
3.2、初始化

需要进入 /usr/local/mysql8/bin,若添加了 PATH 变量可忽略。

初始化命令:注意文件夹名称。

–defaults-file:指定配置文件(要放在–initialize 前面)

–user: 指定用户

–basedir:指定安装目录

–datadir:指定初始化数据目录

–intialize-insecure:初始化无密码(否则生成随机密码)

mysqld --defaults-file=/usr/local/etc/my.cnf --basedir=/usr/local/mysql8 --datadir=/data/mysql8_data/mysql --user=mysql --initialize-insecure

可能会碰到问题

img

为兼容老程序,创建软链接把 libaio.so.1 指向实际存在的 libaio.so.1t64 文件

sudo ln -s /usr/lib/x86_64-linux-gnu/libaio.so.1t64 /usr/lib/x86_64-linux-gnu/libaio.so.1

然后,把这个链接再放到 MySQL 期望的路径:

sudo ln -s /usr/lib/x86_64-linux-gnu/libaio.so.1 /lib/x86_64-linux-gnu/libaio.so.1

最后更新缓存:

sudo ldconfig

之后再尝试启动 MySQL:

mysqld --defaults-file=/usr/local/etc/my.cnf --basedir=/usr/local/mysql8 --datadir=/data/mysql8_data/mysql --user=mysql --initialize-insecure

这样做是利用 libaio.so.1t64 来代替旧的 libaio.so.1,适配 Ubuntu 24.04 这种新架构。

3.3、启动 MySQL

查看 MySQL 的 /bin 下是否包含 mysqld_safe用于后台安全启动 MySQL

3.3.1、启动服务

安全后台启动 MySQL

# 完整命令
/usr/local/mysql8/bin/mysqld_safe --defaults-file=/usr/local/etc/my.cnf &
# 若添加了PATH变量,可省略如下
mysqld_safe --defaults-file=/usr/local/etc/my.cnf &

确认启动:第二条即 MySQL 服务。

ps -ef|grep mysql
3.3.2、登录
mysql -u root --skip-password
3.4、修改密码
# 修改密码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';# 设置密码永不过期(本地)
alter user 'root'@'localhost' password expire never;# 刷新权限
FLUSH PRIVILEGES;

4、远程连接 MySQL

4.1、创建远程连接用户
-- 选择 mysql 数据库,查看当前用户
USE mysql;--  host 字段表示可访问当前数据库的主机,目前仅本地可访问。
SELECT user,host,plugin,authentication_string FROM user;-- 创建用户
CREATE user 'root'@'%';-- 设置首次密码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密码';-- 授权用户所有权限
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%';-- 设置密码永不过期(远程)
alter user 'root'@'%' password expire never;-- 刷新权限
FLUSH PRIVILEGES;

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

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

相关文章

Docker,其他机器下载镜像并copy到目标机器导入docker镜像

Docker,其他机器下载镜像并copy到目标机器导入docker镜像源机器 【下载镜像】目标机器slave1 【无法下载镜像】步骤 1:在网络正常的机器(cg)上下载镜像,导出镜像到指定路径# 1. 下载镜像docker pull ubuntu:20.04# 2.…

基于现代R语言【Tidyverse、Tidymodel】的机器学习方法与案例分析

机器学习已经成为继理论、实验和数值计算之后的科研“第四范式”,是发现新规律,总结和分析实验结果的利器。机器学习涉及的理论和方法繁多,编程相当复杂,一直是阻碍机器学习大范围应用的主要困难之一,由此诞生了Python…

如何将 git 远程 URL 从 https 更改为 ssh

在项目开发中,使用 SSH 连接 Git 仓库可以提高安全性和便利性。本文将指导你如何将 Git 远程 URL 从 HTTPS 更改为 SSH。操作指南步骤 1: 查看当前远程 URL首先,确认当前的远程 URL 使用的是 https。打开终端并输入以下命令:git remote -v如&…

PyCharm 高效入门指南(核心模块详解二)

四、生产力工具集成PyCharm 不仅仅是 Python 编辑器,更是集成了多种开发工具的综合平台。通过内置的生产力工具,开发者可以在一个界面内完成数据库操作、科学计算、远程开发和测试等全流程工作,避免工具切换带来的效率损耗。4.1 数据库工具链…

WebkitSpeechRecognition 语音识别

JavaScript WebkitSpeechRecognition:使用语音识别技术增强 Web 应用程序 WebkitSpeechRecognition 是一种 JavaScript API,它可以让您的 Web 应用程序使用语音识别技术。使用 WebkitSpeechRecognition,您可以让用户通过说话来与您的 Web 应用程序进行交互,这可以使您的应…

CUDA C++核心库(CCCL)

文章目录CUDA C核心库(CCCL)核心库介绍CUDA C 开发工具的层级范围各层级工具的具体内容Thrust自动内存管理类型安全自定义分配器(页锁定内存)高级API替代底层操作thrust::transform基本使用几种执行策略iteratorload_cs高效索引md…

MySQL InnoDB存储引擎深度解析:从原理到优化

InnoDB的优势InnoDB之所以成为众多应用的首选,主要得益于以下几个显著优势:事务支持:InnoDB是MySQL中唯一支持ACID(原子性、一致性、隔离性、持久性)事务的存储引擎。它通过日志和锁机制确保事务的完整性,这…

LLM评测框架Ragas:Natural Language Comparison指标(解决了Ollama推理框架不支持的问题)

Factural Correctness Factural Correctness是事实正确性是评价LLM生成的反馈和reference的事实正确性。该指标用于确定生成的响应与参考文献的一致程度。Factural Correctness取值在0到1之间,越接近于1结果越好。 为了衡量回应和参考文献之间的一致性,该指标使用 LLM 首先将…

HTTP 协议常见字段(请求头/响应头)

HTTP(HyperText Transfer Protocol)协议通过 请求头(Request Headers) 和 响应头(Response Headers) 传递元数据。以下是 最常见的 HTTP 字段 及其作用:1. 通用字段(请求和响应均可使…

期货配资软件开发注意事项?

期货配资软件开发 期货配资软件开发涉及多个核心模块,包括资金管理、风险控制、交易接口、用户权限管理等。此类系统需符合金融监管要求,确保资金安全与数据合规。开发过程中需优先考虑高并发、低延迟及系统稳定性。期货资管系统平台搭建方案架构设计 采…

STM32-第十节-DMA直接存储器存取

一、DMA:1.简介:DMA,直接存储区存取DMA可以提供外设和存储器或存储器与存储器见的高速数据传输,无需CPU干预。12个通道:DMA1(7个通道),DMA2(5个通道)每个通道…

服务器设置国外IP无法访问对防御攻击有用吗?

将服务器设置为仅允许国外 IP 访问,限制国内 IP 访问,确实可以在某些特定场景下提高服务器的抗攻击能力,但这并不能完全防御攻击。以下是对这种方法的分析、优缺点以及其他防御攻击的补充措施。1. 仅允许国外 IP 访问是否有用?1.1…

八大作业票(一) 动火安全作业证

动火安全作业证 执行标准:GB30871 GSDH——2200001 申报单位 申请人 作业申请时间 年 月 日 时 分 动火内容 动火方式 动火地点 动火类别 特级动火□ 一级动火□ 二级动火□ 作业负责人 监护人 动火…

NumPy库使用教学,简单详细。

NumPy 使用教学NumPy 是 Python 中用于科学计算的基础库,它提供了高性能的多维数组对象以及用于处理这些数组的工具。下面将结合多个代码文件,详细介绍 NumPy 的各种用法。1. 创建数组1.1 从列表创建数组import numpy as np# 一维数组 list1 [1,2,3,4,5…

vue3:十八、内容管理-实现行内图片的预览、审核功能

一、实现效果 实现图片的显示,大图预览;审核部分的待审核的审核功能 二、图片预览实现 1、参考官网 官网-图片预览 2、图片预览插槽设置 {row,index} 插槽中获取row行信息、index索引信息(指定行图片预览需要用到) style 设置基本样式宽width高height src 设置图片的路径…

Go后端配置文件教程

注:本文为博主,首次接触项目时的入门级配置实操在 Go 后端中,使用配置文件管理参数(如数据库连接、服务端口等)是必备技能。Viper 是 Go 生态中最流行的配置管理库。支持多种配置文件、环境变量、命令行参数等&#xf…

ubuntu24.04安装CUDA、VLLM、Pytorch等并部署Qwen3-8B-AWQ【50系显卡通用】

1. 系统更新与依赖安装 sudo apt update && sudo apt upgrade -y sudo apt install -y python3-pip python3-venv build-essential git nvidia-driver-575注:RTX 5070 Ti 推荐驱动 ≥550 版本 我是直接官网安装最新的驱动了,反正向上兼容,驱动安装教程可以参考我以…

Azure可靠性架构指南:构建云时代的高可用系统

随着企业加速拥抱数字化转型,云服务的可靠性已成为业务连续性的核心命题。Microsoft Azure凭借其"可靠性即核心"的设计理念,为企业技术决策者与架构师提供了一个可信赖的数字化底座。本文将系统解析Azure如何通过技术架构、工具链与方法论&…

linux 驱动 - v4l2 驱动框架

文章目录一、/dev/videoX1. 查询设备能力2. 获取当前视频格式3. 设置视频格式4. 申请缓冲区1) mmap 方式2) user 分配5. 查询缓冲区信息6. 将缓冲区放入队1) fill_vb2_buffer2) buf_prepare3) get_userptr4) buf_init5) attach_dmabuf 和 map_dmabuf6) start_streaming7) 总结7…

windows内核研究(驱动开发-0环与3环的通信)

驱动开发0环与3环的通信 设备对象 在之前开发窗口程序时,消息都是被封装成一个结构体(MSG),在内核开发时,消息被封装成另外一个结构体:IRP(I/O Request Package) 在窗口程序中&#…