当前位置: 首页 > news >正文

CentOS7安装mysql

1、安装工作

1.1、卸载 MariaDB

1.1.1、MariaDB

MySQL 的一个分支,主要由开源社区维护。

  1. CentOS 7+不再默认使用 MySQL 数据库,而是 MariaDB 数据库。
  2. 直接安装 MySQL 会与 MariaDB 的文件冲突。

👉 安装 MySQL 之前,先卸载自带的 MariaDB。

1.1.2、卸载

步骤

  1. 查看版本:有则需要卸载。

    rpm -qa|grep mariadb
  2. 卸载:复制文件名,执行以下指令。

    rpm -e --nodeps 文件名
  3. 确认卸载

    rpm -qa|grep mariadb

    如图所示:

1.2、下载资源包

Hint:将 MySQL 资源包放在/usr/local/

官网下载地址:https://downloads.mysql.com/archives/community/

下载下来,不要解压

1.3、检查旧版本 MySQL

指令

rpm -qa|grep mysql
  • 没有输出:说明当前系统没有安装 MySQL,开始安装。

  • 有输出:显示的 MySQL 不是想要的版本,则卸载。

    # 停止服务 systemctl stop mysqld # 卸载 rpm -e --nodeps mysql文件名

1.4、解压安装

1.4.1 先装上传工具(执行这行)

第一步:bash命令

yum install -y lrzsz

在centos7中使用yum命令时候报错解决方法

1.4.2. 执行上传命令

第二步:bash命令

rz

弹出窗口后,选中你 Windows 里的mysql-8.0.27-linux-glibc2.x-x86_64.tar.xz,点打开,直接上传到当前/usr/local目录

或者更简单:直接把 Windows 里的压缩包拖进 MobaXterm 黑色终端,自动上传

  1. 解压:tar 指令。

    我的是:tar -Jxvf mysql-8.0.27-linux-glibc2.12-x86_64.tar.xz -C /usr/local/mysql/

    # .tar.gz 后缀tar-zxvf文件名# .tar.xz 后缀tar-Jxvf文件名

​ 解压mysql

2.解压完成/usr/local/mysql下会生成 MySQL 文件夹。

2、配置工作

2.1、基本设置

安装完成后的基本设置。

2.1.1、文件夹重命名

  • 重命名MySQL 文件夹

  • 通常命名为mysql版本号

    # 重命名(也可通过Xftp修改)mv原文件夹名 mysql8# 软链接ln-s文件夹名 mysql8

2.1.2、PATH 变量

添加 PATH 变量后,可在全局使用 MySQL

添加方式

  1. 临时生效:export 命令(连接会话关闭后失效,通常用于测试环境)
    export PATH=$PATH:/usr/local/mysql8/bin
  2. 永久生效:修改配置文件。

2.1.3、确认安装

  1. 查看版本
    • mysql--version

  1. 确定 MySQL 安装成功后,可删除压缩包。
rm -rf 压缩包名

2.2、数据目录

2.2.1创建目录

mkdir-p/usr/local/mysql/data/mysql8_data

在mysql下创建data文件夹,里面还有mysql8_data,意思是:创建一个用来存放 MySQL 数据的文件夹,专门存数据库文件。

3、初始化 & 启动

3.1、配置文件

/usr/local/etc/下创建my.cnf配置文件

用于初始化 MySQL 数据库

3.1.1、配置方式

注:部分配置涉及 MySQL 文件夹名称,若文件夹名不是mysql8则需修改。

1.修改文件(随便一个编辑器)

2.配置内容
[mysql] # 默认字符集 default-character-set=utf8mb4 [client] port = 3306 socket = /tmp/mysql.sock [mysqld] port = 3306 server-id = 3306 user = root socket = /tmp/mysql.sock # 安装目录 basedir = /usr/local/mysql/mysql8 # 数据存放目录 datadir = /usr/local/mysql/data/mysql8_data/ log-bin = /usr/local/mysql/data/mysql8_data/mysql-bin innodb_data_home_dir =/usr/local/mysql/data/mysql8_data innodb_log_group_home_dir =/usr/local/mysql/data/mysql8_data # 日志及进程数据的存放目录 log-error =/usr/local/mysql/data/mysql8_data/mysql.log pid-file =/usr/local/mysql/data/mysql8_data/mysql.pid # 服务端字符集 character-set-server=utf8mb4 lower_case_table_names=1 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_sort_buffer_size = 64M thread_cache_size = 128 #query_cache_size = 128M 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_data_file_path = ibdata1:10M:autoextend innodb_buffer_pool_size = 1024M innodb_log_file_size = 256M innodb_log_buffer_size = 8M innodb_flush_log_at_trx_commit = 1 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、初始化

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

  • --defaults-file:指定配置文件(要放在–initialize 前面)
  • --intialize-insecure:初始化无密码(否则生成随机密码)
mysqld --defaults-file=/usr/local/etc/my.cnf --initialize-insecure

3.3、启动 MySQL

3.3.1查看是否有这个文件mysqld_safe

3.3.2 安全后台启动MySQL

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

