MySQL的学习成长记

CSDN话题挑战赛第2期
参赛话题:大数据学习成长记录

前言

近几年来,随着大数据时代的到来,不管是在企业中还是在不同领域建立了数据库,可以说在管理上也是更加高效、快捷的。
数据库中的数据具有“集成”与“共享”的特点,亦即是数据库集中了各种应用的数据,进行统一构造与存储,而使它们可以被不同应用程序所使用。
对于一个刚毕业的大学生,从小就受爸爸的影响,很爱好数据库,所以毕业之后决定做一名DBA,在这里我来分享下我的MySQL学习历程。

✨ 1.数据库介绍

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。
MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。

MYSQL数据库的趋势,有2个数值很重要,全球前20大互联网网站有90%使用是使用MYSQL使用数据库,另外80%大数据平台都是与MYSQL数据库相结合。
简单来说,我这边归纳了一下5点,
1、 MYSQL数据库最为流行的开源数据库
2、 全球前20大互联网网站有18家使用了MYSQL。
3、 前10大独立软件开发商,有8家采用了MySQL数据库
4、 在云的平台架构下,市场占有率第一的云数据库。
5、 大数据平台下,80%与大数据平台所集成,因为MySQL是互联网应用,互联网负责产生内容,Hadoop负责内容消费,形成开源的趋势,OLTP在线事务使用MYSQL数据库,OLAP离线分析,使用Hadoop发展趋势。

在这里插入图片描述

✨ 2.学习心得

首先概览下mysql的知识体系:
基础:sql语句表结构设计
调优:索引、慢查询优化配置参数调优
核心原理:InnoDb存储引擎 (包括隔离级别、事务、锁、缓存池、回滚日志等等)Mysqld (包括连接管理、进程管理、查询缓存、查询优化、日志等等)
架构与运维:用户与权限、安全备份与恢复日志分布式与高可用

💞💞💞 对于零基础的童鞋
在这里插入图片描述

✨3. 数据库实践

💞💞💞 在Mysql环境下,常常由于数据磁盘满而导致Mysql故障。
下面整理了如何在Mysql环境下做好Mysql的Binlog日志空间清理的方法。
`

查看磁盘空间占用
[root@mysqlhost01 /]# df -lh

在这里插入图片描述
💞💞💞定时自动清理Binlog日志

mysql>show variables like ‘%expire_logs_days%’; --mysql 5.7
mysql> show variables like ‘%binlog_expire_logs_seconds%’ --mysql8.0
mysql8.0
mysql 8开始 expire_logs_days 废弃 启用binlog_expire_logs_seconds设置binlog自动清除日志时间
保存时间 以秒为单位;默认2592000 30天
14400 4小时;86400 1天;259200 3天;
mysql> set global binlog_expire_logs_seconds=86400;
mysql5.7
这个默认是0,也就是logs不过期,可通过设置全局的参数,使他临时生效:
mysql>set global expire_logs_days=10;

在这里插入图片描述
💞💞💞手动删除Binlog日志

第一步:登陆进入mysql,并使用 show binary logs; 查看日志文件。
mysql>show binary logs;
第二步:查看正在使用的日志文件:show master status;
mysql>show master status;
当前正在使用的日志文件是mysqlhost01-bin.000010,那么删除日志文件的时候应该排除掉该文件。
删除日志文件的命令:purge binary logs to ‘mysqlhost01-bin.000010’;
mysql>purge binary logs to ‘mysqlhost01-bin.000010’;
删除除mysqlhost01-bin.000010以外的日志文件
也可以指定其他文件名,例如mysql-bin.000003。
删除后就能释放大部分空间。

在这里插入图片描述

✨4 推荐学习书籍

以下是我的一些学习MySQL看过的书籍:
入门看的是菜鸟的SQL教程(下面讲到),实习期间看的是《MySQL是怎么样运行的》,一本简单介绍SQL原理稍微深入的书籍。
正式工作后接触了大量的金融业务,需要大量的报表和SQL调优,于是又看了《MySQL实战45讲-丁奇》,这是丁奇老师在极客时间的一门课程,讲的非常好,还有就是《MySQL排错指南》。
看完这俩,对我的MySQL能力有了质的飞跃(其实也就是豁然开朗的感觉)。因为历史遗留的SQL随着数据量激增运行太耗时了,后来开始结合慢日志进行排查和优化,对锁、binlog、redolog、索引等有了深刻印象。也相辅相成吧,结果就是让我的SQL能力也更强了。
目前(2022年04月),正在学习MySQL的高可用。这部分学习起来十分吃力,主要还是用不上,你说我想搭个高可用的分库分表数据库,领导也不放心让我搞啊,也只能是偶尔翻翻书,有个大概的印象,万一以后再用到了,我再系统的翻翻书,看看网上的案例就行了。

终于在CSDN看到了邦德老师的专栏,现在跟着学,高可用很实用,
可以把专栏分享给各位小伙伴
https://blog.csdn.net/weixin_41645135/category_11595820.html

在这里插入图片描述

✨5 OCP认证

MySQL 认证考试只有 OCP,没有和 Oracle 一样还有 OCM 认证,但 MySQL 的认证分不同版本,截止到2021年4月,MySQL 有 MySQL 5.7 OCP 和 MySQL 8.0 OCP 两个版本,2021年 2 月初取消了 MySQL 5.6 OCP 认证。

值得一说的是 MySQL 认证不需要培训课程,意思就是你可以直接参加 MySQL 的认证考试儿不需要去培训机构参加培训,这无疑是一个很便利的事情,只要你认为自己有考试的能力,可前去官网购买考券,然后网上预约考试,到期后去预约的考点线下考试,然后等待几天便可以拿到证书,无需其他额外的步骤即可获得证书。本人便是通过这种方式参加的考试获取的证书而没有去培训机构,当然参加培训你可能会获得更多的技能,但也会花费更多的 money,有利有弊

MySQL OCP 8.0 的考试代码是 1Z0-908,考试时间变成了140 分钟, 85 道选择题(包括单选和不定项多选),及格率也调整为 62%,可见难度有所增加,网上也很少有参考资料,相比于 5.7 难度提高了不少。

在这里插入图片描述

✨ 5 总结

从大学、自学一路走来,深知算法,计算机基础知识的重要性,目前专注于写这些底层知识,
提升我们的内功,帅地期待你的关注,和我一起学习。

最后还是要给大家推荐CSDN最权威的博客,能让你体系化掌握MySQL数据库
MySQL八股文连环45问,你能坚持第几问?
https://blog.csdn.net/weixin_41645135/article/details/123963994

CSDN话题挑战赛第1期
活动详情地址:https://marketing.csdn.net/p/bb5081d88a77db8d6ef45bb7b6ef3d7f

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值