- 博客(19)
- 收藏
- 关注

原创 深入浅出MySQL事务日志(redo log和undo log)
innodb事务日志包括redo log和undo log。redo log是重做日志,提供前滚操作,undo log是回滚日志,提供回滚操作。undo log不是redo log的逆向过程,其实它们都算是用来恢复的日志:1.redo log通常是物理日志,记录的是数据页的物理修改,而不是某一行或某几行修改成怎样怎样,它用来恢复提交后的物理数据页(恢复数据页,且只能恢复到最后一次提交的位置)。2.undo用来回滚行记录到某个版本。undo log一般是逻辑日志,根据每行记录进行记录。1.redo l
2020-12-10 00:33:42
1446
原创 设计模式大冒险第一关:观察者模式
所谓的观察者模式指的是一种一对多的关系,我们把其中的一叫做Subject(类比上文中的公众号),把其中的多叫做Observer(类比上文中关注公众号的用户),也就是观察者。因为多个Observer的变动依赖Subject的状态更新,所以Subject在内部维护了一个Observer的列表,一旦Subject的状态有更新,就会遍历这个列表,通知列表中每一个Observer进行相应的更新。因为有了这个列表,Subject就可以对这个列表进行增删改查的操作。也就实现了Observer对Subject。...
2022-08-30 14:29:01
176
原创 【ElasticSearch从零开始第00章】-环境准备部署centos7
和大家说明一下,我们的目的仅仅是要安装一个centos7,然后在centos7上部署ElasticSearch如果搞不定vagrant+virtualbox的方式,可以直接使用VM搭建一个centos7或者使用一台云服务器安装centos7我们的目的只是为了得到一个centos7的机器,所以不必花太多精力在这个环境问题上折腾
2022-02-20 17:19:37
1249
原创 2022考研数学李永乐线代辅导讲义PDF电子版
①2022考研数学李永乐线性代数辅导讲义pdf②2022李永乐线性代数辅导讲义严选题pdf这也放不了链接 ,请见评论关于李永乐线代的问题,可以这么说吧,李永乐老师的线代强化课程,只要全部吃透了,考研的线代就算是已经搞定90%了,还有10%左右的比较新的题型需要在一些模拟题中去自己归纳总结。比如:合工大的超越5套卷,共创五套卷,张宇8+4,李林4+6等等。 那么听课这一块,我的建议是这样的:如果你能够充分吸收李永乐老师强化班的内容,那么之听强化班的课是完全可以的,并且建议多听几遍。如果觉得太难
2022-01-10 14:24:48
3951
3
原创 解决谷歌浏览器http链接自动跳转到https的问题
有些网址http协议和https协议是两个服务,有时候需要访问http地址,但chrome会默认转成https请求地址。比如:输入 http://baidu.com 会自动跳转到 https://baidu.com这时候清理浏览器缓存之类的都是没有用的,需要进行如下操作方法一:删除浏览缓存1、打开缓存设置页面在chrome浏览器地址输入:chrome://net-internals/#hsts2、删除缓存在最下面的Delete domain security policies里输入想要删除的
2021-05-31 14:15:57
5908
原创 ES学习系列02-创建索引
索引命名业务应用日志应用业务应用商品索引:product_001店铺索引:shop_001商户索引:merchant_001日志应用系统日志:system-log-2021.01.24业务日志:product-log-2021.01.24索引创建动态创建静态创建索引别名滚动创建动态创建概念定义索引无需提前创建,第一条数据插入即可创建成功应用场景非严格数据模型限制规范的场景、日志、监控示例代码#动态创建DELETE gupaoedu-co
2021-01-26 07:34:57
2457
原创 mybatis参数格式化异常:NumberFormatException: For input string:“xx“
这是一次比较奇怪的报错,我使用的Map给MyBatis传参我MyBatis参数Map传的是11MyBatis的xml文件判断方式是:<if test="workYearEnd=='11'">报错:NumberFormatException: For input string修改为:<if test="workYearEnd=='11'.toString()">...
2021-01-14 19:39:01
344
1
原创 MySQL事务详解
InnoDB事务查看数据库事务隔离级别5.7使用show global variables like 'tx_isolation';5.8使用show global variables like 'transaction_isolation';事务定义数据库事务(简称:事务)是数据库管理系统执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成。数据库事务通常包含了一个序列的对数据库的读/写操作。包含有以下两个目的:为数据库操作序列提供了一个从失败中恢复到正常状态的方法,同时提供了
2020-12-06 21:23:00
1446
1
原创 mysql8查看 隔离级别
MySQL5.7查询方式show global variables like 'tx_isolation';MySQL8查询了官方文档,在8.0+就已经抛弃了这样的查询方法在MySQL 8.0.3 中,该变量已经被 transaction_isolation 替换了。查询方式1、select @@transaction_isolation;2、show variables like 'transaction_isolation';...
2020-12-05 16:47:56
2296
2
原创 MySQL执行计划
1. Explain表的读取顺序,数据读取操作的类型,哪些索引可以使用,哪些索引实际使用了,表之间的引用,每张表有多少行被优化器查询等信息。下面是使用explain 的例子:1.1. explain执行计划包含的信息mysql> explain select * from mysql.user;±—±------------±------±-----------±-----±--------------±-----±--------±-----±-----±---------±------+
2020-11-30 14:41:54
1448
转载 MySQL select执行流程
以一条select语句为例:select * from T where ID=4 ,梳理下执行的流程一条sql语句在执行过程中需要经过连接器、分析器、优化器、执行器等,也有可能会经过查询缓存,如图所示在这里插入图片描述连接器想要连接数据库那么必须是要通过连接器,连接器负责与客户端建立连接、获取权限、维持和管理连接。当你输入了用户名和密码后,连接器会在权限表中查询你拥有的权限,之后本次连接中你对表能否操作查询删除修改等,都依赖于此时读取到的权限。假设此时修改了你的权限,那么也是不会影响你本次的连接
2020-11-30 00:35:58
1654
转载 java.lang.UnsupportedOperationException
在项目中对List进行操作时报错java.lang.UnsupportedOperationException,后来发现操作的List是由数组转换而成的,通过看源码发现问题,并写测试程序如下。代码块:public class ListTest { public static void main(String[] args) { String[] array = {"1","2","3","4","5"}; List<String> list = Arr
2020-11-21 14:34:41
1747
原创 【ElasticSearch从零开始第01章】-Elasticsearch搭建(单点+集群)
文章目录配置Linux机器配置系统环境创建ES专用账号配置JDK14+配置单点Elasticsearch配置配置文件启动方式Kibana配置配置文件启动方式配置集群Elasticsearch配置配置文件启动方式Kibana配置配置文件启动方式效果展示图片展示命令使用配置Linux机器配置系统环境配置文件 /etc/sysctl.conf# 禁用内存与硬盘交换vm.swappiness=1# 设置虚拟内存大小vm.max_map_count=262144配置文件:/etc/security/l
2020-11-18 00:21:24
2505
1
原创 史上最全最新HashMap源码
文章目录文章总览版本区别JDK1.7JDK1.8数据结构属性解释属性定义默认属性源码解析:添加元素:红黑树化:计算阈值:数组扩容:解析resize()避免rehash()红黑树定义:文章总览JDK1.7和JDK1.8的区别属性解释put()过程解析计算thresholdJDK1.8扩容优化JDK1.7死循环图解版本区别JDK1.7数组+链表,即使哈希函数取得再好,也很难达到元素百分百均匀分布。当 HashMap 中有大量的元素都存放到同一个桶中时,这个桶下有一条长长的链表,极端情
2020-11-11 16:23:47
1999
原创 深入源码理解ReentrantLock锁
文章目录结构整体介绍AQS介绍属性stateNodeheadtailexclusiveOwnerThreadReentrantLock介绍非公平锁加锁解锁参考知识整体介绍ReentrantLock是JUC自带的一种可重入锁主要有两种锁形式公平锁非公平锁主要功能有两种加锁释放锁本质是AQS(同步等待队列),一个带头结点和尾结点的双向链表当当前节点完成任务,会唤醒队列里面的下一个可唤醒节点新的任务到来会放到队列的最后面,等待唤醒AQS介绍属性AQS同步等待队列是一个带头尾节点
2020-10-26 23:09:51
3119
原创 MySQL数据类型详细对比
文章总览MySQL常用数据类型整数类型占用空间实验步骤注意事项实数类型占用空间实验步骤:注意事项:字符类型占用空间数据说明注意事项时间类型占用空间数据说明注意事项参考文档:MySQL常用数据类型整数类型实数类型字符类型日期类型整数类型TINYINTSMALLINTMEDIUMINTINTBIGINT占用空间占用字节有符号位表示范围无符号位表示范围TINYINT1字节-128~1270~255SMALLINT2字节-32768~3276
2020-10-08 23:21:23
3923
原创 最全Centos7安装MySQL8
文章总览1、准备工作:删除旧包2、下载安装包官网地址选择系统版本选择**下载软件**3、安装MySQL8解压安装包安装数据库初始数据库启动数据库数据库状态数据库登录新密码修改3、提示:①获取初始密码②重置密码规则③报错情况处理④启动失败⑤重置密码1、准备工作:删除旧包rpm -e $(rpm -qa|grep mysql) --nodepsrpm -qa|grep mariadb //查看是否自带mariadbrpm -e packagename --nodeps //卸载包2、下载安装包
2020-10-08 23:16:48
3522
原创 MySQL binlog日志分析
总纲通用操作步骤数据初始化基于语句的日志实验步骤优点缺点基于行的日志三种形式实验步骤优点缺点混合日志总纲基于语句的日志 statement基于行的日志 row混合日志 mixed通用操作步骤查看当前日志类型show variables like 'binlog_format';设置日志格式为基于语句形式基于语句set session binlog_format=statement;基于行set session binlog_format=row;查询当.
2020-10-08 23:10:06
2913
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人