欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

tokyo cabinet 和tyrant的安装使用 博客分类: 系统服务 .net脚本网络协议memcachedTokyoCabinet 

程序员文章站 2024-03-23 16:38:16
...

 

1.介绍

 

tokyo cabinet(tc)一个key-value的高性能数据库,类似于新浪的memcachedb。

tokyo tyrant(tt)是tc的网络接口,实现memcached的兼容协议及http访问。

 

2.安装

 

tc下载地址:http://fallabs.com/tokyocabinet/tokyocabinet-1.4.47.tar.gz

tt下载地址:http://fallabs.com/tokyotyrant/tokyotyrant-1.1.41.tar.gz

 

安装比较简单:

tc安装

tar xvfz tokyocabinet-1.4.47.tar.gz

cd tokyocabinet-1.4.47

./configure

make

make install

 

(ps:如果在安装过程中,找不到zlib.h 到http://zlib.net/下载zlib安装,bzlib.h到http://www.bzip.org/下载,安装,安装基本make&& make install)

 

tt安装

tar xvfz tokyotyrant-1.1.41.tar.gz

cd tokyotyrant-1.1.41

./configure

make

make install

 

就安装完成了。

 

3.配置

 

默认情况下,ttserver启动脚本在/usr/local/sbin/ttservctl下,通过

./ttservctl start #启动

 

默认启动端口1978

可以通过 telnet 127.0.0.1 1978 来测试是否安装成功。

 

也可以通过ttserver命令来启动,启动tokyotyrant的主进程(ttserver)

 

单机模式

ulimit -SHn 51200

ttserver -host 127.0.0.1 -port 11211 -thnum 8 -dmn -pid /ttserver/ttserver.pid -log /ttserver/ttserver.log -le -ulog /ttserver/ -ulim 128m -sid 1 -rts /ttserver/ttserver.rts /ttserver/database.tcb#lmemb=1024#nmemb=2048#bnum=10000000

 

双机互为主辅模式

服务器192.168.1.91:

ulimit -SHn 51200

ttserver -host 192.168.1.91 -port 11211 -thnum 8 -dmn -pid /ttserver/ttserver.pid -log /ttserver/ttserver.log -le -ulog /ttserver/ -ulim 128m -sid 91 -mhost 192.168.1.92 -mport 11211 -rts /ttserver/ttserver.rts /ttserver/database.tcb#lmemb=1024#nmemb=2048#bnum=10000000

 

 

服务器192.168.1.92:

ulimit -SHn 51200

ttserver -host 192.168.1.92 -port 11211 -thnum 8 -dmn -pid /ttserver/ttserver.pid -log /ttserver/ttserver.log -le -ulog /ttserver/ -ulim 128m -sid 92 -mhost 192.168.1.91 -mport 11211 -rts /ttserver/ttserver.rts /ttserver/database.tcb#lmemb=1024#nmemb=2048#bnum=10000000

 

 

参数说明

ttserver [-host name] [-port num] [-thnum num] [-tout num] [-dmn] [-pid path] [-log path] [-ld|-le] [-ulog path] [-ulim num] [-uas] [-sid num] [-mhost name] [-mport num] [-rts path] [dbname] 

 

  -host name : 指定需要绑定的服务器域名或IP地址。默认绑定这台服务器上的所有IP地址。

  -port num : 指定需要绑定的端口号。默认端口号为1978 

  -thnum num : 指定线程数。默认为8个线程。 

  -tout num : 指定每个会话的超时时间(单位为秒)。默认永不超时。 

  -dmn : 以守护进程方式运行。

  -pid path : 输出进程ID到指定文件(这里指定文件名)。

  -log path : 输出日志信息到指定文件(这里指定文件名)。

  -ld : 在日志文件中还记录DEBUG调试信息。

  -le : 在日志文件中仅记录错误信息。

  -ulog path : 指定同步日志文件存放路径(这里指定目录名)。

  -ulim num : 指定每个同步日志文件的大小(例如128m)。

  -uas : 使用异步IO记录更新日志(使用此项会减少磁盘IO消耗,但是数据会先放在内存中,不会立即写入磁盘,如果重启服务器或ttserver进程被kill掉,将导致部分数据丢失。一般情况下不建议使用)。

  -sid num : 指定服务器ID号(当使用主辅模式时,每台ttserver需要不同的ID号) 

  -mhost name : 指定主辅同步模式下,主服务器的域名或IP地址。

  -mport num : 指定主辅同步模式下,主服务器的端口号。

  -rts path : 指定用来存放同步时间戳的文件名。

 

  如果使用的是哈希数据库,可以指定参数“#bnum=xxx”来提高性能。它可以指定bucket存储桶的数量。例如指定“#bnum=1000000”,就可以将最新最热的100万条记录缓存在内存中:

ttserver -host 127.0.0.1 -port 11211 -thnum 8 -dmn -pid /ttserver/ttserver.pid -log /ttserver/ttserver.log -le -ulog /ttserver/ -ulim 128m -sid 1 -rts /ttserver/ttserver.rts /ttserver/database.tch#bnum=1000000

 

 

  如果大量的客户端访问ttserver,请确保文件描述符够用。许多服务器的默认文件描述符为1024,可以在启动ttserver前使用ulimit命令提高这项值。例如:

ulimit -SHn 51200

 

 

4.停止tokyotyrant(ttserver)

ps -ef | grep ttserver

 

找到ttserver的进程号并kill,例如:

kill -TERM 2159 或者 kill -15 2159 (ps:不要直接kill -9 2159,如果数据写入会导致文件顺坏)