首页
学习
活动
专区
圈层
工具
发布
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    bitcask的设计与实现

    背景 最近在研究LSM tree,听闻bitcask在LSM tree各种各样的应用中是一个比较简单的实现,所以就以它为突破口,了解下LSM tree真实世界的实现。...bitcask存储模型由Riak提出,github上有各种语言的实现,本人挑选了一个golang版本的实现来进行研究,源码地址是:git.mills.io/prologic/bitcask,学习过程中我添加了一些注释...,有需要的同学可以参考下:github.com/Orlion/bitcask 存储模型 与LSM tree的基本思想一样,bitcask中所有增删改操作都是追加写磁盘中的datafile,其数据结构如图...: 实际文件中是没有换行的,每个entry都是与前一个entry紧密串联在一起的,这里只是为了体现出来一个一个的entry。...总结 可以看到bitcask的实现还是非常简单(lou)的。put(k, v)加了全局锁,锁粒度较粗,并发读写性能应该不是很强。

    24310

    linux内核设计与实现

    ,并且实现了 unix的api linux没有直接使用unix的源代码,但完整表达了unix的设计目标并保证编程接口一致 2....线程在linux中的实现 4.1 liunx线程概述 一组线程共享进程内的内存地址空间,打开的文件和其他资源 线程机制支持并发程序设计技术,多处理器上保证真正的并行处理 linux实现线程的机制非常独特...调度算法 3.1 概述 linux调度程序定义与kernel/sched.c 2.5版本内核重写调度算法,和以前版本区别很大,实现以下目标 充分实现O(1)调度,不管多少进程或什么输入,每个算法能在恒定时间内完成...超级块对象 各种文件系统都必须实现超级块,该对象用于存储特定文件系统的信息,通常对应于存放在磁盘特定扇区中的文件系统控制块 超级块数据结构定义与中的super_block。...文件对象 文件对象定义与中的struct file结构体 文件操作由file_operations结构体表示 具体的文件系统定义不同的实现 6.

    3.2K52

    《redis 设计与实现》--总结

    Redis设计与实现,以及关于Redis使用的总结 1.数据结构与对象 1.简单动态字符串 Redis自己构建了简单动态字符串(Simple Dynamic String,SDS)来作为默认的字符串表示...哈希表的扩展与收缩:以下条件满足时: 服务器没有执行BGSAVE或BGREWRITEAOF命令,哈希表负载因子>1 服务器在执行BGSAVE或BGREWRITEAOF命令,哈希表负载因子>5...Redis中跳跃表的实现: ?...写入与同步:服务器每次结束一个时间循环之前,都会调用flushAppendOnlyFile函数,考虑是否将aof_buf缓冲区中的内容写入和保存到AOF文件中。...底层模型:它们之间底层实现方式以及与客户端之间通信的应用协议不一样。Redis直接自己构建了VM 机制,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求。

    1.3K40

    scheduler-设计与实现

    标签条件的节点,比如 nodeName, label, cpu, 磁盘,cpu 内存等: 这类插件包括: TaintToleration: 污点和容忍 NodeName:检查 Pod 指定的节点名称与当前节点是否匹配...: 选择资源分配较少的节点 NodeResourcesMostAllocated: 选择已分配资源多的节点 InterPodAffinity: 实现 Pod 间亲和性与反亲和性 ServiceAffinity...: 检查属于某个 Service 的 Pod 与配置的标签所定义的节点集是否适配。...几篇论文中的设计如 borg,mesos 也都是单 master + 多 slave 设计。borg 的经验告诉我们,中心化并不一定是一个性能瓶颈(数万节点,上万任务的调度频率)。...统一的 调度上层,类似 mesos/omega 或者 yunikorn 的方式,协调子调度器的关系,统一的调度层需要被精巧的设计,这种设计必须同时考虑灵活性、简洁性、功能性。

    2.2K121

    《redis 设计与实现》--总结

    Redis设计与实现,以及关于Redis使用的总结 1.数据结构与对象 1.简单动态字符串 Redis自己构建了简单动态字符串(Simple Dynamic String,SDS)来作为默认的字符串表示...哈希表的扩展与收缩:以下条件满足时: 服务器没有执行BGSAVE或BGREWRITEAOF命令,哈希表负载因子>1 服务器在执行BGSAVE或BGREWRITEAOF命令,哈希表负载因子>5...Redis中跳跃表的实现: ?...写入与同步:服务器每次结束一个时间循环之前,都会调用flushAppendOnlyFile函数,考虑是否将aof_buf缓冲区中的内容写入和保存到AOF文件中。...底层模型:它们之间底层实现方式以及与客户端之间通信的应用协议不一样。Redis直接自己构建了VM 机制,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求。

    92621

    《Redis设计与实现》读书笔记(三十二) ——Redis事务设计与实现

    《Redis设计与实现》读书笔记(三十二) ——Redis事务设计与实现 (原创内容,转载请注明来源,谢谢) 一、概述 redis的事务同数据库的事务概念一样,即多条命令都成功执行,才会生效...二、redis事务实现 redis事务实现包括事务开始、事务入队、事务执行。 1、事务开始 当客户端输入multi命令,表示事务开始。...与很多关系型数据库不同,redis不支持事务的回滚,因为redis的作者认为事务出错只有在开发环境中会有,生产环境没有。而回滚会导致redis代码复杂,与设计初衷不符。...3、隔离性 隔离性是指多个事务并发进行,各个事务不会互相影响,并且并发状态下执行事务与串行状态下执行事务结果完全相同。...4、watch命令通过数据库的redisDB结构体的watched_keys字典中,将字段与要监视的客户端进行关联,当键被修改,则相应的监视该键的全部客户端的REDIS_DIRTY_CAS标识被打开。

    1.1K50

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

    上一篇文章,我们分析并设计了关于构建引擎BuildEngine的切面设计。...本文我们将基于BuildEngine所提供的切面处理能力,在CustomCreateElementHandle中通过一些逻辑,来完成一个轻量级的设计器画布。 这个画布能够实现如下的一个简单的效果。...在后续的切面处理中,构建元素节点的时候,如果切面正在处理的节点path与selectedNodePath一致,则wrapper组件需要高亮,否则虚线。...对于这个渲染React组件,主要是将schema解析为ComponentNode结构,并交给构建引擎build,同时,我们还传入了自定义的创建过程: isSelected属性来自于当前正处理节点path与第...onClick属性的实现代码则是当wrapper组件点击后,更新selectedNodePath。

    62230

    PhxSQL设计与实现(详细版)

    之前发表过一篇ppt版的“PhxSQL设计与实现”,本文是在ppt的基础上,加上解说的文字内容,形成一篇详细版。 本文详细描述了PhxSQL的设计与实现。...从MySQL的容灾缺陷开始讲起,接着阐述实现高可用强一致的思路,然后具体分析每个实现环节要注意的要点和解决方案,最后展示了PhxSQL在容灾和性能上的成果。...设计背景 互联网应用中账号和金融类关键系统要求和强调强一致性及高可用性。当面临机器损坏、网络分区、主备手工或者自动切换时,传统的MySQL主备难以保证强一致性和高可用性。...PhxSQL设计思路 可靠日志存储 实现一个以可靠日志存储为中心的架构来解决MySQL数据复制时产生的数据不一致问题。...图10 可靠日志存储和Agent共同实现自动选主机制 PhxSQL架构和实现 从上述思路可以得出PhxSQL的简单三层架构。

    83610
    领券