1.mongodb          
基于文档存储,也有数据关联, 单条记录 的结构可以很复杂,索引也可以设置很多列;还有个二进制文件存储模块,貌似很多公司都在用这个存储图片、文档,很爽;感觉使用MongoDB解决一般的应用都没有啥问题;安全管理方面不是强项; 使用过MongoDB,会觉得这个用起来很不错;

mongodb的delete会将该行的数据标示为已删除,因为mongodb在删除记录时并不是真把记录从内存或文件中remove,而是将该删除记录数据置空(写0或特殊数字加以标识)同时将该记录所在地址放到一个list列表“释放列表”中,这样做的好就是就是如果有用户要执行插入记录操作时,mongodb会首先从该“释放列表”中获取size合适的“已删除记录”地址返回,这种方法会提升性能(避免了malloc内存操作),同时mongodb也使用了bucket size数组来定义多个大小size不同的列表,用于将要删除的记录根据其size大小放到合适的“释放列表”中。
2、Hbase的delete是先新建一个tombstonemarkers,然后读的时候会和tombstonemarkers做merge,在 发生major compaction时delete的数据记录才会真真删除。
1、Mongodb bson文档型数据库,整个数据都存在磁盘中

2、hbase是列式数据库,集群部署时每个familycolumn保存在单独的hdfs文件中。

1、Mongodb 主键是“_id”,主键上面可以不建索引,记录插入的顺序和存放的顺序一样

2、hbase的主键就是row key,可以是任意字符串(最大长度是 64KB,实际应用中长度一般为 10-100bytes),在hbase内部,row key保存为字节数组。存储时,数据按照Row key的字典序(byte order)排序存储。设计key时,要充分排序存储这个特性,将经常一起读取的行存储放到一起。

1、Mongodb支持集合查找,正则查找,范围查找,支持skip和limit等等,是最像mysql的nosql数据库
2、而hbase只支持三种查找:通过单个row key访问,通过row key的range,全表扫描

1、mongodb的update是update-in-place,也就是原地更新,除非原地容纳不下更新后的数据记录。
2、而hbase的修改和添加都是同一个命令:put,如果put传入的row key已经存在就更新原记录,实际上hbase内部也不是更新,它只是将这一份数据已不同的版本保存下来而已,hbase默认的保存版本的历史数量是3。★、mongodb和hbase都支持mapreduce,不过mongodb的mapreduce支持不够强大,如果没有使用mongodb分片,mapreduce实际上不是并行执行的
★、mongodb支持shard分片,hbase根据row key自动负载均衡,这里shard key和row key的选取尽量用非递增的字段,尽量用分布均衡的字段,因为分片都是根据范围来选择对应的存取server的,如果用递增字段很容易热点server的产生,由于是根据key的范围来自动分片的,如果key分布不均衡就会导致有些key根本就没法切分,从而产生负载不均衡。
1、mongodb的读效率比写高,
2、hbase默认适合写多读少的情况,可以通过hfile.block.cache.size配置,该配置storefile的读缓存占用Heap的大小百分比,0.2表示20%。该值直接影响数据读的性能。如果写比读少很多,开到0.4-0.5也没问题。如果读写较均衡,0.3左右。如果写比读多,果断默认0.2吧。设置这个值的时候,你同时要参考hbase.regionserver.global.memstore.upperLimit,该值是memstore占heap的最大百分比,两个参数一个影响读,一个影响写。如果两值加起来超过80-90%,会有OOM的风险,谨慎设置。
1、hbase采用的LSM思想(Log-Structured Merge-Tree),就是将对数据的更改hold在内存中,达到指定的threadhold后将该批更改merge后批量写入到磁盘,这样将单个写变成了批量写,大大提高了写入速度,不过这样的话读的时候就费劲了,需要merge disk上的数据和memory中的修改数据,这显然降低了读的性能。
2、mongodb采用的是mapfile+Journal思想,如果记录不在内存,先加载到内存,然后在内存中更改后记录日志,然后隔一段时间批量的写入data文件,这样对内存的要求较高,至少需要容纳下热点数据和索引。
1、Mongodb支持二级索引
2、而hbase本身不支持二级索引

