- 浏览: 1487066 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (691)
- linux (207)
- shell (33)
- java (42)
- 其他 (22)
- javascript (33)
- cloud (16)
- python (33)
- c (48)
- sql (12)
- 工具 (6)
- 缓存 (16)
- ubuntu (7)
- perl (3)
- lua (2)
- 超级有用 (2)
- 服务器 (2)
- mac (22)
- nginx (34)
- php (2)
- 内核 (2)
- gdb (13)
- ICTCLAS (2)
- mac android (0)
- unix (1)
- android (1)
- vim (1)
- epoll (1)
- ios (21)
- mysql (3)
- systemtap (1)
- 算法 (2)
- 汇编 (2)
- arm (3)
- 我的数据结构 (8)
- websocket (12)
- hadoop (5)
- thrift (2)
- hbase (1)
- graphviz (1)
- redis (1)
- raspberry (2)
- qemu (31)
- opencv (4)
- socket (1)
- opengl (1)
- ibeacons (1)
- emacs (6)
- openstack (24)
- docker (1)
- webrtc (11)
- angularjs (2)
- neutron (23)
- jslinux (18)
- 网络 (13)
- tap (9)
- tensorflow (8)
- nlu (4)
- asm.js (5)
- sip (3)
- xl2tp (5)
- conda (1)
- emscripten (6)
- ffmpeg (10)
- srt (1)
- wasm (5)
- bert (3)
- kaldi (4)
- 知识图谱 (1)
最新评论
-
wahahachuang8:
我喜欢代码简洁易读,服务稳定的推送服务,前段时间研究了一下go ...
websocket的helloworld -
q114687576:
http://www.blue-zero.com/WebSoc ...
websocket的helloworld -
zhaoyanzimm:
感谢您的分享,给我提供了很大的帮助,在使用过程中发现了一个问题 ...
nginx的helloworld模块的helloworld -
haoningabc:
leebyte 写道太NB了,期待早日用上Killinux!么 ...
qemu+emacs+gdb调试内核 -
leebyte:
太NB了,期待早日用上Killinux!
qemu+emacs+gdb调试内核
http://tech.it168.com/a2010/0419/875/000000875687_2.shtml
http://www.4pang.com/2010/09/06/%E5%BD%93%E5%BF%83ttservertokyo-tyrant%E5%9C%A8%E7%B3%BB%E7%BB%9F%E5%B4%A9%E6%BA%83%E6%88%96%E6%96%AD%E7%94%B5%E7%9A%84%E6%97%B6%E5%80%99%E4%B8%A2%E5%A4%B1%E6%95%B0%E6%8D%AE.html
http://korrespondence.blogspot.com/2009/09/tokyo-tyrant-tuning-parameters.html
http://www.4pang.com/2010/09/06/%E5%BD%93%E5%BF%83ttservertokyo-tyrant%E5%9C%A8%E7%B3%BB%E7%BB%9F%E5%B4%A9%E6%BA%83%E6%88%96%E6%96%AD%E7%94%B5%E7%9A%84%E6%97%B6%E5%80%99%E4%B8%A2%E5%A4%B1%E6%95%B0%E6%8D%AE.html
http://korrespondence.blogspot.com/2009/09/tokyo-tyrant-tuning-parameters.html
Tokyo Tyrant tuning parameters We've been working with Tokyo Tyrant for some large scale key-value lookups and the performance has been very nice, but has degraded over time. I've been poking around the various options to try to improve the performance and although there is documentation of various options, the pages are hard to read and figure out what's what. So I thought I'd collect them here for reference. I'll describe the results of tuning and tweaking in a future post. The most recent authoritative references are here: http://1978th.net/tokyocabinet/spex-en.html http://1978th.net/tokyotyrant/spex.html#installation Tokyo Tyrant (actually Tokyo Cabinet – the storage engine) supports various types of storage – B+ Tree indexing, hash index, etc. This is configured by setting the filename or file extension to a particular value: If the name is "*", the database will be an in-memory hash database. If it is "+", the database will be an in-memory tree database. If its suffix is ".tch", the database will be a hash database. If its suffix is ".tcb", the database will be a B+ tree database. If its suffix is ".tcf", the database will be a fixed-length database. If its suffix is ".tct", the database will be a table database. Each has its own set of options and while different flavors of storage may accept the same option name (like bnum), the optimal value likely should be different across storage types. Tuning parameters can trail the filename, separated by "#". Each parameter is composed of the name and the value, separated by "=". For example, "casket.tch#bnum=1000000#opts=ld" means that the name of the database file is "casket.tch", and the bucket array size is 1000000, and the options are large and deflate. For disk-based storage, several tuning parameters specify the on-disk layout while others specify memory and caching settings. Changing the on-disk layout requires scanning and re-writing the database data file which requires exclusive access to the file – which means taking the database offline. This scanning and re-writing process is done via tools provided with the distribution (ex: tchmgr and tcbmgr). Changing the memory and caching settings only requires a restart of Tokyo Tyrant. We've been working only with on-disk storage via the hash and B+ Tree database engines. For a hash database the tuning parameters for the on-disk layout is limited to the size of the bucket array and the size of an element in the bucket array (choosing 'large' gets you 64-bit addressing and addressable data greater than 2GB). When a hash database file is first created, space is allocated on disk for the full bucket array. For example a database with 100M bucket size and 'large' option would start out at around 800MB. This region of the data file is accessed via memory mapped IO. There is an additional 'extra mapped memory' setting which default to 64MB – I'm not sure what this is used for, but for performance more memory is always better. For a B+ Tree database, there are additional tuning parameters for the structure of the B+ Tree – how many members (links to child nodes) in an interior non-leaf node and how many members in a leaf node. Records are not stored in the B-Tree leaf nodes, but within 'pages'. The leaf nodes point to these pages and each page holds multiple records and is accessed via an internal hash database (and since this is a B+ Tree the records within a page are of course stored in sorted order). There is also a parameter for the bucket size of this internal hash database. One subtle detail is that the bucket size for a B+Tree database is the number of pages, not the number of elements (records) being stored – so this would likely be a smaller number than a hash database for the same number of records. I've not yet figured out how the dfunit tuning parameter works or what impact that has on a running server, but it looks interesting. In memory hash bnum the number of buckets capnum the capacity number of records capsiz the capacity size of using memory. Note - records spilled the capacity are removed by the storing order. In memory tree capnum the capacity number of records capsiz the capacity size of using memory. Note - records spilled the capacity are removed by the storing order. Hash opts "l" of large option (the size of the database can be larger than 2GB by using 64-bit bucket array.), "d" of Deflate option (each record is compressed with Deflate encoding), "b" of BZIP2 option, "t" of TCBS option bnum number of elements of the bucket array. If it is not more than 0, the default value is specified. The default value is 131071 (128K). Suggested size of the bucket array is about from 0.5 to 4 times of the number of all records to be stored. rcnum maximum number of records to be cached. If it is not more than 0, the record cache is disabled. It is disabled by default. xmsiz size of the extra mapped memory. If it is not more than 0, the extra mapped memory is disabled. The default size is 67108864 (64MB). apow size of record alignment by power of 2. If it is negative, the default value is specified. The default value is 4 standing for 2^4=16. fpow maximum number of elements of the free block pool by power of 2. If it is negative, the default value is specified. The default value is 10 standing for 2^10=1024. dfunit unit step number of auto defragmentation. If it is not more than 0, the auto defragmentation is disabled. It is disabled by default. mode "w" of writer, "r" of reader,"c" of creating,"t" of truncating ,"e" of no locking,"f" of non-blocking lock B-tree opts "l" of large option,"d" of Deflate option,"b" of BZIP2 option,"t" of TCBS option bnum number of elements of the bucket array. If it is not more than 0, the default value is specified. The default value is 32749 (32K). Suggested size of the bucket array is about from 1 to 4 times of the number of all pages to be stored. nmemb number of members in each non-leaf page. If it is not more than 0, the default value is specified. The default value is 256. ncnum maximum number of non-leaf nodes to be cached. If it is not more than 0, the default value is specified. The default value is 512. lmemb number of members in each leaf page. If it is not more than 0, the default value is specified. The default value is 128. lcnum maximum number of leaf nodes to be cached. If it is not more than 0, the default value is specified. The default value is 1024. apow size of record alignment by power of 2. If it is negative, the default value is specified. The default value is 8 standing for 2^8=256. fpow maximum number of elements of the free block pool by power of 2. If it is negative, the default value is specified. The default value is 10 standing for 2^10=1024. xmsiz size of the extra mapped memory. If it is not more than 0, the extra mapped memory is disabled. It is disabled by default. dfunit unit step number of auto defragmentation. If it is not more than 0, the auto defragmentation is disabled. It is disabled by default. mode "w" of writer, "r" of reader,"c" of creating,"t" of truncating ,"e" of no locking,"f" of non-blocking lock Fixed-length width width of the value of each record. If it is not more than 0, the default value is specified. The default value is 255. limsiz limit size of the database file. If it is not more than 0, the default value is specified. The default value is 268435456 (256MB). mode "w" of writer, "r" of reader,"c" of creating,"t" of truncating ,"e" of no locking,"f" of non-blocking lock Table opts "l" of large option,"d" of Deflate option,"b" of BZIP2 option,"t" of TCBS option idx specifies the column name of an index and its type separated by ":" bnum number of elements of the bucket array. If it is not more than 0, the default value is specified. The default value is 131071. Suggested size of the bucket array is about from 0.5 to 4 times of the number of all records to be stored. rcnum maximum number of records to be cached. If it is not more than 0, the record cache is disabled. It is disabled by default. lcnum maximum number of leaf nodes to be cached. If it is not more than 0, the default value is specified. The default value is 4096. ncnum maximum number of non-leaf nodes to be cached. If it is not more than 0, the default value is specified. The default value is 512. xmsiz size of the extra mapped memory. If it is not more than 0, the extra mapped memory is disabled. The default size is 67108864. apow size of record alignment by power of 2. If it is negative, the default value is specified. The default value is 4 standing for 2^4=16. fpow maximum number of elements of the free block pool by power of 2. If it is negative, the default value is specified. The default value is 10 standing for 2^10=1024. dfunit unit step number of auto defragmentation. If it is not more than 0, the auto defragmentation is disabled. It is disabled by default. mode "w" of writer, "r" of reader,"c" of creating,"t" of truncating ,"e" of no locking,"f" of non-blocking lock
发表评论
-
干掉 tt 的数据
2011-08-30 17:15 1085tcrmgr copy -port 11210 10.11.1 ... -
mongo加sum方法
2011-08-19 15:28 1504http://stackoverflow.com/questi ... -
mongodb的python helloworld
2011-07-22 23:31 1913参考http://blog.csdn.net/lolinzha ... -
mongodb的helloworld
2011-07-17 13:26 10531.数据默认保存在mkdir -p /data/db 2.下载 ... -
tt 文件说明
2011-07-13 01:18 1229tt有用的c可能就15个 一行行看也看完了 myconf.c- ... -
tt的lua扩展
2011-07-07 02:14 1232tc: http://fallabs.com/tokyocab ... -
tt安全
2011-07-05 17:34 975转http://hi.baidu.com/ah__fu/b ... -
转TT第三线程
2011-07-01 10:33 968转载 http://lgone.com/html/y2009/ ... -
tokyotyrant 代码跟踪
2011-06-30 14:13 1186如果+++ killed by SIGTRAP +++ htt ... -
转“Tokyo Tyrant问题二三解”
2011-06-30 10:49 1320转发: http://live.shopex.cn/archi ... -
redis的helloworld
2011-06-27 22:07 1049http://code.google.com/p/redis/ ... -
memcache
2011-06-15 16:02 552http://www.blogkid.net/archives ... -
ttserver优化及常用
2011-06-10 15:06 1815安装: tokyocabinet-1.4.44.tar.gz ... -
TT命令
2011-06-07 13:29 1230★★★★★服务端 ttserver Options featu ... -
TTServer(tokyotyrant)的helloworld
2011-05-30 18:44 3171常用命令: apt-get install tokyotyra ...
相关推荐
5. **性能优化**:TokyoTyrant的性能取决于硬件配置,如磁盘速度、内存大小等。可以通过调整服务器的配置参数,例如缓存大小、索引块大小等,来优化性能。此外,合理设计数据结构和访问模式也能显著提升效率。 6. *...
TokyoTyrant 的设计目标是高性能和低延迟,适用于缓存服务、日志记录以及任何需要快速读写操作的应用场景。它支持多种数据类型,如字符串、二进制数据和记录列表,并且可以通过多种编程语言的客户端进行操作,例如 ...
标题 "tokyoCabinet及tokyoTyrant简介" 指向了两个与数据库管理相关的开源工具,Tokyo Cabinet和Tokyo Tyrant。这两个工具由日本开发者开发,主要用于小型到中型的数据存储,尤其适合那些对数据读写速度有较高要求的...
媲美memcached的缓存服务器软件包,tokyocabinet-1.4.45.tar.gz+tokyotyrant-1.1.40.tar.gz
在不同的数据量和负载条件下,Tokyo Tyrant展示了其在读写性能、数据处理能力等方面的竞争优势。 ### 8. 问题与Bug Tokyo Tyrant虽然强大,但也存在一些已知的问题和Bug,这些问题可能影响其稳定性和性能。开发者...
这个C#客户端的开源发布,为.NET开发者提供了与TokyoTyrant交互的工具,使得他们可以利用TokyoTyrant的强大功能,比如高速的键值存储、灵活的数据结构和优秀的性能,来构建高性能的分布式应用。同时,通过社区的参与...
Tokyo Cabinet 是一个DBM的实现。这里的数据库由一系列key-value对的记录构成。key和value都可以是任意长度的字节序列,既可以是二进制也可以是字符串。这里没有数据类型和数据表的概念。 当做为Hash表数据库使用时,...
Tokyocabinet提供多种数据结构,包括哈希表、B+树和直方图,支持多种数据类型,并且具有高度的可移植性和良好的性能。在Ubuntu操作系统上安装和配置Tokyocabinet,可以分为以下几个步骤: 1. **系统准备**: 在...
`TokyoTyrant与Redis的一些简单比较.docx`文件可能比较了两种不同的NoSQL数据库,它们在存储和检索大量数据时的性能和特性。在分布式系统中,`concurrentMap`的实现可能会借鉴类似的思想,例如使用分布式缓存来提升...
兼容程序如TokyoTyrant等数据库系统,也可以与Memcached结合使用,进一步扩展其应用场景。 总之,Memcached通过提供简单高效的缓存机制,能够显著提升数据密集型应用的性能。了解其内部结构和使用方式对于开发者来...
在 "tokyotyrant-1.1.24" 这个压缩包中,我们预期会找到 Tokyo Tyrant 的源代码、文档、示例程序和测试用例。Tokyo Tyrant 提供了丰富的API,使得开发人员可以轻松地在各种编程语言(如C、Python、Ruby等)中与之...
从给出的信息来看,它可能是Tokyo Tyrant的一个特定版本,因为压缩包中的文件名为"tokyotyrant-1.1.41"。Tokyo Tyrant是一个轻量级、高性能的键值存储系统,常用于数据缓存和快速查找应用。 Tokyo Tyrant主要知识点...
- TokyoTyrant是一款由mixi工程师开发的兼容memcached协议的键值存储系统,具有更高的性能和稳定性。 - TokyoTyrant可以在某些场景下作为memcached的替代品。 综上所述,memcached作为一种强大的缓存解决方案,在...
- **兼容应用程序**:如TokyoTyrant等软件与memcached的兼容使用。 ### 总结 memcached作为一个内存缓存系统,具有简单、高效的特点,特别适合Web应用中缓存数据,减少数据库的访问次数。其分布式特性使得系统更加...
- **兼容应用程序**:介绍与memcached兼容的其他应用程序,如TokyoTyrant等。 #### 总结 本文全面剖析了memcached的核心概念和技术细节,包括其工作原理、内存管理机制、分布式算法及应用案例等。通过深入理解这些...
- **TokyoTyrant 案例**:TokyoTyrant 是一个兼容 MemCached 协议的高性能键值存储系统。 以上内容覆盖了 MemCached 的基本概念、安装使用、内存管理、删除机制、分布式算法以及实际应用场景等方面的知识点,为深入...
在深入研究Tokyo Tyrant的内部实现时,可以关注其数据结构、并发控制机制、持久化策略等方面,这些都对理解Tokyo Tyrant的高性能至关重要。 总而言之,Tokyo Tyrant是一款面向高速数据处理的NoSQL数据库,其简单的...
- **TokyoTyrant案例**:TokyoTyrant是一个开源的高性能key-value存储系统,它可以与memcached兼容,提供更强大的功能。 #### 总结 Memcached作为一款高性能的分布式缓存系统,在现代互联网应用中扮演着至关重要的...