首页
学习
活动
专区
工具
TVP
发布

面试官:mysql 表删除一半数据,表空间变小吗?

TIP:文末福利,记得领取~ 这期面试官提的问题是: MySQL 表删除一半数据,表空间是否变小?为什么? 我: 你这么问,肯定是不会?...但是磁盘上,文件不会变小。 所以,delete 命令其实只是把记录的位置,或者数据页标记为了可复用,但磁盘文件的大小是不会变的。也就是说,通过 delete 命令是不能回收表空间的。...03 新增数据 不止是删除数据造成空洞,插入数据也 如果数据是随机插入,非主键自增的,就可能造成索引的数据页分裂。...这也是为什么数据库要设置自增 ID 的主要原因 04 修改数据 不仅是插入数据,更新数据也造成空洞。很多人可能不理解这个过程,更新数据主键都没变怎么造成数据空洞呢?...其中 delete 命令是不会回收表空间的,还要通过 alter table 命令重建表,才能达到表文件变小的目的。

1.9K30

Linux内存描述之高端内存--Linux内存管理(五)

当内核想访问高于896MB物理地址内存时,从0xF8000000 ~ 0xFFFFFFFF地址空间范围内找一段相应大小空闲的逻辑地址空间,借用一。...这意味着一次临时映射导致以前的映射被覆盖。通过 kmap_atomic() 可实现临时映射。 4 页框管理 4.1 页框管理 Linux采用4KB页框大小作为标准的内存分配单元。...但是有些控制路径不能被阻塞,例如一些内核路径产生一些原子内存分配请求。尽管无法保证一个原子内存分配请求不失败,但是内核减少这中概率。...读者问,系 统启动时,内核的代码和数据不是被装入到物理内存吗?它们为什么也处于虚拟内存中呢?这和编译程序有关,后面我们通过具体讨论就会明白这一点。...这意味着一次临时映射导致以前的映射被覆盖。 通过 kmap_atomic() 可实现临时映射。 下图简单简单表达如何对高端内存进行映射 !

12K22
您找到你想要的搜索结果了吗?
是的
没有找到

Linux内存描述之内存页面page--Linux内存管理(四)

1 Linux如何描述物理内存 Linux把物理内存划分为三个层次来管理 层次 描述 存储节点(Node) CPU被划分为多个节点(node), 内存则被分簇, 每个CPU对应一个本地物理内存, 即一个...简单来说, 页是一个数据块, 可以存放在任何页框(内存中)或者磁盘(被交换至交换分区)中 我们今天就来详细讲解一下linux下物理页帧的描述 2 页帧 内核把物理页作为内存管理的基本单位...., 因此需要用virtual保存该页的虚拟地址 _refcount 引用计数,表示内核中引用该page的次数, 如果要操作该page, 引用计数+1, 操作完成-1....的内核中, struct page存储有一个指向对应管理区的指针page->zone, 但是该这hi真在吼吼被认为是一种浪费, 因为如果有成千上万的这样的struct page存在, 那么即使是很小的指针也消耗大量的内存空间...3.2 内存页标识pageflags 其中最后一个flag用于标识page的状态, 这些状态由枚举常量enum pageflags定义, 定义在include/linux/page-flags.h?

7.9K11

Linux内存描述之概述--Linux内存管理(一)

处理机访问本地存储器是比较快的,但访问属于另一台处理机的远程存储器则比较慢,因为通过互连网络产生附加时延 NUMA 的主要优点是伸缩性。...这种方式非常适用于 CPU 数量相对较少的情况,但不适用于具有几十个甚至几百个 CPU 的情况,因为这些 CPU 相互竞争对共享内存总线的访问。...2 (N)UMA模型中linux内存的机构 Linux适用于各种不同的体系结构, 而不同体系结构在内存管理方面的差别很大. 因此linux内核需要用一种体系结构无关的方式来表示内存....”不同, 访问不同簇的代码也不同....2.6 高端内存 由于能够被Linux内核直接访问的ZONE_NORMAL区域的内存空间也是有限的,所以LINUX提出了高端内存(High memory)的概念,并且允许对高端内存的访问

