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

linux系统开机发生了什么?

在次 boot loader 存在与内存,就可以对文件系统进行查询了,同时将默认的内核镜像以及初始化内存盘镜像也被加载到内存中。...BIOS:计算机电自检完成第一个读取的地方就是就是BIOS(Basic Input Output System,基础输入输出系统),BIOS里面记录了主机板的芯片集与相关设置,如CPU与接口设备的通信频率...电脑启动,CPU逻辑电路被设计为只能运行内存中的程序,没有能力直接运行存在于软盘或硬盘中的操作系统,如果想要运行,必须要加载到内存(RAM)中。...系统将解压的内核放置在内存之中,并调用start_kernel()函数来启动一系列的初始化函数并初始化各种设备,完成Linux核心环境的建立。...rc.local就是在一切初始化工作Linux留给用户进行个性化的地方。你可以把你想设置和启动的东西放到这里。

2.4K30

Linux 系统开机发生了什么?

在次 boot loader 存在与内存,就可以对文件系统进行查询了,同时将默认的内核镜像以及初始化内存盘镜像也被加载到内存中。...BIOS:计算机电自检完成第一个读取的地方就是就是BIOS(Basic Input Output System,基础输入输出系统),BIOS里面记录了主机板的芯片集与相关设置,如CPU与接口设备的通信频率...电脑启动,CPU逻辑电路被设计为只能运行内存中的程序,没有能力直接运行存在于软盘或硬盘中的操作系统,如果想要运行,必须要加载到内存(RAM)中。...内核映像,然后把内核映像加载到内存中并把控制权交给Linux内核。...系统将解压的内核放置在内存之中,并调用start_kernel()函数来启动一系列的初始化函数并初始化各种设备,完成Linux核心环境的建立。

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

MONGODB 索引 大内存 与连锁思维

创建MONGODB 的索引,属于基本操作,但如果是一个有2T 的 collection 要一个索引,也属于基本操作,实际上量变产生质变,很多问题的考虑都不在那么简单。...MONGODB 3.4 的时候有一个参数 setParameter: maxIndexBuildMemoryUsageMegabytes: 1024 这个参数就直接为后台添加索引加速的,如果有足够的内存...,(内存的与wiretiger 无关),则会加速background 添加索引的速度。...所以大collection添加索引,就是一个量变到质变的过程,你需要考虑的问题1 你内存的大小,是否能hold 你添加的索引2 业务上访问度是否是高强度的,如果是,那你及需要考虑上面提到的方法3 oplog...的设计大小其实和你以后一些基础操作有关4 尽量抛弃旧版本,升级到 3.6 及以上的版本,这样可以快速调整oplog的大小 所以一件看上去不值得一提的索引的事情,其实如果量大到一定程度,则考虑和需要分析的问题和

2.5K10

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

借用这段逻辑地址空间,建立映射到想访问的那段物理内存(即填充内核PTE页面表),临时用一会,用完归还。这样别人也可以借用这段地址空间访问其他物理内存,实现了使用有限的地址空间,访问所有所有物理内存。...0x800FFFFF 当内核访问完0×80000000 ~ 0x800FFFFF物理内存,就将0xF8700000 ~ 0xF87FFFFF内核线性空间释放。...从上面的描述,我们可以知道高端内存的最基本思想, 借一段地址空间,建立临时地址映射,用完释放,达到这段地址空间可以循环使用,访问所有物理内存。...950MB,那么在编译内核时就需要CONFIG_HIGHMEM4G和CONFIG_HIGHMEM64G选 项,这种情况我们暂不考虑。...内核通过内核页全局目录来管理所有的物理内存,由于线性地址前3G空间为用户使用,内核页全局目录前768项(刚好3G)除0、1两项外全部为0,256项(1G)用来管理所有的物理内存

12K22

delete limit是个好习惯么 ?

