首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

linux内核设计实现

一. linux内核简介 1. linux简介 1.1 unix特点 unix很简洁,仅提供几百个系统调用,并有非常明确设计目的 unix所有东西都当作文件对待,这种抽象使对数据和设备都通过一套相同系统调用接口进行...内核用C语言编写,移植能力很强 进程创建迅速,独特fork调用 提供了简洁但是稳定进程间通讯原语 1.2 unix和linux linux克隆unix,但不是unix linux借鉴了unix很多设计...,并且实现了 unixapi linux没有直接使用unix源代码,但完整表达了unix设计目标并保证编程接口一致 2....线程在linux实现 4.1 liunx线程概述 一组线程共享进程内内存地址空间,打开文件和其他资源 线程机制支持并发程序设计技术,多处理器上保证真正并行处理 linux实现线程机制非常独特...调度算法 3.1 概述 linux调度程序定义kernel/sched.c 2.5版本内核重写调度算法,和以前版本区别很大,实现以下目标 充分实现O(1)调度,不管多少进程或什么输入,每个算法能在恒定时间内完成

2.9K52

以太坊一种可升级可信存证智能合约设计实现

存证作为区块链一个重要应用场景,在各个公链中都有已落地应用和服务。本文将介绍在以太坊上一种可升级存证合约设计实现。...但是大多数存证场景存证内容并不能够自证真实,比如你正在阅读文章,并不能证明作者就是六天,那么为了保证存证方上链内容是可信,这时候就需要引入第三个角色审核方。...审核方负责对存证方发起存证内容进行审核,只有审核通过内容才能够上链。 如果是在联盟环境中,审核方也有可能是取证方,联盟内成员对自己审核通过并已上链内容自然认为是可信。...3.0版 3.0版本2.0版本在架构上是一致,核心区别在逻辑层。3.0版本在逻辑层增加了存证审核方业务逻辑。...说明:合约架构图中各个层级只列出了该层级核心功能点。 四、 存证合约实现 接下来会详细讲解存证合约实现

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

    深度剖析 Linux 伙伴系统设计实现

    在上篇文章 《深入理解 Linux 物理内存分配全链路实现》 中,笔者为大家详细介绍了 Linux 内存分配在内核中整个链路实现: image.png 但是当内核执行到 get_page_from_freelist...那么本文笔者就为大家完整地介绍一下伙伴系统这部分内容,我们将基于内核 5.4 版本源码来详细讨论一下伙伴系统在内核中设计实现。 文章概要.png 1....MAX_ORDER 就是笔者在《深入理解 Linux 物理内存分配全链路实现》 “ 第一小节 "1. 内核物理内存分配接口 ” 中介绍分配阶 order 最大值减 1。...而在 Linux 内存管理架构中都是统一通过 struct page 来管理内存,复合页却是通过两个或者多个物理上连续内存页 page 组装成一个逻辑页,那么复合页管理普通页管理如何统一呢?...而是否能够窃取 fallback 迁移类型列表中页面,就是本小节介绍内容。 7. 内存释放源码实现 在 《深入理解 Linux 物理内存分配全链路实现》 中 “1.

    55831

    PXE启动原理以及普通Linux启动对比

    大家好,又见面了,我是你们朋友全栈君。 关于PXE部署详细配置文章已经有不少了,这篇文章主要讲一下PXE启动原理以及PXE启动和普通Linux启动对比。...下载完成后就会用这些资源来启动了。 这些启动资源其实就是最小操作系统(比如WindowsPE,又比如一个basic Linux kernel+initrd)。...而boot或者install所用到实体,比如磁盘或者CD-ROM,是位于远端,因此需要通过网络传输协议来做。 二、PXE启动过程和普通Linux系统启动过程对比: 1....内核引导之前不同: 普通从硬盘启动Linux系统最初是BIOS将MBR加载入内存,然后将控制权交给MBR中bootloader程序(如GRUB),bootloader程序经过几个stage加载后...内核引导之后不同: vmlinuz和initrd运行得差不多了之后,普通硬盘Linux启动就从本地硬盘加载/sbin/init并运行为1号进程,以及启动系统服务等等,而PXE启动在内核引导完成之后

    1.9K30

    nginx安装配置启动linux

    nginx安装配置 首先明白nginx是干什么,首先它是一款服务器,亲身体验非常轻量。按照一些专业说法。...它是由俄罗斯人开发。开发者伊戈尔·赛索耶夫 本文主要记录一下linux服务器配置nginx服务一些主要过程。 首先它是由c语言开发,所以我们需要去安装一些它编译环境。...很简单在我们linux根目录下面etc/profile,我们用命令进去去编辑这个文件配置 用编辑器打开来看下,这里下面的path就是用来配置环境变量地方。...修改为82 其实在配置文件修改东西后,你可以去用命令查看配置是否正确 nginx -t 启动的话直接输入这个命令就好 nginx 我们可以用这个命令去查看nginx进程相关 ps -ef...add-port=82/tcp --permanent firewall-cmd --reload 现在哦们可以去访问nginx默认界面 服务器的话,就是外网ip加上端口 这样大概就是我们初次配置以及命令启动以及访问

    2.2K10

    Linux内核设计实现》第3版

    Linux内核设计实现》第3版,英文版已经出版,中文版即将出版。...本书基于linux 2.6介绍了linux内核设计实现,涵盖了从核心内核系统应用到内核设计实现等各方面内容,主要内容包括:进程管理、调度、时间管理和定时器、系统调用接口、内存寻址、内存管理、页缓存...本书详细描述了linux内核主要子系统和特点,包括其设计实现和接口,既介绍理论也讨论具体应用,填补了linux内核理论和实践细节之间鸿沟。...能够带领读者快速走进linux内核世界,真正开发内核代码。     如果你是一名linux内核爱好者,本书内容可以帮助你大显身手。如果你是一名普通程序员,本书内容将会拓宽你编程思路。...就我们经验,内核初学者(不是编程初学者)可以从这本书着手,对内核各个核心子系统有个整体把握,包括它们提供什么样服务,为什么要提供这样服务,又是怎样实现

    1.8K20

    读书笔记|Linux内核设计实现

    Linux内核设计原理进行了细致说明,也有具体实现部分介绍,结合源码能很好理解Linux内核; 在简单翻了一遍之后,带着如下几个疑问,整理了下相关知识点: 1、内核是什么时候加载运行; 2、...根据《Linux内核设计实现》说明,CPU在某个任何特定时间点上活动必然概括为下列三种之一: 运行于用户空间,执行用户进程; 运行于内核空间,处于进程上下文,代表某个特定进程执行; 运行于内核空间...Linux设备驱动作为一个linux内核模块存在,模块都有2个接口函数,模块初始化函数和模块退出函数。 上面提到驱动程序注册。一般是由模块初始化函数来实现。...()、exit(); Linux进程创建时使用到写时拷贝技术(copy-on-write)页实现。...(2)存储微页转换表。 MMU/Cache line CPU L1/L2高速缓存 页高速缓存:Linux内核实现磁盘缓存,主要用来减少对磁盘I/O操作。

    1K20

    Linux启动流程模块管理

    ,而且还能够顺利配置多重操作系统多重启动问题,为了多重启动问题,你就不能不学 grub 这个 Linux 下优秀启动管理程序(boot loader),而在系统运行期间,你也得要学会管理内核模块...,并负责实际加载内核到内存当中解压执行,此时内核就能够开始在内存中活动啦,并检测所有硬件信息,加载相应驱动程序,等到内核加载驱动完毕,此时我们操作系统就完成整个启动过程啦,简单归纳来说,系统启动流程是这样...以上流程,就是Linux系统启动流程,你会发现systemd进程非常重要,当然这可是系统根,这些内容你最好背过,要不然面试问到的话就尴尬啦.关于BIOS开机自检MBR主引导记录想要启动一个系统首先就得让系统去加载...由于具有菜单功能,因此我们可以选择不同内核来启动,这里需要强调是,如果要装双系统应该先装windows再装linux.加载内核自检systemd功能接下来就是加载内核时候啦,由于我们Linux...,通常这些模块就是 U盘,RAID,LVM,SCSI等文件系统磁盘驱动程序,等加载完成后会自动调用 /sbin/init 将控制权交给完整Linux系统管理.当上面的工作完成后,我们系统已经可以开始工作啦

    1.3K20

    bitcask设计实现

    背景 最近在研究LSM tree,听闻bitcask在LSM tree各种各样应用中是一个比较简单实现,所以就以它为突破口,了解下LSM tree真实世界实现。...bitcask存储模型由Riak提出,github上有各种语言实现,本人挑选了一个golang版本实现来进行研究,源码地址是:git.mills.io/prologic/bitcask,学习过程中我添加了一些注释...: 实际文件中是没有换行,每个entry都是前一个entry紧密串联在一起,这里只是为了体现出来一个一个entry。...isMerging标记为false,释放写锁,此时可进行读写 索引持久化 上文提到索引是存储在内存中,这样的话进程重启后索引就需要重新构建,如果数据量多的话,可想而知进程启动得多慢。...总结 可以看到bitcask实现还是非常简单(lou)。put(k, v)加了全局锁,锁粒度较粗,并发读写性能应该不是很强。

    10410

    Titan 设计实现

    随着 SSD 价格降低,我们认为这种取舍意义会越来越明显。 设计目标 Titan 作为 TiKV 一个子项目,首要设计目标便是兼容 RocksDB。...架构实现 Titan 基本架构如下图所示: [1-Architecture.jpg] 图 1:Titan 在 Flush 和 Compaction 时候将 value 分离出 LSM-tree,这样做好处是写入流程可以和...BlobFile 有几点值得关注地方: BlobFile 中 key-value 是有序存放,目的是在实现 Iterator 时候可以通过 prefetch 方式提高顺序读取性能。...TitanTableBuilder TitanTableBuilder 是实现分离 key-value 关键。...[10-Random Key Lookup.jpg] 图 10 Random Key Lookup: Titan 拥有比 RocksDB 更卓越点读性能,这主要得益将 value 分离出 LSM-tree

    1.6K30

    GoogleTitan可信计算

    主要包括两个方面:secure boot增强和基于硬件身份加密。 当我第一眼看到这个消息时,我不由地问自己:这不就是TPM和以及TPM实现一套可信启动系吗?...Titan芯片通过SPI总线(Serial Peripheral Interface)主CPU进行通信....总结陈词: 确保服务器启动过程完整性这方面,现在比较流行2种技术:基于UEFIsecure boot 和基于TPM系统启动度量。前者需要一个前提是Firmware本身是可信和完整。...而基于TPM度量,则由于TCG在设计TPM规范时,考虑到兼容性和厂商中立性,把更多空间留给了服务厂商来实现。...相比TPM,除了提供所谓首指令完整性之外,GoogleTitan更主动地去测量服务器启动过程中每一个状态,并主动进行修改。这一点对可信计算厂商来说应该是一个很好参考。

    63520

    Android启动流程——1序言、bootloader引导Linux启动

    4大流程如下: 1、bootloaderLinux启动 2、init进程 3、zygote进程 4、systemServer启动 在某个流程内部我又会分为 1、理论知识:比如这个类作用,他父类是什么...,设立理论部分主要目的是让我们更好地理解它设计思想 2、方法跟踪:从方法这个级别一级一级跟踪,追踪溯源,看到谷歌团队到底是如何设计。...从系统角度看,Android启动程序可分为: 1、bootloader引导 2、装载启动Linux内核 3、启动Android系统 3.1、启动Init进程 3.1、启动Zygote 3.1、...下面简单介绍一下解压缩过程,也就是函数decompress_kernel实现功能:解压缩代码位置kernel/lib/inflate.c,inflate.c是从gzip源程序中分离出来,包含一些对全局数据直接引用...start_kernel是所有Linux平台进入系统内核初始化后入口函数,它主要完成剩余硬件平台相关初始化工作,在进行一些系列内核相关初始后,调用第一个用户进程——init进程并等待用户进程执行

    4.9K21

    linux生成initramfs,Linux启动过程initramfs

    Linux启动过程概述 这里先简单列一下 Linux 操作系统启动全过程: 按下电脑电源键后,电脑通电,BIOS启动; BIOS读取硬盘MBR,运行启动扇区中代码,旧系统往往需要自己写启动扇区,...而新系统基本上由专用启动软件接管了,在 Linux 世界中,目前都是用 Grub2。...由于启动扇区空间太小,放不下太复杂代码逻辑,所以 Grub2 也使用了多阶段启动策略; Grub2 负责将操作系统内核加载到内存,如果有必要,也会把 initramfs 文件加载到内存,然后将控制权交给内核...initramfs概述 Initramfs/Initrd 用于创建一个系统启动初期小型用户空间,解决复杂启动流程问题,作为真实rootfs挂载前过渡。...,二是通地操作grub.cfg启动参数实现 Like this: Like Loading… Related 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/169691

    4K20

    linux命令mysql启动,linux启动mysql命令

    linux启动mysql命令 一、总结一下: 1.linux启动mysql命令: mysqladmin start /ect/init.d/mysql start (前面为mysql安装路径)...2.linux下重启mysql命令: mysqladmin restart /ect/init.d/mysql restart (前面为mysql安装路径) 3.linux下关闭mysql命令:...在Host这一端:application,SDP,L2cap等协议 …… (L2CAP协议简介,L2CAP在BlueZ中实现以及L2CAP编程接口) 一:L2CAP协议简介: Logical Link...这样才有机会自己填充Command Code,Identi …… 摘要 我们在这里讨论是对嵌入式linux系统启动过程输出信息注释,通过我们讨论,大家会对嵌入式linux启动过程中出现、以前感觉熟悉...嵌入式linux启动信息是一个很值得我们去好好研究东西,它能将一幅缩影图呈现在我� …… Linux内核源码分析-链表代码分析 分析人:余旭 分析时间:2005年11月17日星期四 11:40:10

    20.7K10

    低代码平台前端设计实现(三)设计态画布DesignCanvas设计实现

    上一篇文章,我们分析并设计了关于构建引擎BuildEngine切面设计。...本文我们将基于BuildEngine所提供切面处理能力,在CustomCreateElementHandle中通过一些逻辑,来完成一个轻量级设计器画布。 这个画布能够实现如下一个简单效果。...在后续切面处理中,构建元素节点时候,如果切面正在处理节点pathselectedNodePath一致,则wrapper组件需要高亮,否则虚线。...: isSelected属性来自于当前正处理节点path第1点DesignCanvas组件存储path比对,如果当前正在处理及几点就是已经选中节点path,那么这个wrapper组件则被“选中...onClick属性实现代码则是当wrapper组件点击后,更新selectedNodePath。

    36530

    Redis事物设计实现

    Redis 通过 MULTI 、 DISCARD 、 EXEC 和 WATCH 四个命令来实现事务功能, 本章首先讨论使用 MULTI 、 DISCARD 和 EXEC 三个命令实现一般事务, 然后再来讨论带有...WATCH 事务实现。...下文就来介绍 WATCH 实现机制,并且看看事务系统是如何检查某个被监视键是否被修改,从而保证事务安全性。...WATCH 命令实现 在每个代表数据库 redis.h/redisDb 结构类型中, 都保存了一个 watched_keys 字典, 字典键是这个数据库被监视键, 而字典值则是一个链表, 链表中保存了所有监视这个键客户端...需要使用 redis-check-aof 工具将部分成功事务命令移除之后,才能再次启动服务器。还原之后数据总是一致,而且数据也是最新(直到事务执行之前为止)。

    57320

    邮件退订设计实现

    何为邮件退订 在平常验证码, 推广邮件中, 我们通常会在最下角找到 退订链接。通常访问它, 我们就不会再收到他们发送邮件。 但是, 如何以最简单, 最节省性能方式去实现这一功能呢?...这里使用是 sha256 payload payload是有效负荷, 其中存储了jwt签发单位, 签发时间, 有效时间, 公开信息 等, 它同样也是由这些信息json 再经过base64得出....通常情况下, payload建议包含以下字符, 但也不是必须: iss: jwt签发者 sub: jwt所面向用户 aud: 接收jwt一方 exp: jwt过期时间,这个过期时间必须要大于签发时间...nbf: 定义在什么时间之前,该jwt都是不可用. iat: jwt签发时间 jti: jwt唯一身份标识,主要用来作为一次性token,从而回避重放攻击。...发送给用户, 所有的信息仅存储在用户邮件中, 也不用担心伪造. 我们需要做只是保证密钥安全. 此时当用户需要退订时, 服务器接收到这段jwt后, 需先对齐进行验签, 判断其是否经过伪造.

    1.3K20

    短链接设计实现

    前言 短链接实现在生活中比较常见,比如我们接受到广告短信,短信会包含他们活动链接。 这个链接是进行压缩过,比较短。这样既美观也能满足字数限制,比如短信中某个字段需要在多少字符以内。 ?...更高性能设计 在电商公司,经常有很多活动,秒杀,抢红包等等,在某个时间点 QPS 会很高。...考虑到这种情况,我们引入了 openResty,它是一个基于 Nginx Lua 高性能 Web 平台。...如图示,使用 openResty 省去了业务层这一步,直达缓存层数据库层,也提升了不少性能。 最后 通常我们用分布式id + "62进制"就可以了,哈希方法可作为拓展思路。...References 【原创】这可能是东半球最接地气短链接系统设计 liaoxuefeng.com/article/1280526512029729 高性能短链设计

    2K40
    领券