第01章 Linux下MySQL的安装与使用

第01章 Linux下MySQL的安装与使用

1. 安装前说明
1.1 查看是否安装过MySQL
  • 如果你是用rpm安装, 检查一下RPM PACKAGE:
shell 复制代码
rpm -qa | grep -i mysql # -i 忽略大小写
  • 检查mysql service:
shell 复制代码
systemctl status mysqld.service
1.2 MySQL的卸载

1. 关闭 mysql 服务

shell 复制代码
systemctl stop mysqld.service

2. 查看当前 mysql 安装状况

shell 复制代码
rpm -qa | grep -i mysql
# 或
yum list installed | grep mysql

3. 卸载上述命令查询出的已安装程序

shell 复制代码
yum remove mysql-xxx mysql-xxx mysql-xxx mysqk-xxxx

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

4. 删除 mysql 相关文件

  • 查找相关文件
shell 复制代码
find / -name mysql
  • 删除上述命令查找出的相关文件
shell 复制代码
rm -rf xxx

5.删除 my.cnf

shell 复制代码
rm -rf /etc/my.cnf
2. MySQL的Linux版安装
2.1 CentOS7下检查MySQL依赖

1. 检查/tmp临时目录权限(必不可少)

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

shell 复制代码
chmod -R 777 /tmp

2. 安装前,检查依赖

shell 复制代码
rpm -qa|grep libaio
rpm -qa|grep net-tools
2.2 CentOS7下MySQL安装过程

1. 将安装程序拷贝到/opt目录下

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

shell 复制代码
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
  • rpm是Redhat Package Manage缩写,通过RPM的管理,用户可以把源代码包装成以rpm为扩展名的文件形式,易于安装。
  • -i, --install 安装软件包
  • -v, --verbose 提供更多的详细信息输出
  • -h, --hash 软件包安装的时候列出哈希标记 (和 -v 一起使用效果更好),展示进度条

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

2.3 查看MySQL版本
shell 复制代码
mysql --version 
#或
mysqladmin --version
2.4 服务的初始化

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

shell 复制代码
mysqld --initialize --user=mysql

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

查看密码:

shell 复制代码
cat /var/log/mysqld.log

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

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

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

3.2 修改密码
mysql 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';
3.3 设置远程登录

1. 确认网络

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

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

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

方式一:关闭防火墙

  • CentOS6 :
shell 复制代码
service iptables stop
  • CentOS7:
shell 复制代码
#开启防火墙
systemctl start firewalld.service
#查看防火墙状态
systemctl status firewalld.service
#关闭防火墙
systemctl stop firewalld.service
#设置开机启用防火墙 
systemctl enable firewalld.service 
#设置开机禁用防火墙 
systemctl disable firewalld.service

方式二:开放端口

  • 查看开放的端口号
shell 复制代码
firewall-cmd --list-all
  • 设置开放的端口号
shell 复制代码
firewall-cmd --add-service=http --permanent
firewall-cmd --add-port=3306/tcp --permanent
  • 重启防火墙
shell 复制代码
firewall-cmd --reload
4. Linux下修改配置
  • 修改允许远程登陆
mysql 复制代码
use mysql;
select Host,User from user;
update user set host = '%' where user ='root';
flush privileges;

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

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

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

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

解决方法二:

mysql 复制代码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'abc123';
5. 字符集的相关操作
5.1 各级别的字符集
mysql 复制代码
show variables like 'character%';
  • character_set_server:服务器级别的字符集
  • character_set_database:当前数据库的字符集
  • character_set_client:服务器解码请求时使用的字符集
  • character_set_connection:服务器处理请求时会把请求字符串从character_set_client转为character_set_connection
  • character_set_results:服务器向客户端返回数据时使用的字符集

小结

  • 如果创建或修改列时没有显式的指定字符集和比较规则,则该列默认用表的字符集和比较规则
  • 如果创建表时没有显式的指定字符集和比较规则,则该表默认用数据库的字符集和比较规则
  • 如果创建数据库时没有显式的指定字符集和比较规则,则该数据库默认用服务器的字符集和比较规则
5.2 请求到响应过程中字符集的变化

使用操作系统的字符集编码请求字符串 使用操作系统的字符集解码响应的字符串 客户端 从character_set_client转换为character_set_connection 从character_set_connection转换为具体的列使用的字符集 将查询结果从具体的列上使用的字符集转换为character_set_results

相关推荐
嵩山小老虎5 小时前
Windows 10/11 安装 WSL2 并配置 VSCode 开发环境(C 语言 / Linux API 适用)
linux·windows·vscode
Fleshy数模5 小时前
CentOS7 安装配置 MySQL5.7 完整教程(本地虚拟机学习版)
linux·mysql·centos
a41324475 小时前
ubuntu 25 安装vllm
linux·服务器·ubuntu·vllm
az44yao6 小时前
mysql 创建事件 每天17点执行一个存储过程
mysql
一只自律的鸡7 小时前
【Linux驱动】bug处理 ens33找不到IP
linux·运维·bug
17(无规则自律)7 小时前
【CSAPP 读书笔记】第二章:信息的表示和处理
linux·嵌入式硬件·考研·高考
!chen7 小时前
linux服务器静默安装Oracle26ai
linux·运维·服务器
秦老师Q7 小时前
php入门教程(超详细,一篇就够了!!!)
开发语言·mysql·php·db
REDcker7 小时前
Linux 文件描述符与 Socket 选项操作详解
linux·运维·网络
蒹葭玉树8 小时前
【C++上岸】C++常见面试题目--操作系统篇(第二十八期)
linux·c++·面试