Linux系统离线部署MySQL详细教程(带每步骤图文教程)

ops/2025/2/8 2:24:16/

1、登录官网下载对应的安装包

MySQL :: Developer Zone

2、将压缩包上传到服务器上,这里直接上传到/usr/local路径上

使用sftp工具上传到/usr/local目录上

3、解压压缩包

tar -xf mysql-8.0.39-linux-glibc2.17-x86_64.tar.xz

mysql8039linuxglibc217x86_64mysql_30">4、将mysql-8.0.39-linux-glibc2.17-x86_64目录重命名为mysql

在/usr/mysql/目录下

mv mysql-8.0.39-linux-glibc2.17-x86_64 mysql

5、创建用户组

groupadd mysql #创建用户组

useradd -r -g mysql mysql

# -r 参数表示mysql 用户是系统用户,不可用于登录系统;

# -g 将用户mysql添加到用户组mysql

mysql_50">6、分配用户组,将文件属性、组属性改为mysql

chown -R mysql /usr/local/mysql/ # 将文件的所有属性改为mysql用户

chgrp -R mysql /usr/local/mysql/ # 将组属性改为mysql

7、创建新的数据目录(也可以使用默认的数据目录,一般在/var目录下)

mkdir -p /data/mysql #创建数据目录

chown mysql:mysql -R /data/mysql# 将新目录文件的所有属性改为mysql用户

8、修改MySQL服务器配置文件

vim /etc/my.cnf

添加如下配置信息

[mysqld]

port=3306 # 设置MySQL服务监听端口,默认3306

bind-address=0.0.0.0# 设置MySQL服务器绑定的IP地址,可以设置为自己本机IP

user=mysql # 设置MySQL数据库用户

basedir=/usr/local/mysql # 数据库文件路径

datadir=/data/mysql # 数据库数据目录,存储数据库文件的路径

socket=/tmp/mysql.sock # 设置MySQL服务器使用的套接字文件路径

pid-file=/data/mysql/mysql.pid # 设置指定存放进程ID的文件

character_set_server=utf8mb4 # 设置每个连接的默认字符集

symbolic-links=0

explicit_defaults_for_timestamp=true # mysql-5.6.6丢弃了这个系统变量,版本高于5.6.6的可加上

9、初始化数据库

先切换到mysql路径,再执行初始化

cd /usr/local/mysql/bin

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

–basedir 为mysql解压目录,–datadir 为mysql数据存放目录,就是在/etc/my.cnf配置的路径

PS:此步骤可能因glibc依赖问题会报错,如报错可参考第15条的解决方法。

mysql_104">10、初始化后就可以查看mysql初始密码了

cat /data/mysql/mysql.err

mysql_110">11、加入到系统服务,启动mysql服务

cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql

PS:此步骤重启mysql服务可能会log-err文件目录不存在报错,可参考第15条的解决方法。

mysql_120">12、MySQL服务启动成功后,就可以登录到mysql数据库

/usr/local/mysql/bin/mysql -u root -p

输入刚开始初始化后查看到的初始密码,即可完成进入mysql数据库

PS:如果想直接使用mysql -u root -p 直接登录,则需要先把mysql的路径映射链接到/usr/bin目录下

ln -s /usr/local/mysql/bin/mysql /usr/bin

mysql_134">13、更改mysql数据库登录初始密码

ALTER USER ‘root’@‘localhost’ IDENTIFIED BY ‘123456’;

FLUSH PRIVILEGES; #刷新

14、完成部署

退出数据库,再次登录即可输入更改的密码,到此mysql已经部署完成,成功部署。

15、部署时可能出现的问题

1、初始化数据库报错

初始化数据库的时候报“./mysqld:/lib64/libstdc++.so.6:version ‘CXXABI 1.3.11’ not found (required by ./mysqld)”

此报错是缺少对应的libstdc++版本依赖问题,可以先查看对应的版本

strings /usr/lib64/libstdc++ |grep CXXABI

find / -name “libstdc++.so.6*”

