首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL案例:各类临时文件的存放位置

前言 在MySQL中,存在各种各样的临时文件,其存放位置是五花八门,且不同版本也不尽相同,主要包括以下: (1)SQL执行过程中using filesort产生的临时文件 (2)SQL执行过程中using...(2)SQL执行过程中using temporary产生的临时文件,存放在临时空间。 (3)binlog cache产生的临时文件,存放位置由tmpdir决定,以ML开头。...(4)未使用ROW_FORMAT=COMPRESSED创建的InnoDB临时结构存放在tmpdir,以#sql开头frm结尾;数据存放在临时空间。...(5)使用ROW_FORMAT=COMPRESSED创建的InnoDB临时存放位置由tmpdir决定,以#sql开头,以frm/ibd结尾。...(8)Online DDL过程中产生的临时日志(记录DML操作),存放位置由tmpdir决定,以ib开头。

6.2K161

一文看懂影子和扩展

后引入机制,把虚拟地址送往MMU,MMU查TLB不中的情况下,依次查就可以找到对应的物理地址。...二.影子 (Shadow page table) 影子我用一句话来描述就是:VMM把Guest和Host中的合并成一个,称为影子,来实现GVA->HPA映射。...4, 把GVA -> HPA,这一路的映射关系记录到中,这个就是影子。...虚拟机和影子通过一个哈希建立关联(当然也有其他的关联方式),客户机操作系统把当前进程的基址载入PDBR时而VMM将会截获这一特权指令,将进程的影子基址载入客户机PDBR,使客户机在恢复运行时...硬件层面引入EPTP寄存器,来指向EPT基地址。Guest运行时,Guest被载入PDBR,而 EPT 被载入专门的EPT 指针寄存器 EPTP。

1.4K20

Linux中PGD、PUD、PMD等概念介绍

1、PGD: Page Global Directory Linux系统中每个进程对应用户空间的pgd是不一样的,但是linux内核 的pgd是一样的。...当创建一个新的进程时,都要为新进程创建一个新的页面目录PGD,并从内核的页面目录swapper_pg_dir中复制内核区间页面目录项至新建进程页面目录PGD的相应位置,具体过程如下:do_fork()...可以看出Linux系统中每个进程的页面目录的第二部分是相同的,所以从进程的角度来看,每个进程有4G字节的虚拟空间,较低的3G字节是自己的用户空间,最高的1G字节则为与所有进程以及内核共享的系统空间。...每个进程有它自己的PGD( Page Global Directory),它是一个物理,并包含一个pgd_t数组。...每一个表项指向一个框,框就是真正的物理内存

3.1K30

内核调试

一、配置内核 首先配置内核,使其支持导出内核到debugfs下面: Kernel hacking ---> ---> [*] Export kernel pagetable layout to...start] - [PCI I/O end]同上,专门用于PCI设备使用的地址空间,一般映射大小为16M [vmemmap start] - [vmemmap end]对与ARM64用于page映射区,linux...地址空间port属性说明 第一列 当前的映射范围地址 第二列 代表此映射范围大小 PMD PUD PTE 当标识为PMD PUD表示当前映射为block映射,如当前为4K,则pud的block映射一次性可映射...当标识为PTE表示为映射即PAGE_SIZE大小4K。 USR AP标记,用于标识当前范围是否在用户空间还是内核空间可读可写或者仅读。...x表述当前范围特权级别模式可执行,就是内核的可执行代码段,在内核中这段一般指向内核的text*段 SHD 表示可共享属性,在arm64上表述为多核之间可共享其可见 AF 访问标志,当首次映射时,

13010

Linux内核管理-那些鲜为人知的秘密

,而管理是在虚拟内存管理中尤为重要,本文主要以回答几个管理中关键性问题来解析Linux内核管理,看一看管理中那些鲜为人知的秘密。...存放在物理内存中,打开mmu之后,如果需要修改,需要将所在的物理地址映射到虚拟地址才能访问(如内核初始化后会将物理内存线性映射,这样通过物理地址和虚拟地址的偏移就可以获得物理地址对应的虚拟地址...表项中存放是虚是实? 基地址寄存器和各级表项中存放的都是物理地址,而不是虚拟地址。 5. 开启mmu后地址转换过程?...Linux内核为何使用多级?...2)Linux内核 填写,将基地址告诉mmu 内核初始化建立内核,实现缺页异常等机制为用户任务按需分配并映射。 当然,内核也可以遍历,如缺页异常时遍历进程。 10.

1.7K21

深入理解Linux内核映射分页机制原理