shell-init: 获取当前目录时出错: getcwd: 无法访问父目录

  • 含义:当前 shell 的工作目录已被删除(比如您之前执行过rm -rf /usr/local/mysql/data/mysql8_data,然后仍在那个目录下执行命令)。

  • 原因:您执行mysqld_safe时,当前工作目录(可能是/usr/local/mysql/data/mysql8_data)已经被删除,导致 shell 无法获取当前路径。

  • 影响对 MySQL 服务本身没有任何影响。mysqld_safe 和 mysqld 都使用绝对路径(如配置文件中指定的),不会依赖当前目录。只是控制台多了一行无害的错误提示。

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

    • ps -ef|grep mysql

3.3.3、登录

  • 无密码:若以--initialize-insecure初始化,首次登录时跳过密码。

    mysql -u root --skip-password
  • 有密码:若初始化时设置了随机密码,在/data/mysql8_data/mysql/mysql.log查看

    mysql-uroot-p

mysql -u root -p Enter password: # 这里什么都不输,直接按回车

3.4、修改密码

3.4.1、首次修改

MySQL初始化的 root 用户、新创建的用户,都需要设置首次密码。

建议使用本地密码插件mysql_native_password

# 修改密码ALTERUSER'root'@'localhost'IDENTIFIEDWITHmysql_native_passwordBY'新密码';# 刷新权限FLUSHPRIVILEGES;

3.4.2、平时修改

可在 Linux 或 MySQL 中修改。

  1. Linux 命令行

    mysqladmin -u用户名 -p旧密码 password 新密码
  2. MySQL 命令行

    # 设置密码SETPASSWORDFOR'用户名'@'主机'=PASSWORD(‘密码');# 刷新权限FLUSHPRIVILEGES;

3.5、退出、关闭服务

在 MySQL 命令行中执行

若在 Linux 命令行中,会退出/关闭 Linux 服务器。

3.5.1退出 MySQL(命令行)

quit;exit;

3.5.2*关闭 MySQL 服务**:

shutdown;**```bash mysqladmin-u用户名-p旧密码 password 新密码
  1. MySQL 命令行

    # 设置密码SETPASSWORDFOR'用户名'@'主机'=PASSWORD(‘密码');# 刷新权限FLUSHPRIVILEGES;

3.5、退出、关闭服务

在 MySQL 命令行中执行

若在 Linux 命令行中,会退出/关闭 Linux 服务器。

3.5.1退出 MySQL(命令行)

quit;exit;

3.5.2*关闭 MySQL 服务**:

shutdown;
http://www.jsqmd.com/news/848018/

相关文章:

  • CAXA 齿轮齿形
  • 别让严谨变成AI味!实测5大主流降AI工具,这款能完美保留原格式
  • 物联网设备分类与核心功能解析:从感知到边缘计算的实战指南
  • 不只是F5隐写:一次CTF解题,带你深入理解ZIP伪加密的底层原理与手动修复
  • 别再只load_dataset了!HuggingFace Datasets库这5个隐藏功能,帮你把数据处理效率翻倍
  • 保姆级教程:在Windows 11上用Hyper-V Manager给CentOS 7配静态IP,告别虚拟机断网
  • YOLOv11超市货架牛奶目标检测数据集-463张-Milk-1
  • FRAM嵌入式存储应用指南:从原理到Arduino与CircuitPython实战
  • 【实战】Latex|在保留ACM-Reference-Format格式的前提下,实现参考文献按引用顺序排列
  • 如何在macOS上实现专业级OBS虚拟摄像头:从原理到实践的全方位指南
  • 2025年网盘直链下载终极指南:告别限速,轻松获取高速下载链接
  • 基于RP2040与CircuitPython的互动声光按钮:从硬件到代码的完整实现
  • 别再为运放振铃发愁了!用TINA-TI手把手教你搞定电容性负载(附完整仿真文件)
  • ChromaControl终极指南:如何用一个软件控制所有RGB设备?[特殊字符]
  • 别再乱用sudo了!麒麟KYLINOS下用ACL实现安全的精细化权限控制
  • Claude 4 系列正式发布:Opus 4 与 Sonnet 4 全新特性全解析
  • 手把手教你搞定LVPECL时钟电路匹配:从理论计算到实际PCB布局的避坑全流程
  • 2026实验台权威厂家技术评测:全钢实验台/净气型通风柜/双门通风柜/玻璃钢通风柜/落地式通风柜/边台实验台/钢木通风柜/选择指南 - 优质品牌商家
  • 告别复杂代码!d2s-editor:暗黑破坏神2存档编辑的终极可视化方案
  • 【Trae】Trae国内版|国际版|海外版下载|Mac版|Windows版|Linux下载配置教程(含Mermaid图)
  • KMS_VL_ALL_AIO:Windows与Office智能激活解决方案深度解析与实战指南
  • 从ColorDialog到FontDialog:手把手教你定制WinForm功能对话框,打造个性化桌面应用
  • 从设计到验证:如何用ADS的HB2TonePAE_FPswp模板快速评估你的PA线性度?
  • QloRa
  • 印第安纳大学突破:AI隐藏记忆实现可视化与可编辑能力提升
  • 从物理模型到代码:用MATLAB类轻松构建你的第一个仿真对象(比如弹簧振子)
  • SAP-ABAP:数据类型与数据对象(8篇) 第三篇:实例特征篇——数据对象的生命周期与行为属性
  • 别再死记硬背了!用生活中的开关和继电器,5分钟搞懂PLC的常开常闭和线圈
  • 2026最新论文降AIGC全盘点:应对隐形维度检测新规,实测5款高质量优化工具
  • 终极指南:USTC LaTeX论文模板深度配置与高效排版技巧