Tokyo Cabinet 是一款 DBM 数据库,与Berkeley DB是同类产品,但性能要好。
Tokyo Tyrant 是Tokyo Cabinet 的数据库网络接口。它拥有Memcached兼容协议,也可以通过HTTP协议进行数据交换。
我用 tokyocabinet-1.4.10 与 tokyotyrant-1.1.17
●安装 Tokyo Cabinet
apt-get --purge remove gdm
wget http://tokyocabinet.sourceforge.net/tokyocabinet-1.4.12.tar.gz
tar zxvf tokyocabinet-1.4.12.tar.gz
cd tokyocabinet-1.4.12
which gcc
apt-get install gcc
apt-get install zlib1g-dev
wget ftp://ftp.pbone.net/mirror/www.haoli.org/pub/redhat-6.x/RPMS/i386/outdated/bzip2-1.0.0-1.i386.rpm
apt-get install alien
alien -i bzip2-1.0.0-1.i386.rpm
./configure --prefix=/home/tc
make
make install
cd ..
●安装 Tokyotyrant
wget http://tokyocabinet.sourceforge.net/tyrantpkg/tokyotyrant-1.1.17.tar.gz
tar zxvf tokyotyrant-1.1.17.tar.gz
cd tokyotyrant-1.1.17
./configure --prefix=/home/tt --with-tc=/home/tc
make
make install
cd ..
如果安装Tokyo Cabinet时指定了目录,在安装Tokyo Tyrant时用--with-tc指定Tokyo Cabinet的目录,如果没指定会报:configure: error: tcutil.h is required 错误。
启动 ttserver
/home/tt/bin/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
#出现下面的错误
bin/ttserver: error while loading shared libraries: libtokyocabinet.so.8: cannot open shared object file: No such file or directory
libtokyocabinet.so.8 只在/home/tc/lib目录中,所以找不到。可以做一下软件连接,
ln -s /home/tc/lib/libtokyocabinet.so.8.1.0 lib/libtokyocabinet.so.8
ln -s /home/tc/lib/libtokyocabinet.so.8.1.0 lib/libtokyocabinet.so.8
再启动就可以了。
试用:
写入数据
curl -X PUT http://127.0.0.1:11211/my_key -d "this is value"
curl -X PUT http://127.0.0.1:11211/my_key -d "this is value"
取数据
curl http://127.0.0.1:11211/my_key
curl http://127.0.0.1:11211/my_key
删除数据
curl -X DELETE http://127.0.0.1:11211/my_key
curl -X DELETE http://127.0.0.1:11211/my_key
参考:利用Tokyo Tyrant构建兼容Memcached协议、支持故障转移、高并发的分布式key-value持久存储系统
##############################################################################################################################
mkdir -p /var/tokyo
二 启动
1)
单机模式
ulimit -SHn 51200
ttserver -host 127.0.0.1 -port 13000 -thnum 8 -dmn -pid /var/tokyo/ttserver.pid -log /var/tokyo/ttserver.log -le -ulog /var/tokyo/ -ulim 128m -sid 1 -rts /var/tokyo/ttserver.rts /var/tokyo/database.tch
2)
双机互为主辅模式
192.168.1.100
ulimit -SHn 51200
ttserver -host 192.168.1.100 -port 13000 -thnum 8 -dmn -pid /var/tokyo/ttserver.pid -log /var/tokyo/ttserver.log -le -ulog /var/tokyo/ -ulim 128m -sid 100 -mhost 192.168.1.101 -mport 13000 -rts /var/tokyo/ttserver.rts /var/tokyo/database.tch
192.168.1.101
ulimit -SHn 51200
ttserver -host 192.168.1.101 -port 13000 -thnum 8 -dmn -pid /var/tokyo/ttserver.pid -log /var/tokyo/ttserver.log -le -ulog /var/tokyo/ -ulim 128m -sid 101 -mhost 192.168.1.100 -mport 13000 -rts /var/tokyo/ttserver.rts /var/tokyo/database.tch
三 测试
1)
curl -X PUT http://127.0.0.1:13000/testkey -d “this is a test”
curl http://127.0.0.1:13000/testkey
curl -X DELETE http://127.0.0.1:13000/testkey
2)
$mem = new Memcache;
$mem->connect(”127.0.0.1″,13000);
$mem->set(’testkey’, ‘this is a test!!’, 0, 60);
$val = $mem->get(’testkey’);
echo $val;
?>
四 参数说明
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
0 件のコメント:
コメントを投稿