ttserver命令可以启动一个数据库实例。因为数据库已经实现了Tokyo Cabinet的抽象API,所以可以在启动的时候指定数据库的配置类型。
命令通过下面的格式来使用,‘dbname’制定数据库名,如果省略,则被视作内存hash数据库。
ttserver [-host name ] [-port num ] [-th num num ] [-tout num ] [-dmn] [-pid path ] [-log path ] [-ld|-le] [-ulog path ] [-ulim num ] [-uas] [-sid num ] [-mhost name ] [-mport num ] [-rts path ] [-ext path ] [-extpc name period ] [-mask expr ] [ dbname ]
下面来说这些参数的功能:
|
如果使用B+ tree数据库我们可以通过指定”#lcnum=xxx#bnum=yyy” 来提高性能.第一个参数指定被缓存的最大叶子节点数,受内存容量限制,第二个参数指定桶的数量,它应该大于总记录数的1/128.
如果有大量的客户端连接,确保我们的文件描述符够用。系统默认是1024,我们可以用使用“ulimit”来重新设定
比如下面的单机实例启动脚本(一个正在线上运行的脚本):
#!/bin/sh
ulimit -SHn 51200
ttserver -host 192.168.0.136 -port 11212 -thnum 8 -dmn -pid /data/ttserver/ttserver.pid -log /data/ttserver/ttserver.log -le -ulog /data/ttserver/ -ulim 128m -sid 1 -rts /data/ttserver/ttserver.rts /data/ttserver/database.tch#bnum=10000000#xmsiz=434217728#rcnum=20000
|
使用hash数据库,最大会缓存20000个记录,最大使用内存434217728bytes(414M),bucket存储桶的数量 10000000。
目前的库大小:
-rw-r–r– 1 root root 28G Mar 8 12:19 bbsdatabase.tch |
当前获取memcache Threads_cdb_threads_tid3565732_displayorder_0 使用时间 0.00054812431335449 |
#! /bin/sh
#—————————————————————-
# Startup script for the server of Tokyo Tyrant
#—————————————————————-
# configuration variables
prog=”ttservctl”
cmd=”ttserver”
basedir=”/var/ttserver” #数据库存放的路径,比如改为”/data/mydata”
port=”1978″ #启动的端口
pidfile=”$basedir/pid”
logfile=”$basedir/log”
ulogdir=”$basedir/ulog”
ulimsiz=”256m”
sid=1
dbname=”$basedir/casket.tch#bnum=1000000″ #上面讲的数据库类型配置
maxcon=”65536″
retval=0
|
#! /bin/sh
#—————————————————————-
# Startup script for the server of Tokyo Tyrant
#—————————————————————-
# configuration variables
prog=”ttservctl”
cmd=”ttserver”
basedir=”/data/data/data1″
port=”11211″
pidfile=”$basedir/pid”
logfile=”$basedir/log”
ulogdir=”$basedir/”
mhost=”192.168.1.177″ #主ip即另外机器的ip
ulimsiz=”256m”
sid=6#注意要每台机器不一样
dbname=”$basedir/casket.tch#bnum=100000000#xmsiz=104857600#rcnum=1000000″
rts=”$basedir/ttserver.rts” #在ttservctl基础上增加
maxcon=”65536″
retval=0
# locale clear
LANG=C
LC_ALL=C
export LANG LC_ALL
# start the server
start(){
printf ‘Starting the server of Tokyo Tyrant\n’
ulimit -n “$maxcon”
mkdir -p “$basedir”
if [ -f "$pidfile" ] ; then
pid=`cat “$pidfile”`
printf ‘Existing process: %d\n’ “$pid”
retval=1
else
$cmd \
-port “$port” \
-dmn \
-pid “$pidfile” \
-log “$logfile” \
-ulog “$ulogdir” \
-ulim “$ulimsiz” \
-sid “$sid” \
-mhost “$mhost” \#在ttservctl基础上增加
-mport “$port” \#在ttservctl基础上增加
-rts “$rts” \#在ttservctl基础上增加
“$dbname”
if [ "$?" -eq 0 ] ; then
printf ‘Done\n’
else
printf ‘The server could not started\n’
retval=1
fi
fi
}
|
177的配置: