tokyo cabinet 和tyrant的安装使用

阅读更多

 

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,如果数据写入会导致文件顺坏)


你可能感兴趣的:(.net,脚本,网络协议,memcached,TokyoCabinet)