可以看到是缺少相应的版本依赖。

(1)解决办法

1)可以看缺少那些依赖就安装对应的依赖版本

  1. 使用rpm查看glibc版本,然后去官网下载对应的版本即可

mysql_176">2、启动mysql服务报错

启动mysql服务时可能会报“Starting MySQL.2024-09-20T09:32:58.959370Z mysqld safe error:log-errorr set to/var/log/mariadb/mariadb.log’,however file don’t exists.Create writable for us ‘mysql’”

**(1)**解决方法

此错误时没有对应的目录和文件,进行创建目录和文件即可

mkdir /var/log/mariadb/

touch /var/log/mariadb/mariadb.log

chown -R mysql:mysql /var/log/mariadb/


http://www.ppmy.cn/ops/156608.html

相关文章

通过 Docker 部署 S3 对象存储服务器的终极教程

在当今数据驱动的时代,拥有一个灵活且高效的对象存储解决方案至关重要。利用 Docker 部署 S3 对象存储服务器,不仅可以提升数据管理的灵活性,还能大幅降低运营成本。本文将为您提供详细步骤,助您轻松搭建 S3 存储解决方案。 如何…

【Mybatis Plus】JSqlParser解析sql语句

【Mybatis Plus】JSqlParser解析sql语句 【一】JSqlParser 是什么【二】JSqlParser 的安装步骤【三】使用场景【1】sql语句解析【2】SQL 语句转换【3】SQL 语句生成【4】SQL 语句验证 【四】在使用 JSqlParser 时,如何处理 SQL 注入攻击?【1】使用预编译…

Spark SQL读写Hive Table部署

个人博客地址:Spark SQL读写Hive Table部署 | 一张假钞的真实世界 官网参考文档:Hive Tables。 本文使用的组件版本如下: Spark 3.1.2Hive 3.1.2 第一步:Hive部署 在所有Worker节点上部署Hive。主要是使用Hive下面的libs。 …

docker和k8s实践

Docker 和 Kubernetes 是现代云原生应用开发和运维中的两个重要技术。Docker 提供容器化技术,可以将应用及其依赖打包在容器中,而 Kubernetes 则负责容器的编排、部署、伸缩和管理。以下是 Docker 和 Kubernetes 的实践指南,涵盖基础安装、配…

【华为OD机试】真题E卷-招聘(Java)

一、题目描述 题目描述: 某公司组织一场公开招聘活动,假设由于人数和场地的限制,每人每次面试的时长不等,并已经安排给定,用(S1,E1)、 (S2,E2)、 (Sj,Ej)…(Si < Ei,均为非负整数)表示每场面试的开始和结束时间。 面试采用一对一的方式,即一名面试官同时只能面试一名…

Windows图形界面(GUI)-QT-C/C++ - QT Dock Widget

公开视频 -> 链接点击跳转公开课程博客首页 -> ​​​链接点击跳转博客主页 目录 一、概述 二、使用场景 1. 工具栏 2. 侧边栏 3. 调试窗口 三、常见样式 1. 停靠位置 2. 浮动窗口 3. 可关闭 4. 可移动 四、属性设置 1. 设置内容 2. 获取内容 3. 设置标题 …

Debian 安装 Nextcloud 使用 MariaDB 数据库 + Caddy + PHP-FPM

前言 之前通过 docker在ubuntu上安装Nextcloud&#xff0c;但是现在我使用PVE安装Debian虚拟机&#xff0c;不想通过docker安装了。下面开始折腾。 安装过程 步骤 1&#xff1a;更新系统并安装必要的软件 sudo apt update && sudo apt upgrade -y sudo apt install…

MySQL锁类型(详解)

锁的分类图&#xff0c;如下&#xff1a; 锁操作类型划分 读锁 : 也称为共享锁 、英文用S表示。针对同一份数据&#xff0c;多个事务的读操作可以同时进行而不会互相影响&#xff0c;相互不阻塞的。 写锁 : 也称为排他锁 、英文用X表示。当前写操作没有完成前&#xff0c;它会…