Geeks_Z の Blog Geeks_Z の Blog
首页
  • 学习笔记

    • 《HTML》
    • 《CSS》
    • 《JavaWeb》
    • 《Vue》
  • 后端文章

    • Linux
    • Maven
    • 汇编语言
    • 软件工程
    • 计算机网络概述
    • Conda
    • Pip
    • Shell
    • SSH
    • Mac快捷键
    • Zotero
  • 学习笔记

    • 《数据结构与算法》
    • 《算法设计与分析》
    • 《Spring》
    • 《SpringMVC》
    • 《SpringBoot》
    • 《SpringCloud》
    • 《Nginx》
  • 深度学习文章
  • 学习笔记

    • 《PyTorch》
    • 《ReinforementLearning》
    • 《MetaLearning》
  • 学习笔记

    • 《高等数学》
    • 《线性代数》
    • 《概率论与数理统计》
  • 增量学习
  • 哈希学习
GitHub (opens new window)

Geeks_Z

AI小学生
首页
  • 学习笔记

    • 《HTML》
    • 《CSS》
    • 《JavaWeb》
    • 《Vue》
  • 后端文章

    • Linux
    • Maven
    • 汇编语言
    • 软件工程
    • 计算机网络概述
    • Conda
    • Pip
    • Shell
    • SSH
    • Mac快捷键
    • Zotero
  • 学习笔记

    • 《数据结构与算法》
    • 《算法设计与分析》
    • 《Spring》
    • 《SpringMVC》
    • 《SpringBoot》
    • 《SpringCloud》
    • 《Nginx》
  • 深度学习文章
  • 学习笔记

    • 《PyTorch》
    • 《ReinforementLearning》
    • 《MetaLearning》
  • 学习笔记

    • 《高等数学》
    • 《线性代数》
    • 《概率论与数理统计》
  • 增量学习
  • 哈希学习
GitHub (opens new window)
  • Linux

  • Java

  • 微服务笔记

  • MySQL

    • 基础篇

    • MySQL架构篇

      • Linux下MySQL的安装与使用
        • Linux下MySQL的安装与使用
          • 1. 安装前说明
          • 1.1 查看是否安装过MySQL
          • 1.2 MySQL的卸载
          • 2. MySQL的Linux版安装
          • 2.1 CentOS7下检查MySQL依赖
          • 2.2 CentOS7下MySQL安装过程
          • 2.3 查看MySQL版本
          • 2.4 服务的初始化
          • 2.5 启动MySQL,查看状态
          • 2.6 查看MySQL服务是否自启动
          • 3. MySQL登录
          • 3.1 首次登录
          • 3.2 修改密码
          • 3.3 设置远程登录
          • 4. Linux下修改配置
          • 5. 字符集的相关操作
          • 5.1 各级别的字符集
          • 5.2 请求到响应过程中字符集的变化
      • MySQL的数据目录
      • 用户与权限管理
      • 逻辑架构
      • 存储引擎
      • 数据库日志
      • 主从复制
      • 数据库备份与恢复
      • 数据库事务
      • 事务日志
      • 锁
      • 多版本并发控制
      • MySQL索引及调优篇
      • 性能分析工具的使用
    • MySQL问题清单
  • Nginx

  • HTML

  • CSS

  • JavaWeb

  • Vue

  • Git

  • 开发规范

  • SpringCloud微服务权限系统

  • bug

  • Software

  • ProgramNotes
  • MySQL
  • MySQL架构篇
Geeks_Z
2023-01-17
目录

Linux下MySQL的安装与使用

Linux下MySQL的安装与使用

1. 安装前说明

1.1 查看是否安装过MySQL

  • 如果你是用rpm安装, 检查一下RPM PACKAGE:
rpm -qa | grep -i mysql # -i 忽略大小写
1
  • 检查mysql service:
systemctl status mysqld.service
1

1.2 MySQL的卸载

  1. 关闭 mysql 服务
systemctl stop mysqld.service
1
  1. 查看当前 mysql 安装状况
rpm -qa | grep -i mysql
# 或
yum list installed | grep mysql
1
2
3
  1. 卸载上述命令查询出的已安装程序
yum remove mysql-xxx mysql-xxx mysql-xxx mysqk-xxxx
1

务必卸载干净,反复执行rpm -qa | grep -i mysql确认是否有卸载残留

  1. 删除 mysql 相关文件
  • 查找相关文件
find / -name mysql
1
  • 删除上述命令查找出的相关文件
rm -rf xxx
1

5.删除 my.cnf

rm -rf /etc/my.cnf
1

2. MySQL的Linux版安装

2.1 CentOS7下检查MySQL依赖
  1. 检查/tmp临时目录权限(必不可少)

由于mysql安装过程中,会通过mysql用户在/tmp目录下新建tmp_db文件,所以请给/tmp较大的权限。执行 :

chmod -R 777 /tmp
1
  1. 安装前,检查依赖
rpm -qa|grep libaio
rpm -qa|grep net-tools
1
2
2.2 CentOS7下MySQL安装过程
  1. 将安装程序拷贝到/opt目录下

在mysql的安装文件目录下执行:(必须按照顺序执行)