那么,在日常执行 delete 时,我们是否需要养成 limit 的习惯呢?是不是一个好习惯呢? 在日常的 SQL 编写中,你写 delete 语句时是否用到过以下 SQL?...delete from t where sex = 1 limit 100; 你或许没有用过,在一般场景下,我们对 delete 是否需要 limit 的问题很陌生,也不知有多大区别,今天带你来了解一下...如果是清空表数据建议直接用 truncate,效率上 truncate 远高于 delete,应为 truncate 不走事务,不会锁表,也不会生产大量日志写入日志文件;truncate table table_name 立刻释放磁盘空间...这个例子对我们实践的指导意义就是,在删除数据的时候尽量 limit。这样不仅可以控制删除数据的条数,让操作更安全,还可以减小加锁的范围。...所以,在 delete limit 是个值得养成的好习惯。 好了,本文就带你了解这些,如果有相关疑问和好想法,请在下方留言,方便和小伙伴儿们一起讨论。

61310

delete limit是个好习惯么

喏 → MySQL专栏目录 | 点击这里 在业务场景要求高的数据库中,对于单条删除和更新操作,在delete和update后面limit 1绝对是个好习惯。...delete from t where sex = 1 limit 100; 你或许没有用过,在一般场景下,我们对 delete 是否需要 limit 的问题很陌生,也不知有多大区别,今天带你来了解一下...如果是清空表数据建议直接用truncate,效率上truncate远高于delete,应为truncate不走事务,不会锁表,也不会生产大量日志写入日志文件;truncate table table_name 立刻释放磁盘空间...这个例子对我们实践的指导意义就是,在删除数据的时候尽量 limit。这样不仅可以控制删除数据的条数,让操作更安全,还可以减小加锁的范围。...所以,在 delete limit 是个值得养成的好习惯。 好了,本文就带你了解这些,如果有相关疑问和好想法,请在下方留言,方便和小伙伴儿们一起讨论。

49630

delete limit 是个好习惯么?!

在业务场景要求高的数据库中,对于单条删除和更新操作,在删除和更新限制1绝对是个好习惯。...那么,在日常执行删除时,我们是否需要养成极限的习惯呢?是不是一个好习惯呢? 在日常的SQL编写中,您写删除语句时是否用到过以下SQL?...delete from t where sex = 1 limit 100; 你或许没有用过,在一般场景下,我们对删除是否需要limit的问题很陌生,也不知有多大区别,今天带你来了解一下,记得mark...如果是清空表数据建议直接用truncate,效率上truncate远高于删除,应为truncate不走事务,不会锁表,也不会产生大量日志写入日志文件;truncate table table_name立即立即释放删除磁盘空间...所以,在删除限制是个值得养成的好习惯。 好了,这里就带你了解这些,如果有相关疑问和好想法,请在下方留言,方便和小伙伴儿们一起讨论。 ---- ----

1K71

delete limit 是个好习惯么

delete from t where sex = 1 limit 100; 你或许没有用过,在一般场景下,我们对 delete 是否需要 limit 的问题很陌生,也不知有多大区别,今天带你来了解一下...如果是清空表数据建议直接用 truncate,效率上 truncate 远高于 delete,应为 truncate 不走事务,不会锁表,也不会生产大量日志写入日志文件;truncate table table_name 立刻释放磁盘空间...所以,在 delete limit 是个值得养成的好习惯。...delete from t where sex = 1 limit 100; 你或许没有用过,在一般场景下,我们对 delete 是否需要 limit 的问题很陌生,也不知有多大区别,今天带你来了解一下...所以,在 delete limit 是个值得养成的好习惯。

55830

delete limit是个好习惯么 ?