6.8K30

Linux内存管理

本篇介绍 本篇介绍下Linux内存管理,用系统角度看内存的寻址和分配机制。 内容介绍 内存管理应该是系统中最难的模块之一了,而且历史也悠久,就先来简单回顾下。...分页机制可以完全避免内存碎片问题么? 公布下答案: 的确有分页机制就可以完全不需要分段机制,目前linux是在分段的基础上实现了分页,这个也有考虑到是兼容性问题。...分页机制只是将内存管理的粒度变小了,不过还是不能完全避免内存碎片问题,只是目前的内存碎片一定会小于页框大小,比起之前的方案已经改进很多了。...对于系统,所有的mm_struct串成一个链表,对于进程,所有的vma_ares_struct也串成一个链表,这样就可以遍历一个进程使用的所有虚拟内存空间。...mmap流程如下: image.png 缺页异常 linux 是在不得不使用物理内存的时候才会分配物理内存。这句话该怎么理解呢?

13.4K50

Linux 内存管理

操作系统内存管理包括物理内存管理和虚拟内存管理:       我们这篇主要介绍Linux的虚拟内存管理。...但你不必担心他们碰头,因为他们之间间隔很大(到底大到多少,你可以从下面的例子程序计算一下),绝少有机会能碰到一起。 下图简要描述了进程内存区域的分布: 二....程序代码产生逻辑地址,或者说是段中的偏移地址,加上相应段的基地址就生成了一个线性地址。如果启用了分页机制,那么线性地址可以再经变换以产生一个物理地址。...把页装入物理内存。   ·   五.swap对换空间 ----      32位Linux系统的每个进程可以有4 GB的虚拟 内存空间 ....例如:32位Linux的每个用户进程都可以访问4GB的线性地址空间, 而实际的物理内存可能远远少于4GB. 采用分页机制 ,Linux仅把可执行映像的一小部分装入物理内存

7.3K10

Linux内存修改

作为物理内存的扩展,Linux会在物理内存不足时,使用交换分区的逻辑内存,内核会把暂时不用的内存块信息写到交换空间,这样物理内存就得到了释放,这块儿内存就可以用于其他目的,而需要用到这些内容的时候,这些信息就会被重新从交换分区读入物理内存...Linux内存管理采用的是分页存取机制,为了保证物理内存得到充分的利用,内核会在适当的时间把物理内存中不经常使用的数据块儿自动交换到虚拟内存中,而将充分使用的信息保留到物理内存中。...当那些程序要再次重新运行时,再从Swap分区或虚拟内存文件中恢复之前保存的数据到内存中。...该swap虚拟磁盘失效,为保证永久生效,还需往/etc/fstab文件添加分区信息:) [20210506232009464.png]         再次使用 cat /proc/swaps 查看swap...IO开销,特别是,如果内存使用率已经非常高,而同时IO性能也不是很好的情况下,该机制其实起到相反的效果:不仅系统性能提升较小(因为内存使用率已经非常高了),而且由于频繁的内存到Swap的切换操作,导致产生大量额外的

13.1K41

JS哪些操作造成内存泄露