rpm -ivh mysql-community-common-8.0.25-1.el7.x86_64.rpm 
rpm -ivh mysql-community-client-plugins-8.0.25-1.el7.x86_64.rpm 
rpm -ivh mysql-community-libs-8.0.25-1.el7.x86_64.rpm 
rpm -ivh mysql-community-client-8.0.25-1.el7.x86_64.rpm 
rpm -ivh mysql-community-server-8.0.25-1.el7.x86_64.rpm
1
2
3
4
5
  • rpm是Redhat Package Manage缩写,通过RPM的管理,用户可以把源代码包装成以rpm为扩展名的文件形式,易于安装。
  • -i, --install 安装软件包
  • -v, --verbose 提供更多的详细信息输出
  • -h, --hash 软件包安装的时候列出哈希标记 (和 -v 一起使用效果更好),展示进度条

若存在mariadb-libs问题,则执行yum remove mysql-libs即可

2.3 查看MySQL版本
mysql --version 
#或
mysqladmin --version
1
2
3
2.4 服务的初始化

为了保证数据库目录与文件的所有者为 mysql 登录用户,如果你是以 root 身份运行 mysql 服务,需要执行下面的命令初始化:

mysqld --initialize --user=mysql
1

说明: --initialize 选项默认以“安全”模式来初始化,则会为 root 用户生成一个密码并将该密码标记为过期,登录后你需要设置一个新的密码。生成的临时密码会往日志中记录一份。

查看密码:

cat /var/log/mysqld.log
1

root@localhost: 后面就是初始化的密码

2.5 启动MySQL,查看状态
#加不加.service后缀都可以 
启动:systemctl start mysqld.service 
关闭:systemctl stop mysqld.service 
重启:systemctl restart mysqld.service 
查看状态:systemctl status mysqld.service
1
2
3
4
5
2.6 查看MySQL服务是否自启动
systemctl list-unit-files|grep mysqld.service
1
  • 如不是enabled可以运行如下命令设置自启动
systemctl enable mysqld.service
1
  • 如果希望不进行自启动,运行如下命令设置
systemctl disable mysqld.service
1

3. MySQL登录

3.1 首次登录

通过mysql -hlocalhost -P3306 -uroot -p进行登录,在Enter password:录入初始化密码

3.2 修改密码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';
1
3.3 设置远程登录
  1. 确认网络

1.在远程机器上使用ping ip地址保证网络畅通

2.在远程机器上使用telnet命令保证端口号开放访问

  1. 关闭防火墙或开放端口

方式一:关闭防火墙

  • CentOS6 :
service iptables stop
1
  • CentOS7:
#开启防火墙
systemctl start firewalld.service
#查看防火墙状态
systemctl status firewalld.service
#关闭防火墙
systemctl stop firewalld.service
#设置开机启用防火墙 
systemctl enable firewalld.service 
#设置开机禁用防火墙 
systemctl disable firewalld.service
1
2
3
4
5
6
7
8
9
10

方式二:开放端口

  • 查看开放的端口号
firewall-cmd --list-all
1
  • 设置开放的端口号
firewall-cmd --add-service=http --permanent
firewall-cmd --add-port=3306/tcp --permanent
1
2
  • 重启防火墙
firewall-cmd --reload
1

4. Linux下修改配置

  • 修改允许远程登陆
use mysql;
select Host,User from user;
update user set host = '%' where user ='root';
flush privileges;
1
2
3
4

%是个 通配符 ,如果Host=192.168.1.%,那么就表示只要是IP地址前缀为“192.168.1.”的客户端都可以连接。如果Host=%,表示所有IP都有连接权限。

注意:在生产环境下不能为了省事将host设置为%,这样做会存在安全问题,具体的设置可以根据生产环境的IP进行设置。

配置新连接报错:错误号码 2058,分析是 mysql 密码加密方法变了。

解决方法一:升级远程连接工具版本

解决方法二:

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'abc123';
1

5. 字符集的相关操作

5.1 各级别的字符集
show variables like 'character%';
1
  • character_set_server:服务器级别的字符集
  • character_set_database:当前数据库的字符集
  • character_set_client:服务器解码请求时使用的字符集
  • character_set_connection:服务器处理请求时会把请求字符串从character_set_client转为character_set_connection
  • character_set_results:服务器向客户端返回数据时使用的字符集

小结

  • 如果创建或修改列时没有显式的指定字符集和比较规则,则该列默认用表的字符集和比较规则
  • 如果创建表时没有显式的指定字符集和比较规则,则该表默认用数据库的字符集和比较规则
  • 如果创建数据库时没有显式的指定字符集和比较规则,则该数据库默认用服务器的字符集和比较规则
5.2 请求到响应过程中字符集的变化
graph TB
A(客户端) --> |"使用操作系统的字符集编码请求字符串"| B(从character_set_client转换为character_set_connection)
B --> C(从character_set_connection转换为具体的列使用的字符集)
C --> D(将查询结果从具体的列上使用的字符集转换为character_set_results)
D --> |"使用操作系统的字符集解码响应的字符串"| A

1
2
3
4
5
6

#MySQL
上次更新: 2025/02/26, 08:57:57
MySQL8新特性
MySQL的数据目录

← MySQL8新特性 MySQL的数据目录→

最近更新
01
RAIL
02-26
02
IOCTF
02-25
03
DGM
02-25
更多文章>
Theme by Vdoing | Copyright © 2022-2025 Geeks_Z | MIT License
京公网安备 11010802040735号 | 京ICP备2022029989号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式