那么,在日常执行 delete 时,我们是否需要养成 limit 的习惯呢?是不是一个好习惯呢? 在日常的 SQL 编写中,你写 delete 语句时是否用到过以下 SQL?...delete from t where sex = 1 limit 100; 你或许没有用过,在一般场景下,我们对 delete 是否需要 limit 的问题很陌生,也不知有多大区别,今天带你来了解一下...如果是清空表数据建议直接用 truncate,效率上 truncate 远高于 delete,应为 truncate 不走事务,不会锁表,也不会生产大量日志写入日志文件;truncate table table_name 立刻释放磁盘空间...这个例子对我们实践的指导意义就是,在删除数据的时候尽量 limit。这样不仅可以控制删除数据的条数,让操作更安全,还可以减小加锁的范围。...所以,在 delete limit 是个值得养成的好习惯。 之前,给大家发过三份Java面试宝典,这次新增了一份,目前总共是四份面试宝典,相信在跳槽前一个月按照面试宝典准备准备,基本没大问题。

46830

deletelimit是个好习惯么

在业务场景要求高的数据库中,对于单条删除和更新操作,在delete和update后面limit 1绝对是个好习惯。...delete from t where sex = 1 limit 100; 你或许没有用过,在一般场景下,我们对 delete 是否需要 limit 的问题很陌生,也不知有多大区别,今天带你来了解一下...如果是清空表数据建议直接用truncate,效率上truncate远高于delete,应为truncate不走事务,不会锁表,也不会生产大量日志写入日志文件;truncate table table_name 立刻释放磁盘空间...这个例子对我们实践的指导意义就是,在删除数据的时候尽量 limit。这样不仅可以控制删除数据的条数,让操作更安全,还可以减小加锁的范围。...所以,在 delete limit 是个值得养成的好习惯。 好了,本文就带你了解这些,如果有相关疑问和好想法,请在下方留言,方便和小伙伴儿们一起讨论。

58320

ARM Linux ELF壳方案

早期的壳产品主要利用压缩加密技术对文件进行整体性保护,但随着逆向技术的提升,整体性的文件保护方案已经被攻克,于是壳产品引入虚拟机概念,可以实现函数级的代码控制流保护,加密的颗粒度更加细致,激活成功教程难度呈几何级增加...后来又出现了「自定义 Linker」等方式的保护方式,这样可以隐藏一些文件格式信息,但依旧解决不了函数被Dump的反编译问题。...虽然使用OLLVM进行保护,可以在一定程度上起到防止反编译的作用,但依旧存在很多问题。...无函数边界 通过链接器乱序再重定位,生成的指令块在可执行文件中的位置是随机的,函数保护变成了无数个随机位置的指令碎片,无法知道函数的边界。...支持工具推荐 支持ARM 虚拟化保护方案的工具:Virbox Protector 开发环境支持 Windows、Linux、macOS。

5.3K30

Linux内存描述之内存节点node--Linux内存管理(二)

CPU访问本地内存的速度比访问远程内存的速度要快 Linux适用于各种不同的体系结构, 而不同体系结构在内存管理方面的差别很大....因此linux内核需要用一种体系结构无关的方式来表示内存....因此linux内核把物理内存按照CPU节点划分为不同的node, 每个node作为某个cpu结点的本地内存, 而作为其他CPU节点的远程内存, 而UMA结构下, 则任务系统中只存在一个内存node, 这样对于...系统中的NUMA结点都是从0开始编号的 3.1 linux-2.4中的实现 pgdat_next指针域和pgdat_list内存结点链表 而对于NUMA结构的系统中, 在linux-2.4.x之前的内核中所有的节点...-3.x~4.x的实现 node_data内存节点数组 在新的linux3.x~linux4.x的内核中,内核移除了pg_data_t的pgdat_next之指针域, 同时也删除了pgdat_list链表

7.5K20

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

