码迷,mamicode.com
首页 > 其他好文 > 详细

Tair是由淘宝网自主开发的Key/Value结构数据存储系统

时间:2014-10-13 19:54:07      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:style   color   io   文件   sp   数据   div   on   问题   

Tair是由淘宝网自主开发的Key/Value结构数据存储系统,在淘宝网有着大规模的应用。您在登录淘宝、查看商品详情页面或者在淘江湖和好友"捣浆糊"的时候,都在直接或间接地和Tair交互。

Tair的功能

Tair是一个Key/Value结构数据的解决方案,它默认支持基于内存和文件的两种存储方式,分别和我们通常所说的缓存和持久化存储对应。

Tair除了普通Key/Value系统提供的功能,比如get、put、delete以及批量接口外,还有一些附加的实用功能,使得其有更广的适用场景,包括:

  • Version支持>
  • 原子计数器
  • Item支持

Version支持

Tair中的每个数据都包含版本号,版本号在每次更新后都会递增。这个特性有助于防止由于数据的并发更新导致的问题。

比如,系统有一个value为"a,b,c",A和B同时get到这个value。A执行操作,在后面添加一个d,value为"a,b,c,d"。B执行操作添加一个e,value为"a,b,c,e"。如果不加控制,无论A和B谁先更新成功,它的更新都会被后到的更新覆盖。

Tair无法解决这个问题,但是引入了version机制避免这样的问题。还是拿刚才的例子,A和B取到数据,假设版本号为10,A先更新,更新成功后,value为"a,b,c,d",与此同时,版本号会变为11。当B更新时,由于其基于的版本号是10,服务器会拒绝更新,从而避免A的更新被覆盖。B可以选择get新版本的value,然后在其基础上修改,也可以选择强行更新。

Tair是由淘宝网自主开发的Key/Value结构数据存储系统

标签:style   color   io   文件   sp   数据   div   on   问题   

原文地址:http://www.cnblogs.com/top15from/p/4022731.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!