Tokyo Cabinet 是一款 DBM 数据库,与Berkeley DB是同类产品,但性能要好。
Tokyo Tyrant 是Tokyo Cabinet 的数据库网络接口。它拥有Memcached兼容协议,也可以通过HTTP协议进行数据交换。
我用 tokyocabinet-1.4.10 与 tokyotyrant-1.1.17
安装 Tokyo Cabinet
- wget tar.gz
- tar zxvf tokyocabinet-1.4.10.tar.gz
- cd tokyocabinet-1.4.10
- ./configure --prefix=/home/tc
- make
- make install
- cd ..
wget tar.gz tar zxvf tokyocabinet-1.4.10.tar.gz cd tokyocabinet-1.4.10 ./configure --prefix=/home/tc make make install cd ..
安装 Tokyo Tyrant
- wget 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 ..
wget 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 "this is value"
curl -X PUT -d "this is value"
取数据
- curl
curl
删除数据
- curl -X DELETE
curl -X DELETE
参考:利用Tokyo Tyrant构建兼容Memcached协议、支持故障转移、高并发的分布式key-value持久存储系统