1 Linux如何描述物理内存 Linux把物理内存划分为三个层次来管理 层次 描述 存储节点(Node) CPU被划分为多个节点(node), 内存则被分簇, 每个CPU对应一个本地物理内存, 即一个...内存中的每个节点都是由pg_data_t描述,而pg_data_t由struct pglist_data定义而来, 该数据结构定义在include/linux/mmzone.h, line 615, 每个结点关联到系统中的一个处理器...简单来说, 页是一个数据块, 可以存放在任何页框(内存中)或者磁盘(被交换至交换分区)中 我们今天就来详细讲解一下linux下物理页帧的描述 2 页帧 内核把物理页作为内存管理的基本单位....内核提供了page_zone通过页面查找其对应的内存区域zone_t, 页提供了set_page_zone接口, 而查找到了zone, 可以通过 其struct pglist_data *zone_pgdat...3.2 内存页标识pageflags 其中最后一个flag用于标识page的状态, 这些状态由枚举常量enum pageflags定义, 定义在include/linux/page-flags.h?

7.9K11

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

2 (N)UMA模型中linux内存的机构 Linux适用于各种不同的体系结构, 而不同体系结构在内存管理方面的差别很大. 因此linux内核需要用一种体系结构无关的方式来表示内存....Linux内核通过插入一些兼容层, 使得不同体系结构的差异很好的被隐藏起来, 内核对一致和非一致内存访问使用相同的数据结构 2.1 (N)UMA模型中linux内存的机构 非一致存储器访问(NUMA)模式下...而内存管理的其他地方则认为他们就是在处理一个(伪)NUMA系统. 2.2 Linux物理内存的组织形式 Linux把物理内存划分为三个层次来管理 层次 描述 存储节点(Node) CPU被划分为多个节点..., 我们会在后面典型架构(x86)上内存区域划分详细讲解x86_32上的内存区域划分 因此Linux内核对不同区域的内存需要采用不同的管理方式和映射方式, 为了解决这些制约条件,Linux使用了三种区:...2.6 高端内存 由于能够被Linux内核直接访问的ZONE_NORMAL区域的内存空间也是有限的,所以LINUX提出了高端内存(High memory)的概念,并且允许对高端内存的访问

6.8K30

数据库“炸了”,CPU内存?或许还有更好的解决方法!

02 原因分析 众所周知,单台数据库实例的配置是有瓶颈的,特别是关系型数据库,当CPU和内存配置提高到一定程度,性能就不再提升了,即使对数据库的内核进行优化,也只能稍微抬高这个瓶颈线。...在我经历过的应用系统压力测试工作中发现,大厂提供的应用产品通常服务器压力和数据库压力是基本持平的,小的开发商提供的应用系统往往是服务器还没有明显压力,CPU、内存使用率都很低,数据库却已经“炸了”。...当已经无法通过上面方案降低数据库压力,还可以采用分布式数据库、主从读写分离数据库来横向扩展数据库性能。从原理上分析,横向扩展数据库性能是可以无限提高数据库承压能力的。...Redis缓存数据库是将数据以键值对的形式缓存在内存中的高效数据库。...纵向提高数据库配置 CPU、内存,性能提升也是有限的,幸运的是,目前大部分数据库都支持分布式架构,或主从读写分离架构。

1.3K30

Linux内存描述之内存区域zone--Linux内存管理(三)

因此相对于任何一个CPU访问本地内存的速度比访问远程内存的速度要快, 而Linux为了兼容NUMAJ结构, 把物理内存相依照CPU的不同node分成簇, 一个CPU-node对应一个本地内存pgdata_t...Linux使用enum zone_type来标记内核所支持的所有内存区域 3.1 内存区域类型zone_type zone_type结构定义在include/linux/mmzone.h, 其基本信息如下所示...位系统中, Linux内核虚拟地址空间只有1G, 而0~895M这个986MB被用于DMA和直接映射, 剩余的物理内存被成为高端内存....借用这段逻辑地址空间,建立映射到想访问的那段物理内存(即填充内核PTE页面表),临时用一会,用完归还。...进程在访问page前,wait_on_page_locked函数,使进程加入一个等待队列 访问完成,UnlockPage函数解锁其他进程对page的访问。其他正在等待队列中的进程被唤醒。

8.8K31
领券