- 1、本文档共67页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[计算机软件及应用]NoSQL产品性能评测
NoSQL产品性能评测
2012-12-05 杨琪科
目的
NoSQL产品的介绍。
NoSQL产品的性能对比测试。
具体的一个网站作为案列,分享下Redis,Memcache,Mongodb的使用情况和碰到的问题。
NoSQL 产品列表
Memcache
Redis
Mongdb
Oracle TimesTen
HBase
NoSQL- Memcache
Memcache是什么?
Memcache有什么特点?
Memcache在什么场景下适用?
Memcache具体怎么用?
在用Memcache中碰到的问题?
Memcache 是什么
Memcache是个高性能的基于内存的分布式缓存系统,Memcache的分布式是基于客户端的Key的hash来做均衡,是个伪分布式的系统。
Memcache有2个组件,一个客户端(java),一个服务器端c编写。
Memcache 的特点
基于内存(但是重启了后,数据丢失)。
提供简单的get,set方法。
缓存对象只能小于1M。
安装,使用比较简单。
Memcache 的使用场景
中小型网站应用中来存放非可靠性的只读数据。例如
存放用户的信息。
网站的计数。
数据库DAO前的行记录缓存。
全局的代码参数。
Memcache具体怎么用
安装
libevent 安装
wget /downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz
tar -zxvf libevent-2.0.21-stable.tar.gz
./configure -prefix=/usr
make
make install
Memcache具体怎么用
memcache 安装
wget /files/memcached-1.4.15.tar.gz
tar -zxvf memcached-1.4.15.tar.gz
./configure -with-libevent=/usr
make
make install
Memcache的启动参数
启动
./memcached -d -m 10240 -p 11211 -u root
启动参数
启动参数说明
-d选项是启动一个守护进程,后台挂起跑
-m是分配给Memcache使用的内存数量,单位是MB
-u是运行Memcache的用户
-l是监听的服务器IP地址,如果有多个地址的话,
-p是设置Memcache监听的端口
-c选项是最大运行的并发连接数,默认是1024,
-P是设置保存Memcache的pid文件
关闭
killall memcached
Memcache-Java客户端
spymemcached 官方,单线程
/code/couchbase/java
Java memcached client
/memcached
memcache-client-forjava
/p/memcache-client-forjava/
Java客户端操作Memcache
Memcache中碰到的问题
Memcache 无文件备份机制,机器重启,数据掉失。
只能存放1M的内容,有一定的局限性。
伪分布式存储,JAVA客户端做HASH的路由,
节点的增加和宕机都是会造成数据的掉失。
只提供了核心的2个get/set命令,无其他丰富的API
节点的增加和减少导致的数据问题
Hash一致性问题
解决方案
1 主从模式,主从模式之间保持数据同步.
2 一致性Hash算法.
3 Redis来代替Memcache.
Hash一致性
Hash一致性
NoSQL-Redis
Redis 是什么?
Redis 能干吗?
Redis 有什么特点?
Redis 在什么场景下适用?
Redis 具体怎么用?
在用Redis中碰到的问题?
Redis 是什么?
Redis 是一个 用c语言写的类似Memcache 的key-value的存储系统,它比Memcache提供了更多的API接口和更好的并发性能,可以支持10万并发的读写,建议用Redis代替Memcahe。
Redis 是基于内存的,因此部署Redis的机器对于内存是非常有高的要求的,Redis是会把数据实时写到内存中,再定时同步到文件。
Redis 能干嘛?
Redis 可以当作数据库来用,但是有缺陷,在可靠性上,没有Oracle关系型数据库来的稳定。
可以作为持久层的Cache层。可以缓存下面的数据库结构。
计数
排行榜样,最新浏览的数据
队列(订阅关系)
Redis 能干嘛?
Redis 可以当作数据库来用,但是有缺陷,在可靠性上,没有Oracle关系型数据库来的稳定。
可以作为持久层的Cache层。可以缓存下面的数据库结构。
计数
排行榜样,最新浏览的数据
队
您可能关注的文档
- [计算机]扫描仪推荐方案.doc
- [计算机]数字图像处理领域的二十四个典型算法及vc实现1.doc
- [计算机]数字媒体艺术.doc
- [计算机]打印及其他使用技巧.doc
- [计算机]数字媒体规划设计.ppt
- [计算机]搭建服务器.doc
- [计算机]数据库—人事管理系统.doc
- [计算机]数据库上机实验表项目三.doc
- [计算机]数字法庭管理系统软件环境配置过程.ppt
- [计算机]数据库原理实验任务S5-SQL交互式查询-单表查询-2011-2012-2.doc
- [计算机软件及应用]EXCEL2003之入门基础教程.ppt
- [计算机软件及应用]Novell IDM Solution.pdf
- [计算机软件及应用]Oracle和DB2的转换.doc
- [计算机软件及应用]rational robot.ppt
- [计算机软件及应用]SIMATIC PCS7 培训--32--硬件安装与硬件组态.ppt
- [计算机软件及应用]steel初级讲解word文档.doc
- [计算机软件及应用]UnrealScript简单教程.doc
- [计算机软件及应用]vb循环结构.ppt
- [计算机软件及应用]TP001-服务器基础知识.ppt
- [计算机软件及应用]V15 文档加密模块图文详解.doc
文档评论(0)