1.简介

1 )MySQL C/S结构介绍
两种连接方式:

  1. TCP/IPmysql -uroot -poldboy123 -h 10.1.1.11 -P3306
  2. Socketmysql -uroot -poldboy123 -S /tmp/mysql.sock

2)MySQL实例的构成
公司: 老板 + 经理 + 员工 + 办公区
实例: mysqld + master thread + 干活的Thread + 预分配的内存

2.MySQLd进程结构

1) MySQL中mysqld服务器进程结构
1.1 SQL语句引入
结构化的查询语言
DQL 数据查询语言
DDL 数据定义语言
DML 数据操作语言
DCL 数据控制语言

  1. mysql> select user,host from mysql.user;

2) 连接层
(2.1) 提供连接协议
Socket
TCPIP
(2.2) 验证用户名(root@localhost)密码合法性,进行匹配专门的授权表。
(2.3) 派生一个专用连接线程(接收SQL,返回结果)
mysql> show processlist;
思考:
忘记密码的参数在哪做的手脚?
—skip-grant-tables
—skip-networking

3) SQL层(优化方面至关重要的)
(1)验证SQL语法和SQL_MODE(sql92)
(2)验证语义
(3)验证权限
(4)解析器进行语句解析,生成执行计划(解析树)
(5)优化器(各种算法,基于执行代价),根据算法,找到代价最低的执行计划。
代价:CPU IO MEM
(6)执行器按照优化器选择执行计划,执行SQL语句,得出获取数据的方法。
(7)提供查询缓存(默认不开),一般不开,会用redis。
(8)记录操作日志(binlog),默认没开。

4) 存储引擎层
真正和磁盘打交道的一个层次
根据SQL层提供的取数据的方法,拿到数据,返回给SQL,结构化成表,再又连接层线程返回给用户。

3.数据的逻辑结构

1) MySQL逻辑存储结构
库 ——》Linux目录
create database wordpress charset utf8mb4; ——》mkdir /wordpress
show databases; ——》ls /
use wordpress; ——》cd /wordpress

表 ——》Linux的文件
列(字段) 无
列属性 无
数据行(记录) ——》Linux数据行
表属性(元数据) ——》Linux 文件属性

2) MySQL物理存储结构
库: 使用FS上的目录来表示
表:
MyISAM(ext2)
user.frm : 存储的表结构(列,列属性)
user.MYD : 存储的数据记录
user.MYI : 存储索引

InnoDB(XFS)
time_zone.frm : 存储的表结构(列,列属性)
time_zone.ibd : 存储的数据记录和索引
ibdata1 : 数据字典信息

3) innodb 段 区 页
一般情况下(非分区表)
一个表就是一个段
一个段由多个区构成
一个区在(16k),64个连续的页,1M大小

4.用户权限管理

1) 作用
登录MySQL
管理MySQL

2) 用户的定义
用户名@’白名单’
root@’%’
root@’localhost’
root@’127.0.0.1’
root@’10.0.0.%’
root@’10.0.0.5%’
root@’10.0.0.0/255.255.254.0’
root@’10.0.%’

3) 用户的操作
3.1) 建用户

  1. mysql> create user zabbix@'10.0.0.%' identified by '123';
  2. Query OK, 0 rows affected (0.00 sec)

说明:
8.0以前,可以自动创建用户并授权

  1. mysql> grant all on . to zabbix@'10.0.0.%' identified by '123';

3.2) 查询用户

  1. mysql> select user,host from mysql.user;

3.3) 修改用户密码

  1. mysql> alter user zabbix@'10.0.0.%' identified by '123456';

3.4) 删除用户

  1. mysql> drop user zabbix@'10.0.0.%' ;

4) 权限管理
41.) 权限列表
ALL
SELECT,INSERT, UPDATE, DELETE, CREATE, DROP, RELOAD, SHUTDOWN, PROCESS, FILE, REFERENCES, INDEX, ALTER, SHOW DATABASES, SUPER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, REPLICATION SLAVE, REPLICATION CLIENT, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, CREATE USER, EVENT, TRIGGER, CREATE TABLESPACE

with grant option

4.2) 授权命令

  1. grant all on . to oldguo@'10.0.0.%' identified by '123' with grant option;
  2. grant 权限 on 作用目标 to 用户 identified by 密码 with grant option;
  3. grant SELECT,INSERT, UPDATE, DELETE, CREATE on wordpress.* to
  4. 作用目标:
  5. .
  6. wordpress.*
  7. worpress.t1