(1)意外的全局变量引起的内存泄露。 function leak(){ leak=“xxx”;//leak成为一个全局变量,不会被回收 } (2)闭包引起的内存泄露。...(4)被遗忘的定时器或者回调 5)子元素存在引起的内存泄露。21,什么是闭包,如何使用它,为什么要使用它? 闭包就是能够读取其他函数内部变量的函数。...它的最大用处有两个,一个是前面提到的可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。...使用闭包的注意点: · 由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。

1.3K11

ThreadLocal真的造成内存泄漏吗?

前几天有位小伙伴问我一个问题,说ThreadLocal是不是真的造成内存泄漏?今天给大家做一个分享,个人见解,仅供参考。如果大家有其他见解可以在评论区讨论。...在多线程并发访问同一个共享变量的情况下,如果不做同步控制的话,就可能导致数据不一致的问题,所以,我们需要使用synchronized加锁来解决。...3、造成内存泄漏的原因 内存泄漏和ThreadLocalMap中定义的Entry类有非常大的关系。...也随之被回收。...问题是,线程本身是非常珍贵的计算机资源,很少会去频繁的创建和销毁,一般都是通过线程池来使用,这就将线程的生命周期大大拉长,「内存泄漏」的影响也越来越大。 最后,一句话总结一下。

54510

为什么Handler导致内存泄漏?

,因此这次和大家分享一下什么情况下导致内存泄漏,以及内存泄漏背后的故事。...1.Handler在什么情况下导致内存泄漏 Handler在使用过程中,什么情况导致内存泄漏?...,我们首先需要分析一下为什么导致内存泄漏。...以及藏在内存泄漏背后的事。 2.为什么导致内存泄漏 上面的两段代码导致内存泄漏,为什么导致内存泄漏呢?这个问题也很好回答,因为匿名内部类和默认的内部类持有外部类的引用。...其实内存泄漏在不管什么语言,什么平台上,都是有可能发生的,而我们需要自己去主动关注这个方面,在编写代码的时候尽量规避掉一些可能导致内存泄漏的代码。

1.1K30

Linux 内存池【转】

内存池(Memery Pool)技术是在真正使用内存之前,先申请分配一定数量的、大小相等(一般情况下)的内存块留作备用。...当有新的内存需求时,就从内存池中分出一部分内存块,若内存块不够再继续申请新的内存。这样做的一个显著优点是尽量避免了内存碎片,使得内存分配效率得到提升。...不仅在用户态应用程序中被广泛使用,同时在Linux内核也被广泛使用,在内核中有不少地方内存分配不允许失败。...作为一个在这些情况下确保分配的方式,内核开发者创建了一个已知为内存池(或者是 "mempool" )的抽象,内核中内存池真实地只是相当于后备缓存,它尽力一直保持一个空闲内存列表给紧急时使用,而在通常情况下有内存需求时还是从公共的内存中直接分配...,这样的做法虽然有点霸占内存的嫌疑,但是可以从根本上保证关键应用在内存紧张时申请内存仍然能够成功。

4.8K50

Linux用尽内存

原文地址:当Linux用尽内存 作者:platinaluo Mulyadi Santosa 也许你很少面临这一情况,但是一旦如此,你一定知道出什么错了:可用内存不足或者说内存用尽(OOM)。...如果你仔细看,你会发现B用1填满得到的内存,而A几乎不拿他们干什么。Linux允许推迟的页分配, 换句话说,只当你真的要用的时候才开始分配动作,比如写入数据时。...因为内存块的不连续,有时CPU L1和L2的缓冲欠满,虚拟连续的内存分散在不同的物理缓冲行,减慢连续的内存访问。 内存分配包括两步:第一步扩展内存区域的长度,然后根据需要分配页。这就是按需分页。...和overcommit配合, malloc()因为认为不能申请自由页而返回NULL,从而避免了OOM。 内存泄露是不必要的内存消耗。...总是查询内存分配统计 linux内核提供了/proc/meminfo来找到内存状态信息。top free vmstat的信息皆来于此。 你需要检查的是自由的和可回收的内存

4.9K31

Linux内核高端内存

Linux内核地址空间划分 通常32位Linux内核地址空间划分0~3G为用户空间,3~4G为内核空间。注意这里是32位内核地址空间划分,64位内核地址空间划分是不同的。 ?...Linux内核高端内存的理解 前面我们解释了高端内存的由来。...当内核想访问高于896MB物理地址内存时,从0xF8000000 ~ 0xFFFFFFFF地址空间范围内找一段相应大小空闲的逻辑地址空间,借用一。...借用这段逻辑地址空间,建立映射到想访问的那段物理内存(即填充内核PTE页面表),临时用一,用完后归还。这样别人也可以借用这段地址空间访问其他物理内存,实现了使用有限的地址空间,访问所有所有物理内存。...这意味着一次临时映射导致以前的映射被覆盖。通过 kmap_atomic() 可实现临时映射。 常见问题: 1、用户空间(进程)是否有高端内存概念? 用户进程没有高端内存概念。

4.3K31
领券