存档

文章标签 ‘Tokyo Tyrant’

linux下安装tokyo cabinet和tokyo tyrant客户端

2009年4月10日 没有评论

linux下安装tokyo cabinet和tokyo tyrant客户端

关于tokyo cabinet和tokyo tyrant是什么请google之。下面是如何安装tokyo cabinet和tokyo tyrant的步骤,请注意如果你安装的版本有区别,请根据版本修改相应的安装命令:

1、首先编译安装tokyocabinet数据库

wget http://tokyocabinet.sourceforge.net/tokyocabinet-1.3.22.tar.gztar zxvf tokyocabinet-1.3.22.tar.gz

cd tokyocabinet-1.3.22/

./configure

make

make install

cd ../

2、然后编译安装tokyotyrant

wget http://tokyocabinet.sourceforge.net/t … /tokyotyrant-1.1.8.tar.gztar zxvf tokyotyrant-1.1.8.tar.gz

cd tokyotyrant-1.1.8/

./configure

make

make install

cd ../


二、配置

1、创建tokyotyrant数据文件存放目录

mkdir -p /ttserver/

2、启动tokyotyrant的主进程(ttserver)

(1)、单机模式

ulimit -SHn 51200ttserver -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 51200ttserver -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 51200ttserver -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
分类: 转载 标签: ,

Tokyo Tyrant使用小结

2009年4月10日 没有评论

Tokyo Tyrant使用小结


Tokyo Tyrant安装上了之后如何使用,官方说明见:http://tokyocabinet.sourceforge.net/tyrantdoc/

下面是我的操作过程:
启动Tokyo Tyrant使用命令:
ttservctl start
使用命令查看当前进程:
ps -ef | grep ttserver
结果如下,说明在1978端口启动ttserver成功,数据库文件存储在/var/ttserver/casket.tch:
root 10923 1 0 20:09 ? 00:00:00 ttserver -port 1978 -dmn -pid /var/ttserver/pid -log /var/ttserver/log -ulog /var/ttserver/ulog -ulim 256m -sid 1 /var/ttserver/casket.tch#bnum=1000000

由于服务器上已经安装了memcache,因此直接利用php的memcache来进行Tokyo Tyrant操作测试:
$memcache = new Memcache;
$memcache->connect(’localhost’, 1978) or die (”Could not connect”);
$add = $memcache->set(”askie”,”2″);
echo $add.”\n”;
$add = $memcache->get(”askie”);
echo $add.”\n”;
?>

输出结果:
1
2

说明已经向数据库中加入了key=askie,value=1的数据。OK! 至此在php利用memcache客户端操作Tokyo Tyrant成功了!

Memcache操作函数:
Memcache::add — 添加一个值,如果已经存在,则返回false
Memcache::addServer — 添加一个可供使用的服务器地址
Memcache::close — 关闭一个Memcache对象
Memcache::connect — 创建一个Memcache对象
memcache_debug — 控制调试功能
Memcache::decrement — 对保存的某个key中的值进行减法操作
Memcache::delete — 删除一个key值
Memcache::flush — 清除所有缓存的数据
Memcache::get — 获取一个key值
Memcache::getExtendedStats — 获取进程池中所有进程的运行系统统计
Memcache::getServerStatus — 获取运行服务器的参数
Memcache::getStats — 返回服务器的一些运行统计信息
Memcache::getVersion — 返回运行的Memcache的版本信息
Memcache::increment — 对保存的某个key中的值进行加法操作
Memcache::pconnect — 创建一个Memcache的持久连接对象
Memcache::replace — R对一个已有的key进行覆写操作
Memcache::set — 添加一个值,如果已经存在,则覆写
Memcache::setCompressThreshold — 对大于某一大小的数据进行压缩
Memcache::setServerParams — 在运行时修改服务器的参数

分类: 转载 标签: ,