开源数据库Mysql_DBA运维实战 (DCL/日志)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 开源数据库Mysql_DBA运维实战 (DCL/日志)

SQL(Structured Query Language 即结构化查询语言)


a.DDL语句   数据库定义语言: 数据库,表,视图,索引,存储过程,函数,创建删除ALTER(CREATE DROP ALTER) b.DML语句 数据库操纵语言: 插入数据INSERT、删除数据DELETE、更新数据UPDATE

c.DQL语句   数据库查询语言:查询数据SELECT

d.DCL语句 数据库控制语言:  例如控制用户的访问权限GRANT,REVOKE



DCL



DCL的概述


DCL(Data Control Language 数据控制语句)的操作是数据库对象的权限,这些操作的确定使数据更加的安全。


四种权限级别


1.Global  level     所有库,所有表的权限

2.Database  level    某个数据库中的所有表的权限

3.Table  level  库中的某个表的权限

4.Column   level   表中的某个字段 的权限


Mysql用户管理



1.创建用户


CREATE  USER  user1@'localhost'  IDENTIFIED   BY  'QianFeng@123456';


代码注释:CREATE  创建(关键字)  


           USER 用户(关键字)                                                                                                              user1   用户名称(自定义)                                                                                                      @ 分隔符(关键字)                                                                                                                ‘localhost’   允许登录的主机                                                                                                    IDENTIFIED BY 身份认证(关键字)                                                                                      ‘QianFeng@123456’   用户密码      


验证:                
 select * from mysql.user\G;


2.删除用户


DROP USER 'user1'@'localhost';


验证:                select * from mysql.user\G;

                          drop user 'user1'@'localhost';

                          select user from mysql.user;


3.修改用户密码


Root修改自己密码

#示例1
mysqladmin -uroot  -p'123'  password  'new_password'
#示例2
SET PASSWORD=password('new_password');


刷新权限:         FLUSH PRIVILEGES;


当root用户,忘记了密码。可以使用破解的方式来登录系统。修改密码。

原理:使系统在启动时,不加载密码文件。


丢失root用户密码


a.修改mysql启动设置


    # vim /etc/my.cnf
    [mysqld]
    skip-grant-tables


b.重启mysql,无密码登录


重启mysql程序
# systemctl    restart   mysqld
无密码登录
# mysql -uroot


c.修改自己的密码


mysql>UPDATE mysql.user SET authentication_string=password('QianFeng@123456789')  where  user='root'  and  host='localhost';
mysql> FLUSH PRIVILEGES;


d.修改mysql启动设置


注释掉跳过密码


4.登录MySQL


mysql   -P 3306 -u root -p123 mysql -e 'show tables'


 -h    指定主机名         【默认为localhost】


注释:    -P    MySQL服务器端口              【默认3306】    大P

              -u    指定用户名                       【默认root】

              -p    指定登录密码                    【默认为空密码】

              -e    接SQL语句


免登录查询数据库


mysql -uroot -p'QianFeng@123' -hlocalhost -P 3306 mysql -e 'show tables'


Mysql权限原理



语法格式:

 grant 权限列表  on 库名.表名 to '用户名'@'客户端主机'  [identified by '密码'  with option参数];


注释:


==权限列表:all 所有权限(不包括授权权限)

                     select,update     查询更新

==数据库.表名 : *.*   所有库下的所有表

                            web.*   web库下的所有表
                            web.box   web库下的box表

grant SELECT (id), INSERT (name,age) ON mydb.mytbl to 'user8'@'localhost' identified by 'QianFeng@123'; 


==客户端主机:    %   所有主机

                           192.168.2%   192.168.2网段的所有主机

                            192.168.119.156    指定主机

                            localhost      指定主机

==with_option参数:            GRANT OPTION   授权的选项


Mysql权限示例


赋予权限

授权目标:授予admin3 对bbs库 所有的表,具有所有权限(不包含授权)


GRANT ALL ON bbs.* TO admin3@'%' IDENTIFIED BY 'QianFeng@13910604684';


准备测试授权账户:


root账户创建:

CREATE USER admin3@'%' IDENTIFIED BY 'QianFeng@123';


root账户授权

GRANT ALL ON bbs.* TO admin3@'%' IDENTIFIED BY 'QianFeng@13910604684';


使用测试账户操作数据库

[root@localhost ~]# mysql -uadmin3 -p'QianFeng@123'
mysql> create database bbs;
mysql> create database bba;
ERROR 1044 (42000): Access denied for user 'admin3'@'%' to database 'bba'
进入bbs库,创建数据表和插入数据。授权验证完毕


回收权限


查看权限

查看自己的权限  SHOW GRANTS\G

查看别人的权限   SHOW GRANTS FOR admin3@'%'\G

回收权限REVOKE


语法:REVOKE 权限列表 ON 数据库名 FROM 用户名@‘客户端主机’

 REVOKE ALL PRIVILEGES  ON bbs.*  FROM admin3@’%’;     //回收所有权限


日志



日志分类


48a44992bdb740248b1584025a60be37.png


1 错误日志 :启动,停止,关闭失败报错。rpm安装日志位置 /var/log/mysqld.log

2 通用查询日志:所有的查询都记下来。

3 二进制日志:实现备份,增量备份。只记录改变数据,除了select都记。

4 中继日志:读取主服务器的binlog,在本地回放。保持一致。

5 slow log:慢查询日志,指导调优,定义某一个查询语句,定义超时时间,通过日志提供调优建议给开发人员。

6 DDL log: 定义语句的日志。


日志的弊端:

日志功能会 降低MySQL数据库的性能 。

日志会 占用大量的磁盘空间 。


Error Log


1)错误日志的介绍

错误日志(error log):记录MySQL服务进程mysqld在自动/关闭或远行过程中遇到的错误信息

