外存 正在参加 2020 年度 OSC 中国开源项目评选,请投票支持!
外存 在 2020 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
投票让它出道
已投票
授权协议: GPL
开发语言: C/C++
操作系统: 跨平台
收录时间: 2014-12-05
提 交 者: 火羽

1.什么是外存

Exist 外存本质上是一个内存级别的nosql。 它提出了“面向变量”的数据访问思想,让用户只见变量,不见接口,省去了繁琐的接口调用。

以此实现了逻辑与数据分离的效果,一份单结点代码自动达到分布式效果。

目前提供了int8、uint8、uint64、float、double等基础类型变量的操作,后续将实现map vector类型变量操作。

2.应用场景对比

来看看面向变量的接口方式比传统数据接口方式要方便多少

场景1:假设服务上有3个逻辑:用户登录时,用户发表文章,用户发表评论时,要提升用户等级 。

申明数据库连接 db;
db.connect();
OnLogin()
{
    申明变量 level
    get(表名,"level", level);
    level++;
    set(表名,"level", level);
}
OnSend()
{
    申明变量 level
    get(表名,"level", level);
    level++
    set(表名,"level", level);
}
OnReply()
{
    申明变量 level
    get(表名,"level", level);
    level++
    set(表名,"level", level);
}

面向变量的访问方式

Exist::int32 m_var("level");//申明变量
OnLogin()
{
    var++;//数据已经在外存服务器上修改,下次访问将在新值基础上
}
OnSend()
{
    var++;//数据已经在外存服务器上修改,下次访问将在新值基础上
}
OnReply()
{
    var++;//数据已经在外存服务器上修改,下次访问将在新值基础上
}

就这么简单,用户直接看到一个个的变量,就像操作内存上的变量一样操作数据,根本不需要任何接口,外存由此得名

场景2:100万用户同时在线:用户A要查询用户B的资料

  • 传统接口方式

m_otherNode;//其它结点/中转定位服务
std::map<...> m_userList;//已经登录当前结点的用户的列表
OnFindUser( char *username )
{
        map::iterater it = m_userList.find(username);
        if ( it == m_userList.end() )//用户未必再当前结点登录,
        {
                m_otherNode.Send("查询用户数据");//到其它结点,或其它定位服务中专查询
                m_otherNode.Recv();
                if (回应用户不存在) 
                {
                        回应用户不存在;
                        return;
                }
        }
        回应用户信息
        return;
};

面向变量接口方式

Exist::map<...> m_userList;//已经登录的用户的列表,用户信息在外存上
OnFindUser( char *username )
{
        map::iterater it = m_userList.find(username);
        if ( it == m_userList.end() )//用户要么在外存中,要么不存在
        {
                回应,用户不存在;
                return;
        }
        回应用户信息;
        return;
};

省去了到其它结点查询的代码,省去了记录相关服务的连接对象,一套代码同时满足单结点与分布式需求,从此没有分布式一说
map与vector尚未实现,将在后续版本中实现,请期待

支持平台:win linux
性能:单个client测试,win 5000~6000tps,linux 最高达到3.7万tps
支持编译:VC++6.0和VS2010,VS2010以下用户可以从 VC6.0工程转换,linux直接make

欢迎各路朋友一起体验尝鲜

展开阅读全文

代码

的 Gitee 指数为
超过 的项目

外存 的相关资讯

还没有任何资讯

外存 的相关博客

NOSQL

一、NoSQL介绍 前期一直用的数据库mysql,属于关系型数据库。现介绍一款非关系型数据库——NoSQL;NoSQL=Not Only SQL,意为“...

NoSQL上

概念 NoSQL 泛指非关系型的数据库。近年来,非关系型数据库非常迅速的发展,为了解决大规模数据集合多重数据种类带来的挑战,...

NOSQL

NoSQL的介绍: 非关系型数据库就是NoSQL,关系型数据库代表MySQL 对于关系型数据库来说,是需要把数据存储到库、表、行、字段...

NoSQL

NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,是一项全新的数据库革命性运动,早期就有人提出,发展至2009年趋势越发...

NoSQL

NoSQL,指的是非关系型的数据库。随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的...

NoSQL

一、什么是NoSQL? NoSQL关系数据库库管理系统的统称。 两者存在许多显著的不同点,其中最重要的是 NoSQL 不使用 SQL 作为查询...

NoSQL概述-从Mongo和Cassandra谈谈NoSQL

分两部分介绍NoSQL - NoSQL 概览 1. RDBMS VS NoSQL 2. NoSQL 种类 3. NoSQL 的一些名词 - 结合Mongo,Cassandra谈谈NoSQL的设...

NoSQL数据库---NoSQL数据库的分类

NoSQL数据库的分类 个人理解一下文档型数据库: 就是键值对数据库的升级,允许键值之间嵌套键值,比如JSON格式的数据。效率比k...

nosql

nosql

NoSQL下

set操作 Set是不重复的list sadd(name,values) r.sadd("set_name","aa","bb") smembers(name) 获取name对应的集合的所有成员 ...

外存 的相关问答

还没有任何问答,马上提问

评论 (0)

加载中
更多评论
0 评论
6 收藏
分享
返回顶部
顶部