STVM

C 语言编写的内存数据库
授权协议 GPL
开发语言 C/C++
所属分类 数据库相关、 数据库服务器
软件类型 开源软件
地区 国产
投 递 者 宿建本
操作系统 跨平台
开源组织
适用人群 未知
 软件概览

STVM(truck of Virtual memory table)是一个开源的使用ANSI C语言编写、支持本地API调用和网络调用,全表数据基于IPC共享内存方式存储,

基于C语言struck结构定义记录行,RB-Tree和hash作为主要算法的内存数据库,是一款介于SQL和NOSQL之间的一款高速缓存数据库, 一款将队列与数据库完美结合的缓存数据库。

数据全部存储在IPC内存中,支持本地接口和网络接口。

关于性能

在相同环境在,用本地API访问对单标操作是redis的30倍以上,网络api也快1.5倍以上, 且拥有百万级别无锁队列。

见具体测试数据:

REDIS哈希与STVM性能比较

REDIS列表与STVM无锁队列性能比较

  • STVM STVM(truck of Virtual memory table)是一个开源的使用ANSI C语言编写、支持本地API调用和网络调用,全表数据基于IPC共享内存方式存储、是一款全新的内存数据库、百万级的内存无锁队列,第一个版本于2018年3月1号提交至githup。 基于C语言struck结构定义记录行,RB-Tree和hash作为主要算法的内存数据库,是一款介于SQL和NOSQL之

  • redis-list队列功能,生产-消费模式,大多用于项目的事件驱动,本文将最近测试的REDIS列表与STVM无锁环形队列性能做以下测试报告,仅供大家参考。        由于STVM本身支持多进程,多线程,为了测试对比性,STVM网络服务启动1个线程,单张队列表,客户端采用多进程,多线程,全部采用单机部署。 注意gcc 版本必须 >= 4.1.2   测试配置: 机器配置如下: 在64位 Ubu

  • STVM STVM(truck of Virtual memory table)是一个开源的使用ANSI C语言编写、支持本地API调用和网络调用,全表数据基于IPC共享内存方式存储, 基于C语言struck结构定义记录行,RB-Tree和hash作为主要算法的内存数据库,是一款介于SQL和NOSQL之间的一款高速缓存数据库。 由于数据全部存储在内存中,相比较其他类型的缓存,运行速度之快可想而知。

  •        redis-哈希存储类似表记录,在项目中应用比较广,本文将最近测试的REDIS和STVM性能做以下测试报告。 各有应用场景(毕竟研发的出发点不同),非评论优劣好坏,测试案例也并不全面, 仅供大家参考。        由于STVM本身支持多进程,多线程,每张表都拥有独立锁,为了测试对比性,STVM网络服务启动1个线程,单张表,客户端采用多进程,多线程,全部采用单机部署。 测试配置: 机

  • STVM 高效缓存数据库 STVM(truck of Virtual memory table)是一个开源的使用ANSI C语言编写、支持本地API调用和网络调用,全表数据基于IPC共享内存方式存储,基于C语言struck结构定义记录行,RB-Tree和hash作为主要算法的内存数据库,是一款介于SQL和NOSQL之间的一款高速缓存数据库。 支持SQL基础语法(insert、update、dele

 相关资料
  • 内存分布之数据段 不管我们以后是自己写代码还是读别人的代码,都应该想想这个变量默认存储的位置。在我们以后的嵌入式开发中,技巧性的代码越来越多的时候,我们可能把某一些代码放在一段。我们可以通过修改变量或者代码默认放置的段,让它被放到其它的段中。我们也可以自己定义一个新的段。 随着运行,栈空间是随时会变化的。栈空间临时的去存储一些变量,当我们进入一个函数,系统就会在栈空间去分配一片内存去保存这个函数里

  • 1. 引言 其实我们不知道的是,早期的计算机是没有内存的,但是如今我们去买电脑时,都会十分关心电脑内存的各种参数,因此可以看出内存对于电脑性能的重要性。那么为什么需要内存呢?换句话说,内存与计算机以及程序之间的关系又是什么呢?本章将会以内存为中心,探讨许多与内存相关的概念和话题,这些概念是学好后续C语言知识不可缺少的基础,因此希望读者认真对待本章节的内容。 2. 计算机程序运行的目的 2.1 什么

  • 语言集成的相关查询是实验性的,现在暂时只支持scala。 Spark SQL也支持用领域特定语言编写查询。 // sc is an existing SparkContext. val sqlContext = new org.apache.spark.sql.SQLContext(sc) // Importing the SQL context gives access to all the p

  • 问题内容: 我知道供应商有自己的原始SQL语言子集,这些子集用C(类似于Postgre SQL)或MS-SQL Server(C ++)等编写。 那么,原始的SQL是用C编写的,还是在Assembly中创建的呢?我真的找不到关于其原始语言根源的明确答案(除了历史等) 问题答案: 在Oracle上进行的快速历史搜索得出: 在70年代后期,Ingres刚开始在加州大学伯克利分校工作时,三个从事CIA合

  • 本文向大家介绍C语言中编写可变参数函数,包括了C语言中编写可变参数函数的使用技巧和注意事项,需要的朋友参考一下 通过stdarg.h头文件为函数提供了定义可变参数列表的能力。声明一个可变参数的函数类似: void f1(int n,...); 其中n表示参数列表个数,而用省略号来表示未知参数列表。stdarg.h中提供了一个va_list类型,用于存放参数。一个大概的使用过程类似: 看一个求和的例

  • 本文向大家介绍汇编语言 寄存器内存访问原理解析,包括了汇编语言 寄存器内存访问原理解析的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了汇编语言 寄存器内存访问原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 在内存中字的存储 这段话的主要意思是:一个字=2B=16bit,CPU中是用两个内存单元储存一个字(假如获取0地址存放的字

  • 本文向大家介绍易语言读写数据库操作详解,包括了易语言读写数据库操作详解的使用技巧和注意事项,需要的朋友参考一下 1.实现效果 2.注意事项:我们先用SQLiteStudio建表以及表中字段(SQLiteStudio工具可百度下载);写程序之前对支持库进行配置,勾选Sqlite3数据库支持库而不是Sqlite数据库支持库,因为选用后者会出现一些打不开表之类的问题; 3.源码

  • 我正在努力学习汇编语言。我注意到它与Java等高级编程语言完全不同。 因此,我了解到数据传输指令遵循以下语法: 我将其视为换句话说,将值分配给内存。 我在《数据段声明》一书中看到了一个示例。 怎么会有 我会很感激任何解释。 谢谢