Hbase 与 MongoDB的区别相关推荐

  1. HBase和MongoDB的区别和联系

    HBase和MongoDB的区别和联系 小组轮到我做技术分享,由于最近MongoDB用的比较多,就想着和之前用到的HBase做下对比,以此加深理解,恰好网上对于HBase和MongoDB做对比的资料比 ...

  2. HBase与MongoDB的区别

    HBase与MongoDB的区别 1.HBase依赖于HDFS:MongoDB直接存储在本地磁盘中. 2.HBase按照列族将数据存储在不同的文件中:MongoDB不分列,整个文档都存储在一个(或者说 ...

  3. Nosql简介 Redis,Memchche,MongoDb的区别

    Nosql介绍 Nosql的全称是Not Only Sql,这个概念早起就有人提出,在09年的时候比较火.Nosql指的是非关系型数据库,而我们常用的都是关系型数据库.就像我们常用的mysql,sql ...

  4. Redis、Memcache和MongoDB的区别

    >>Memcached Memcached的优点: Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key.value的字节大小以及服务器硬件性能,日常环 ...

  5. Oracle与mongodb的区别

    oracle与mongodb的区别 1. 从概念上 Oracle中的许多概念与MongoDB中的类似.下表概述了Oracle和MongoDB中的常见概念. Oracle mongodb ACID Tr ...

  6. redis.mecmcached和mongoDB的区别

    转载自  https://blog.csdn.net/cleble/article/details/78325527 https://segmentfault.com/q/10100000025880 ...

  7. Redis和MongoDB的区别

    Redis和MongoDB的区别(面试受用) 项目中用的是MongoDB,但是为什么用其实当时选型的时候也没有太多考虑,只是认为数据量比较大,所以采用MongoDB. 最近又想起为什么用MongoDB ...

  8. 数据库工作笔记016---Redis、Memcache和MongoDB的区别

    技术交流QQ群[JAVA,.NET,BigData,AI]:170933152 了解一下还是有必要滴,要不然光知道用一个也不行啊,逮住一个一直用不行,都得捣鼓捣鼓 >>Memcached ...

  9. hive与hbase的联系与区别

    hive与hbase的联系与区别: 共同点: 1.hbase与hive都是架构在hadoop之上的.都是用hadoop作为底层存储. 他们的底层是要通过mapreduce分布式计算的,hbase.hi ...

最新文章

  1. java request get json数据_Java中,获取request中json数据
  2. Java学习日志(一)
  3. HashMap的存储过程
  4. Java web 初入
  5. 原创《SQL基础知识第2版》PDF高清版,限时下载!
  6. jscript换行等特殊字符
  7. 条码生成代码(Code39码)
  8. 接受与返回json数据
  9. 计算机电路基础张志良,计算机电路基础
  10. eclipse linux远程调试工具,使用本地Eclipse IDE调试器与远程项目源(Linux)
  11. phpcmsV9怎样在单页中调用后台栏目SEO设置的Meta_title
  12. 华为云再“祭”神器!
  13. Android系统联系人全特效实现(上),分组导航和挤压动画
  14. MyBatis框架(6)动态sql
  15. Android OAID 获取 基于MSA oaid_sdk_1.0.25.zip
  16. 快手短视频广告投放是怎么收费的 快手信息流广告收费标准
  17. 【历史上的今天】10 月 1 日:仙童半导体公司诞生;斯坦福大学正式办学;万维网之父成立万维网联盟
  18. 支持Kubernetes集群运维审计,JumpServer v2.2.0发布丨Release Notes
  19. 根据入职时间计算工龄
  20. 公众号和知乎排版神器 - mdnice.com

热门文章

  1. 密码经济学绝非掌上观纹
  2. 部分城市知名互联网公司名单(部分公司)
  3. R语言limma包差异表达分析
  4. 利用ZoomEye搜索引擎
  5. mktime函数 php,php mktime函数怎么用
  6. linux的mktime函数,关于kernel_mktime 函数详解
  7. C++解析EIT表中的P-F信息
  8. 智能机器人在医疗领域的应用
  9. elementary OS 发布代号由 Isis 改为 Freya
  10. android studio 分析 hprof,Android Studio 中的 HProf静态分析