如果哪天mysql服务起不来了,请来这个日志文件看看。


2)错误日志的设置

vim   /etc/my.cnf      进入主配置文件,观察日志是否启动。

log-error=/var/log/mysqld.log    该字段,标记是否启动日志,以及日志位置。


在my.cnf配置文件里面查看错误日志log-error

[root@linzhongniao ~]# sed -n '78,79p' /data/3306/my.cnf   
[mysqld_safe]
log-error=/data/3306/mysql_linzhongniao3306.err


Binary Log


(1)二进制日志的介绍

二进制日志(binary log):记录数据被修改的相关信息。


(2)二进制日志的设置

从库提升主库必须开启log-slave-updates


# vim   /etc/my.cnf
log_bin   添加该字段。指启动二进制日志
server-id=2   群集问题,必须指定该主机的序号。数字随意
# systemctl restart mysqld  重启数据库


测试:

a.查看二进制日志文件当前状态

ls /var/lib/mysql/*bin*    查询二进制文件生成完成

mysqlbinlog -v /var/lib/mysql/localhost-bin.000001    查看二进制文件日志

b.进入数据库,进行数据操作

c.完成二进制日志启动,查询测试

mysqlbinlog -v /var/lib/mysql/localhost-bin.000001          找到刚才创建的记录即可


Slow Query Log


MySQL的慢查询日志,用来记录在MySQL中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志中。long_query_time的默认值为10,意思是运行10秒以上(不含10秒)的语句,认为是超出了我们的最大忍耐时间值。


它的主要作用是,帮助我们发现那些执行时间特别长的SQL查询,并且有针对性地进行优化,从而提高系统的整体效率。当我们的数据库服务器发生阻塞、运行变慢的时候,检查一下慢查询日志,找到那些慢查询,对解决问题很有帮助。例如一条SQL执行超过5秒钟,我们就算慢SQL,希望能收集超过5秒的sql,结合explain进行全面分析。


默认情况下,MySQL数据库没有开启慢查询日志,需要我们手动来设置这个参数。如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会或多或少带来一定的性


慢查询日志支持将日志记录写入文件。


开启慢查询日志功能


vim   /etc/my.cnf
#加入下面2行配置
slow_query_log=1       启动慢查询日志这个参数设置为ON,可以捕获执行时间超过一定数值的SQL语句。
long_query_time=3      当SQL语句执行时间超过此数值时,就会被记录到日志中,建议设置为1或者更短。
#重启服务器
#systemctl  restart  mysqld


查看慢查询日志文件


1. #查看日志文件已经生成
2. ll /var/lib/mysql/*slow*


模拟慢查询


1. #基本测试语句,测试一个超长时间的查询
2. 
3. mysql>SELECT BENCHMARK(500000000,2*3);


验证慢查询日志


1. #观察长查询日志记录,记录了刚才超长的查询结果。稍后反馈给开发部,进行优化。
2. 
3. tail /var/lib/mysql/localhost-slow.log
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
20天前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
60 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
10天前
|
存储 SQL 数据库
深入浅出后端开发之数据库优化实战
【10月更文挑战第35天】在软件开发的世界里,数据库性能直接关系到应用的响应速度和用户体验。本文将带你了解如何通过合理的索引设计、查询优化以及恰当的数据存储策略来提升数据库性能。我们将一起探索这些技巧背后的原理,并通过实际案例感受优化带来的显著效果。
28 4
|
1月前
|
SQL NoSQL 数据库
Cassandra数据库与Cql实战笔记
Cassandra数据库与Cql实战笔记
18 1
Cassandra数据库与Cql实战笔记
|
18天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
85 1
|
24天前
|
NoSQL 关系型数据库 MySQL
MySQL与Redis协同作战:优化百万数据查询的实战经验
【10月更文挑战第13天】 在处理大规模数据集时,传统的关系型数据库如MySQL可能会遇到性能瓶颈。为了提升数据处理的效率,我们可以结合使用MySQL和Redis,利用两者的优势来优化数据查询。本文将分享一次实战经验,探讨如何通过MySQL与Redis的协同工作来优化百万级数据统计。
55 5
|
24天前
|
运维 关系型数据库 MySQL
运维|MySQL 数据库被黑,心力交瘁
前一阵有一个测试用的 MySQL 数据库被黑了,删库勒索的那种,这里记录一下事情经过,给自己也敲个警钟。
32 2
|
1月前
|
SQL 运维 关系型数据库
MySQL 运维 SQL 备忘
MySQL 运维 SQL 备忘录
46 1
|
1月前
|
架构师 关系型数据库 MySQL
MySQL最左前缀优化原则:深入解析与实战应用
【10月更文挑战第12天】在数据库架构设计与优化中,索引的使用是提升查询性能的关键手段之一。其中,MySQL的最左前缀优化原则(Leftmost Prefix Principle)是复合索引(Composite Index)应用中的核心策略。作为资深架构师,深入理解并掌握这一原则,对于平衡数据库性能与维护成本至关重要。本文将详细解读最左前缀优化原则的功能特点、业务场景、优缺点、底层原理,并通过Java示例展示其实现方式。
75 1
|
19天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第26天】数据库作为现代应用系统的核心组件,其性能优化至关重要。本文主要探讨MySQL的索引策略与查询性能调优。通过合理创建索引(如B-Tree、复合索引)和优化查询语句(如使用EXPLAIN、优化分页查询),可以显著提升数据库的响应速度和稳定性。实践中还需定期审查慢查询日志,持续优化性能。
47 0
|
1月前
|
SQL 关系型数据库 MySQL
sql注入原理与实战(三)数据库操作
sql注入原理与实战(三)数据库操作
sql注入原理与实战(三)数据库操作