在ubuntu下安装过程如下:
官方网站地址:http://1978th.net/
安装libbz2
apt-get install libbz2-dev
安装 Tokyo Cabinet
wget http://1978th.net/tokyocabinet/tokyocabinet-1.4.42.tar.gz
tar zxvf tokyocabinet-1.4.14.tar.gz
cd tokyocabinet-1.4.14
./configure –prefix=/usr/local/tcserver
make
make install
安装 Tokyo Tyrant
wget http://1978th.net/tokyotyrant/tokyotyrant-1.1.40.tar.gz
tar zxvf tokyotyrant-1.1.23.tar.gz
cd tokyotyrant-1.1.23
./configure –prefix=/usr/local/ttserver –with-tc=/usr/local/tcserver
make
make install
二、配置
1、创建tokyotyrant 数据文件存放目录
mkdir -p /ttserver/
2、启动tokyotyrant 的主进程(ttserver)
(1)、单机模式
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.tch
(2)、双机互为主辅模式
服务器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.tch
服务器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.tch
(3)、参数说明
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
3、停止tokyotyrant(ttserver)
ps -ef | grep ttserver
找到ttserver的进程号并 kill,例如:
kill -TERM 2159
注:
1、启动ttserver时,指定的host ip为监听ip,如果使用127.0.0.1,则仅有本地才允许访问。所以,如果允许网络访问,应该使用192之类的ip。
2、参数含义如下,适用于TT(tokyo tyrant):
- capnum :设置记录的最大容量
- capsiz :设置内存型database的内存容量,内存不足记录将按照顺序移除
- mode : 可选的选项:w (写)、r (读)、c (创建)、t (截断)、t (无锁)、f (非阻塞锁)。默认值为 :wc
- idx :设置索引的列名,用:分割
- opts :可选的选项:l (64位bucket数组,database容量可以超过2G)、d (Deflate压缩)、b(BZIP2压缩)、t(TCBS压缩)
- bnum :bucket的数量
- apow :specifies the size of record alignment by power of 2. 如果负数,设置无效
- fpow :specifies the maximum number of elements of the free block pool by power of 2. 如果负数,设置无效
- rcnum :设置缓存记录的最大数,如果数值不是大于0则会禁用缓存,默认禁用
- lcnum :设置缓存叶节点(leaf nodes)的最大数,如果数值不是大于0则会禁用缓存,默认值4096
- ncnum :设置缓存非叶节点(non-leaf nodes)的最大数,如果数值不是大于0则会禁用缓存,默认值512
- xmsiz :设置额外内存映射容量,如果数值不是大于0则会禁用内存映射,默认值67108864
- dfunit :specifie the unit step number. If it is not more than 0, the auto defragmentation is disabled. It is disabled by default.
- width :设置记录的固定大小,如果数值不是大于0,则默认是255
- limsiz :设置数据库文件的大小,如果数值不是大于0,则默认是268435456
- lmemb :设置每个叶节点页(leaf page)的成员数,如果数值不是大于0,则默认是128
- nmemb :设置每个非叶节点页(non-leaf page)的成员数,如果数值不是大于0,则默认是256
lmemb和nmemb是B+tree的参数,规定了叶节点和非叶节点个数。回忆下B+ tree哦。
—————–
TCHDB 哈希数据库、TCBDB B+Tree数据库、TCFDB 定长数据库、TCTDB 表格数据库、TCMDB内存哈希数据库、TCNDB 内存B+Tree数据库