,再依次找到下级,所有的存放在内存中,访问内存是需要额外的时间消耗的,相对于CPU对寄存器的访问,Cache的访问速度而言,内存的访问速度是灾难性的,何况还是多次访问。...因此实际的应用可能会更“聪明”,用户进程在请求地址空间时,可以因需求选择合适的大小,这样既可以满足数据的存放,同时占用更少的TLB表项。...而Linux有一个三层的结构,可以很容易地将其包装成适合两层的结构—只使用PGD和PTE。但是,Linux还要求每个页面有一个“PTE”,而且至少要有一个“dirty”位。...ARMv7属性的定义分为Linux版本的和ARMv7硬件的Linux版本的PTE属性定义加入前缀L_,如下所示: /* * "Linux" PTE definitions....APX位置位,设置为只读权限 tst r1, #L_PTE_USER orrne r3, r3, #PTE_EXT_AP1 tst r1, #L_PTE_XN orrne r3, r3,

2.8K10

Linux-3.14.12内存管理笔记【建立内核(1)】

前面已经分析过了Intel的内存映射和linux的基本使用情况,已知head_32.S仅是建立临时,内核还是要建立内核,做到全面映射的。...建立内核前奏,了解两个很关键的变量: max_pfn:最大物理内存页面帧号; max_low_pfn:低端内存区(直接映射空间区的内存)的最大可用帧号; max_pfn 的值来自setup_arch...Linux是一个支持多硬件平台的操作系统,各种硬件芯片的分页并非固定的2级(全局目录和),仅仅Intel处理器而言,就存在3级的情况(全局目录、中间目录和),而到了64位系统的时候就成了4...所以Linux为了保持良好的兼容性和移植性,系统设计成了以下的4级分页模型,根据平台环境和配置的情况,通过将上级目录和中间目录的索引位设置为0,从而隐藏了三级目录和中间目录的存在。...此外还有一个准备操作,在setup_arch()函数中调用的缓冲区申请操作: early_alloc_pgt_buf(): 【file:/arch/x86/mm/init.c】 void __init

1.8K41

Linux基础教程:Linux目录的分类存放规则

/bin 存放最基本的可执行文件。这里主要存放的一些所有用户都可以用的一些最基本的命令执行文件。如ls,cd之类的。这里面的命令可以在单用户下执行。.../dev存放各种设备文件,如硬盘,鼠标,键盘之类的。/dev/sda /dev/null 等 /etc主要存放各种配置文件。一些开机启动进程的配置文件就在这里面。如vsftpd。.../etc/init.d存放开机启动脚本文件。 /lib 存放一些开机时用到的系统链接库文件。/lib/modules放置了核心驱动模块。 /media存放挂载点的目录。.../proc存放内存中的一些缓存文件,都存放在内存中,并不占用硬盘空间。常用的/proc/cpuinfo查看cpu信息。可以用du 来查看其占用量,发现其大小均为0!.../sys存放与核心相关的一些信息,也是存放于内存中,不占用硬盘空间

1.5K00

技术分享 | MySQL 内部临时是怎么存放

MySQL 8.0 内部临时存放方式的变化。...:如果内部临时转化为磁盘临时,则这个参数指定了磁盘临时的存储引擎,默认是 INNODB,还可以设置为 MYISAM; innodb_temp_data_file_path:指定了临时空间的位置和大小...但是你想想,关系型数据库设计了存储引擎这么好的东西来存放数据,这时候用文件来存是不是过分了点?估计官方是这么想的:哎呀内部临时很小的,我就临时放放,你忍忍。...新参数: innodb_temp_tablespaces_dir :定义了创建会话临时空间的位置,默认位置是数据目录中 #innodb_temp的目录 shell> ls datadir/#innodb_temp...,存放在 innodb 会话临时空间中,与 MySQL 5.7 的区别是,session 断开后就会释放空间,不需要重启 MySQL : 可以看到临时文件数量不变,磁盘临时数量+1: ----

2.4K10

多级的好处

,如果只使用了一个,一个表项的大小为4byte,32位系统有4GB的物理空间(一个进程看到是4GB大小的虚拟空间),每一个表项对应着物理空间的第xxx(4KB大小的),那么应该有4GB/4KB=...如果是二级,规则就会改变,让二级对应到物理内存上的4KB大小的,一级此时变成映射为物理地址的4MB(这样子是无法定位到具体的(4KB)的,所以二级再去找),这样先找到一级,一级再和二级进行结合...,二级表相当于一级4MB分成了1024个(1KB个)4KB,找完后二级充当了offset的角色,此时定位到具体的4KB的页面,再用一级的offset一结合定位到具体物理地址。...这样一个进程浪费掉的空间是一级占用的:(4GB/4MB)*4byte=4KB,二级浪费掉的是1kb(1个一级占用这么多)*1kb(此时有1kb(4GB/4MB)个一级)=4MB,加起来是...4MB+4KB,比光用一级要多4KB,但是2级是可以不存在的,比如此时程序只用了%20的,那么4MB就需要乘以%20,这样一下子就比只有一级时少了。

1.6K30

Linux从头学16:操作系统-如何把【目录和】当做普通物理进行操作的?

进行"自操作" 在 x86 系统中,内存管理中的分页机制是非常重要的,在Linux操作系统相关的各种书籍中,这部分内容也是重笔浓彩。...如果你看过 Linux 内核相关书籍,一定对下面这张图又熟悉、又恐惧: 这是 Linux 系统中,处理单元的多级查询方式。...文章链接在此:Linux从头学15:【目录和】-理论 + 实例 + 图文的最完全、最接地气详解!,但是其中有一个环节被特意忽略过去了。...在上一篇文章中,我们举了这样一个示例: 假设实际的物理内存是1 GB; 用户程序文件在硬盘上的长度是20 MB; 操作系统把用户程序加载到内存中时,从 0x4000_0000 的虚拟内存地址处开始存放...详细的讨论过程,请参考上一篇文章:Linux从头学15:【目录和】-理论 + 实例 + 图文的最完全、最接地气详解!。

1.5K20
领券