使用哈希索引有几个要求,满足全部三个
-
对这个页的连续访问模式必须是一样的, 即WHERE后面的限制要等价
-
以同种访问模式下访问了100次
-
页通过该模式访问了N次,其中N等于页中记录数的十六分之一。
比如,一个表中有a,b联合索引,那么访问模式可以为下面的情况
WHERE a = xxx;
WHERE a = xxx AND b = yyy
WHERE b = xxx
访问模式指的是WHERE后面的查询的条件一样,若交替执行上述的访问模式,是开启不了自定义哈希索引的。而且必须要在这个模式下访问100次,而且访问该页的时候使用同种访问模式的次数为记录数的十六分之一。
可以通过参数innodb_adaptive_hash_index来开启或禁用产生自适应哈希索引的功能(默认是开启)
SHOW VARIABLES LIKE “innodb_adaptive_hash_index”;
[]( )异步IO
采用异步IO(Asynchronous IO,AIO)的方式可以提高磁盘的操作性能
与AIO相反的是Sync IO,Sync IO是同步的,必须要IO操作执行完了、结束了,才能继续接下来的操作。
[]( )异步IO的优点
当用户发出一条索引扫描的查询,会扫描多个页,那么就会对磁盘进行多次的IO操作,如果用Sync IO的话,则是完成一次IO操作才可以进行下一次IO操作,这是没有必要的,如果使用AIO的话,则是发出一个IO请求后,可以再发出另外的IO请求,将所有的IO请求发送后,等待所有的IO请求执行成功即可。
AIO的另一个优势就是,当IO请求是连续的时候,可以进行将其合并为一个IO请求,比如这里有三个IO请求,用户需要访问3次页(space,offset),分别为(8,6)、(8,7)、(8,8),每个都分别是16KB。
那么如果使用Sync IO的话,就要执行3次请求,但AIO会先去判断,判断发现这请求的3个页是连续的,则会合并成一个请求,从(8,6)开始,读取48KB的数据。
总结
-
异步IO可以一次性发送所有请求,不必等待前面请求完成再发送
-
异步IO可以合并多个请求变为一个请求,前提是请求的数据是连续的
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
😕/bbs.csdn.net/topics/618164986)
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!