欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    Orip:基于内存数据库的海量数据实时处理解决方案(26页).doc

    • 资源ID:36727713       资源大小:155KB        全文页数:26页
    • 资源格式: DOC        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    Orip:基于内存数据库的海量数据实时处理解决方案(26页).doc

    -Orip:基于内存数据库的海量数据实时处理解决方案-第 26 页Orip:基于内存数据库的海量数据实时处理解决方案李朝铭(北京开拓天际信息技术有限公司首席架构师)2010.4.3目录Ø内存数据库简介Øorip内存数据库架构Øorip内存数据库应用开发框架Øorip内存数据库应用案例Øorip内存数据库开发什么是海量数据处理?当数据量不断突破TB、PB、EB级时,当企业关键应用开始数据大集中、应用管理大集中时,当企业数据库中心向多城市扩张时,当前的数据库体系开始面临各种发展瓶颈:如何将单一数据库通过Cluster集群方式扩展?如何利用Cache机制提高数据库访问速度、如何性能调优?如何保证数据库的备份、容灾安全、同步性、一致性?-摘自本次大会网站主页当在线用户数达到数万甚至是数百万时,当每分钟有数十万甚至数千万SQL需要处理时,当用户请求要求在秒级甚至在毫秒级得到响应时,而满足这些需求我们的money却非常有限时应选用何种数据库?数据库如何设计?其安全可靠性如何保障?-这是本演讲的主题什么是内存数据库· 什么是内存数据库?数据主要存储于内存中,具备数据库的基本功能· 为什么要使用内存数据库?一些应用要求极高的数据处理性能,而内存数据库性能远远高于基于磁盘的关系数据库;内存价格已下降· 常见的内存数据库有哪些?(Altibase、Timesten、SolidDB、BerkeleyDB、eXtremeDB .)什么是ORIP ?ORIP 是 OnDemandRealTime InformationProcessPlatform 的缩写,中文名称为“实时信息随需处理平台”。内存数据库消息中间件SOA服务平台内置了消息引擎、内存数据库引擎、SOA 服务引擎、企业信息服务总线和高可用管理模块等广泛适用于电信、金融、电力、税务、保险、证券等数据量大、实时性和可靠性要求高的行业应用运行平台动态Web服务器HA管理软件更高的综合性能· 相对传统关系数据库方式,总体性能有10倍以上的提高· DELL2950(2*4 2.5GHz CPU,16GB 内存)上并发处理平均处理能力接近每秒20万个 SQL· 在千兆网络下,ORIP单事例每秒可同时处理5万个以上的并发HTTP请求(含内存数据库访问)高可靠性· Orip提供了redo日志,保证了主机或ORIP进程在意外down掉的情况下,数据能够可靠地恢复· checkPoint机制兼顾了性能和故障恢复时间· 支持事务和非事务模式· 支持一个服务内多个事务穿插进行更高的可用性· ORIP内置高可用(HA)软件特性,可支持双机热备、双机热并行、N+1备份、多机并行等· 可在无磁盘阵列柜的情况下,实现双机数据(内存数据库)的准实时同步· 在不启用ORIP内置HA特性的情况下,可安装oripMon守护进程,将自动重启意外down掉的orip事例Ø内存数据库简介Øorip内存数据库架构Øorip内存数据库应用开发框架Øorip内存数据库应用案例Øorip内存数据库开发ORIP体系结构Orip 事例SGAMAOripConsole字典缓冲区消息缓冲区系统内核组件系统标准组件oripmgroripsql事务缓冲区数据存储区Redo日志缓冲区共享索引区用户服务组件用户服务组件用户服务组件用户服务组件网络管理字典管理缓冲区管理事务管理锁管理组件库管理客户端接口库任务管理消息管理服务管理备份管理恢复管理日志管理应用用户进程应用用户进程参数配置文件控制文件数据文件备份重做日志文件服务动态库锁文件Profile文件Orip 客户端许可文件Orip 脱机存储区Orip内存数据库管理工具oripmgroripsqloripexp/oripimporip consoleORIP HA主备示意1/3服务地址:192.168.1.3启动地址:192.168.1.1心跳地址:10.16.1.1orip主节点Redo log启动地址:192.168.1.2心跳地址:10.16.1.2orip备节点ORIP HA主备示意2/3X服务地址:192.168.1.3启动地址:192.168.1.1心跳地址:10.16.1.1orip主节点启动地址:192.168.1.2心跳地址:10.16.1.2orip备节点ORIP HA主备示意3/3服务地址:192.168.1.3启动地址:192.168.1.1心跳地址:10.16.1.1orip主节点Redo log服务地址:192.168.1.4启动地址:192.168.1.2心跳地址:10.16.1.2orip备节点Ø内存数据库简介Øorip内存数据库架构Øorip内存数据库应用开发框架Øorip内存数据库应用案例Øorip内存数据库开发内存数据库应用开发架构应用Orip Server应用内存数据库内存数据库用户服务组件用户服务组件常规嵌入式内存数据库应用开发模式ORIP嵌入式内存数据库应用开发模式Ø内存数据库简介Øorip内存数据库架构Øorip内存数据库应用开发框架Øorip内存数据库应用案例Øorip内存数据库开发支持一亿用户的电信用户帐单/余额查询系统内存表:1.用户身份认证表用户1用户2用户n2、用户余额表3、用户帐单表(每月一个)服务器配置:IBM3850 2台(每台64GB内存,4CPU),双机并行互为备份操作系统:Linux 64位支持百万用户同时在线的IM设计1/2-IM用户信息表create table imUser(userName varchar(16) primary key,uid unsigned int,petName varchar(16),password varchar(16),registerTime unsigned int);-IM 用户朋友表create table imUserFriend(uid unsigned int primary key,friendId unsigned int primary key,groupId unsigned int);-IM Uid与用户对应表create table imUserUid(uid unsigned int primary key,userName varchar(16),socketId int,ip unsigned int,port unsigned short int,offlineMsg char,status char,lastLoginTime unsigned int);支持百万用户同时在线的IM设计2/2用户2用户1X.X.1.1城市1X.X.1.2用户3Redo logX.X.2.1城市2X.X.2.2X.X.3.1城市3X.X.3.2用户5用户4Ø内存数据库简介Øorip内存数据库架构Øorip内存数据库应用开发框架Øorip内存数据库应用案例Øorip内存数据库开发Orip内存数据库开发示例1/2#include<orip_server.h>/*insert demo */Int serviceInsertDemo (char *inPara, char *outPara, int *retLen)char dbMsisdn12;char dbName32;int dbAge = 0;LDATETIME dbDt;CLI_PTR *cliPtr = NULL;cliPtr = (CLI_PTR *) mallocCli (100);cliPtr = addInsertHead (cliPtr, dbMsisdn, "mdb_demo", &trans1, &flag);cliPtr = addField (cliPtr, "msisdn", dbMsisdn, strlen (dbMsisdn), DT_CHAR,&flag);cliPtr = addField (cliPtr, "name", dbName, strlen (dbName), DT_CHAR, &flag);cliPtr = addField (cliPtr, "age", (char *) &dbAge, 4, DT_INT, &flag);cliPtr = addField (cliPtr, "dt", (char *) &dbDt, 8, DT_LDATETIME, &flag);callInsert (cliPtr, &ret);Orip内存数据库开发示例2/2#include<orip_server.h>/*select demo */intserviceSelectDemo (char *inPara, char *outPara, int *retLen)char dbMsisdn12;char dbName32;int dbAge = 0;LDATETIME dbDt;SELECT_PARA para4;CLI_PTR *cliPtr = NULL;char *ptr = NULL;char *freePtr = NULL;strncpy (dbMsisdn, inPara, 11);dbMsisdn11 = 0;para0.val = (char *) &dbMsisdn;para1.val = (char *) &dbName;para2.val = (char *) &dbAge;para3.val = (char *) &dbDt;cliPtr = (CLI_PTR *) mallocCli (100);cliPtr = addSelectHead (cliPtr, dbMsisdn, "mdb_demo", &flag);cliPtr = addFieldEmpty (cliPtr, "msisdn", DT_CHAR, &flag);cliPtr = addFieldEmpty (cliPtr, "name", DT_CHAR, &flag);cliPtr = addFieldEmpty (cliPtr, "age", DT_INT, &flag);cliPtr = addFieldEmpty (cliPtr, "dt", DT_LDATETIME, &flag);cliPtr = addWhereSign (cliPtr);ptr = callSelect (cliPtr, &ret);freePtr = ptr;if (ret >= 0)/*获取首条记录*/ret =getSelectFirstResult (&ptr, &para0, &para1,&para2, &para3,NULL);char *dt = NULL;dt = l_dttoc1 (dbDt);printf("ndbMsisdn=%s,dbName=%s,dbAge=%d,dt=%sn",dbMsisdn, dbName, dbAge, dt);free (dt);else if (ret < 0)printf ("nselect error:%dn", ret);return ret;if (freePtr)free (freePtr);return 0;演示谢谢!orip.kaitone

    注意事项

    本文(Orip:基于内存数据库的海量数据实时处理解决方案(26页).doc)为本站会员(1595****071)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开