4.3) 授权需求

  1. 创建一个管理员用户root,可以通过10网段,管理数据库.
    grant all on . to root@’10.0.0.%’ identified by ‘123’ with grant option;
  2. 创建一个应用用户wordpress,可以通过10网段,wordpress库下的所有表进行SELECT,INSERT, UPDATE, DELETE.
    grant SELECT,INSERT, UPDATE, DELETE on wordpress.* to wordpress@’10.0.0.%’ identified by ‘123’;

4.4) 回收权限

  1. show grants for wordpress@'10.0.0.%';
  2. mysql> revoke delete on wordpress.* from 'wordpress'@'10.0.0.%';
  3. mysql> show grants for wordpress@'10.0.0.%';

5.Mysql基础管理

  1. MySQL的启动和关闭

1.1 日常启停

  1. mysql.server start ---> mysqld_safe ---> mysqld
  2. mysql.service ---> mysqld
  3. mysql.service 需要依赖于 /etc/my.cnf
  4. ExecStart=/application/mysql/bin/mysqld --defaults-file=/etc/my.cnf
  5. [root@localhost support-files]# ll /application/mysql/support-files/mysql.server
  6. -rwxr-xr-x 1 mysql mysql 10576 Sep 24 2020 /application/mysql/support-files/mysql.server
  7. [root@localhost support-files]# ll /application/mysql/bin/mysqld_safe
  8. -rwxr-xr-x 1 mysql mysql 27836 Sep 24 2020 /application/mysql/bin/mysqld_safe

1.2 维护性的任务

  1. mysqld_safe --skip-grant-tables --skip-networking &
  2. 我们一般会将我们需要的参数临时加到命令行.
  3. 也会读取/etc/my.cnf的内容,但是如果冲突,命令行优先级最高
  4. [root@db01 ~]# mysqld_safe &
  5. [root@db01 ~]# mysqladmin -uroot -p123 shutdown
  1. 初始化配置

2.1 作用
(1)影响数据库的启动
(2)影响到客户端的功能
2.2 初始化配置的方法
(1)初始化配置文件(例如/etc/my.cnf)
(2)启动命令行上进行设置(例如:mysqld_safe mysqld)
(3)预编译时设置(仅限于编译安装时设置)
2.3 初始化配置文件的书写格式
[标签]
xxx=xxx
[标签]
xxx=xxx

2.4 配置文件标签的归类
服务器端:
[mysqld]
[mysqld_safe]
[server]

客户端:
[mysql]
[mysqladmin]
[mysqldump]
[client]

2.5 配置文件设置样板(5.7)

  1. #服务器端配置
  2. [mysqld]
  3. #用户
  4. user=mysql
  5. #软件安装目录
  6. basedir=/application/mysql
  7. #数据路径
  8. datadir=/data/mysql/data
  9. #socket文件位置
  10. socket=/tmp/mysql.sock
  11. #服务器id号
  12. server_id=6
  13. #短口号
  14. port=3306
  15. #客户端配置
  16. [mysql]
  17. #socket文件位置
  18. socket=/tmp/mysql.sock

2.6 配置文件读取顺序

  1. [root@db01 ~]# mysqld --help --verbose |grep my.cnf
  2. /etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf

2.7 强制使用自定义配置文件

  1. --defautls-file
  2. [root@db01 tmp]# mysqld_safe --defaults-file=/tmp/aa.txt &
  1. MySQL的连接管理

3.1 mysql 命令
注意:提前应该将用户授权做好

  1. mysql> grant all on . to root@'10.0.0.%' identified by '123';
  2. TCPIP :
  3. mysql -uroot -p -h 10.0.0.51 -P3306
  4. Socket
  5. mysql -uroot -p -S /tmp/mysql.sock

3.2 客户端工具
sqlyog
navicat

  1. 多实例管理
    4.1 准备多个目录
    mkdir -p /data/330{7,8,9}/data

4.2 准备配置文件

  1. cat > /data/3307/my.cnf <<EOF
  2. [mysqld]
  3. basedir=/application/mysql
  4. datadir=/data/3307/data
  5. socket=/data/3307/mysql.sock
  6. log_error=/data/3307/mysql.log
  7. port=3307
  8. server_id=7
  9. log_bin=/data/3307/mysql-bin
  10. EOF
  11. cat > /data/3308/my.cnf <<EOF
  12. [mysqld]
  13. basedir=/application/mysql
  14. datadir=/data/3308/data
  15. socket=/data/3308/mysql.sock
  16. log_error=/data/3308/mysql.log
  17. port=3308
  18. server_id=8
  19. log_bin=/data/3308/mysql-bin
  20. EOF
  21. cat > /data/3309/my.cnf <<EOF
  22. [mysqld]
  23. basedir=/application/mysql
  24. datadir=/data/3309/data
  25. socket=/data/3309/mysql.sock
  26. log_error=/data/3309/mysql.log
  27. port=3309
  28. server_id=9
  29. log_bin=/data/3309/mysql-bin
  30. EOF

4.3 初始化三套数据

  1. mv /etc/my.cnf /etc/my.cnf.bak
  2. mysqld --initialize-insecure --user=mysql --datadir=/data/3307/data --basedir=/application/mysql
  3. mysqld --initialize-insecure --user=mysql --datadir=/data/3308/data --basedir=/application/mysql
  4. mysqld --initialize-insecure --user=mysql --datadir=/data/3309/data --basedir=/application/mysql

4.4 systemd管理多实例

  1. cd /etc/systemd/system
  2. cp mysqld.service mysqld3307.service
  3. cp mysqld.service mysqld3308.service
  4. cp mysqld.service mysqld3309.service
  5. vim mysqld3307.service
  6. 修改为:
  7. ExecStart=/application/mysql/bin/mysqld --defaults-file=/data/3307/my.cnf
  8. vim mysqld3308.service
  9. 修改为:
  10. ExecStart=/application/mysql/bin/mysqld --defaults-file=/data/3308/my.cnf
  11. vim mysqld3309.service
  12. 修改为:
  13. ExecStart=/application/mysql/bin/mysqld --defaults-file=/data/3309/my.cnf
  14. [root@db01 system]# grep "ExecStart" mysqld3309.service
  15. ExecStart=/application/mysql/bin/mysqld --defaults-file=/data/3309/my.cnf
  16. [root@db01 system]# grep "ExecStart" mysqld3308.service
  17. ExecStart=/application/mysql/bin/mysqld --defaults-file=/data/3308/my.cnf
  18. [root@db01 system]# grep "ExecStart" mysqld3307.service
  19. ExecStart=/application/mysql/bin/mysqld --defaults-file=/data/3307/my.cnf
  20. [root@db01 system]#

4.5 授权

  1. chown -R mysql.mysql /data/*


4.6 启动

  1. systemctl start mysqld3307.service
  2. systemctl start mysqld3308.service
  3. systemctl start mysqld3309.service

4.7 验证多实例

  1. netstat -lnp|grep 330
  2. mysql -S /data/3307/mysql.sock -e "select @@server_id"
  3. mysql -S /data/3308/mysql.sock -e "select @@server_id"
  4. mysql -S /data/3309/mysql.sock -e "select @@server_id"

6.Mysql 常见命令

1)查看数据库的版本

  1. 方式1
  2. mysql> select version();
  3. +-----------+
  4. | version() |
  5. +-----------+
  6. | 5.7.33 |
  7. +-----------+
  8. 1 row in set (0.00 sec)
  9. 方式2
  10. [root@server_10.1.1.11 ~]#mysql -V
  11. mysql Ver 14.14 Distrib 5.7.33, for linux-glibc2.12 (x86_64) using EditLine wrapper

2)切换到指定的库

  1. mysql> use world;

3)查看当前库的所有表

  1. mysql> show tables;
  2. +-----------------+
  3. | Tables_in_world |
  4. +-----------------+
  5. | city |
  6. | country |
  7. | countrylanguage |
  8. +-----------------+

4)查看其他库的所有表

  1. mysql> show tables from zabbix;
  2. +------------------+
  3. | Tables_in_zabbix |
  4. +------------------+
  5. | stu |
  6. +------------------+
  7. 1 row in set (0.00 sec)

5)查看表结构

  1. mysql> desc city;
  2. +-------------+----------+------+-----+---------+----------------+
  3. | Field | Type | Null | Key | Default | Extra |
  4. +-------------+----------+------+-----+---------+----------------+
  5. | ID | int(11) | NO | PRI | NULL | auto_increment |
  6. | Name | char(35) | NO | | | |
  7. | CountryCode | char(3) | NO | MUL | | |
  8. | District | char(20) | NO | | | |
  9. | Population | int(11) | NO | | 0 | |
  10. +-------------+----------+------+-----+---------+----------------+
  11. 5 rows in set (0.00 sec)