项目网站:
http://1978th.net/
一、install:
1.到http://tokyocabinet.sourceforge.net上下载最新版本。
wget http://tokyocabinet.sourceforge.net/misc/tokyocabinet-1.4.19-rc1.tar.gz
wget http://tokyocabinet.sourceforge.net/misc/tokyotyrant-1.1.24-rc1.tar.gz
2.tar xvzf tokyocabinet-1.4.19.tar.gz
cd tokyocabinet-1.4.19
./configure
make
make install(查看最终按装路径)
tar xvzf tokyotyrant-1.1.24-rc1.tar.gz
cd tokyotyrant-1.1.24-rc1
./configure
make
make install(查看最终按装路径)
二、启动
在/tmp/下面创建ttserver目录,保存ttserver启动后的一些日志文件等文件
默认的的安装路径是:/usr/local/bin里面
cd /usr/local/bin
(1)、单机模式 用hash数据库
./ttserver -host 10.0.9.100 -port 11211 -thnum 8 -dmn -pid /tmp/ttserver/ttserver.pid -log /tmp/ttserver/ttserver.log -le -ulog /tmp/ttserver/ -ulim 128m -sid 1 -rts /tmp/ttserver/ttserver.rts /tmp/ttserver/database.tch
----------------------------
用hash模式启动:
ttserver -host 10.0.8.9 -port 11211 -thnum 8 -dmn -pid /data3/ttserver/ttserver.pid -log /data3/ttserver/ttserver.log -le -ulog /data3/ttserver/ -ulim 128m -sid 1 -rts /data3/ttserver/ttserver.rts /data3/ttserver/database.tch#bnum=100000000#xmsiz=434217728#rcnum=200000
使用hash数据库,最大会缓存20000个记录,最大使用内存434217728bytes(414M),bucket存储桶的数量10000000。
(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
=============================================
一个运行中的tt启动配置
./ttserver -host 10.0.9.100 -port 22222 -thnum 8 -dmn -pid /tmp/ttserver/ttserver.pid -log /tmp/ttserver/ttserver.log -le -ulog /tmp/ttserver/ -ulim 128m -sid 100 -mhost 10.0.8.9 -mport 22222 -rts /tmp/ttserver/ttserver.rts /tmp/ttserver/database.tch#bnum=100000000#xmsiz=104857600#rcnum=1000000
./ttserver -host 10.0.8.9 -port 22222 -thnum 8 -dmn -pid /data2/ttserver/ttserver.pid -log /data2/ttserver/ttserver.log -le -ulog /data2/ttserver/ -ulim 128m -sid 9 -mhost 10.0.9.100 -mport 22222 -rts /data2/ttserver/ttserver.rts /data2/ttserver/database.tch#bnum=100000000#xmsiz=104857600#rcnum=1000000
================================================
(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
--------------------------
三、java api使用(编译老是通不过,不能产生jar文件,只好直接copy解压后里面的.java源文件到eclipse里面直接使用)
编译java api
http://tokyocabinet.sourceforge.net/javapkg/tokyocabinet-java-1.18.tar.gz
tar zxvf tokyocabinet-java-1.18.tar.gz
cd tokyocabinet-java-1.18
编译时一定要设置JAVA_HOME环境变量,不然会报找不到jni.h错误
export JAVA_HOME=.....
./configure
make
make install
编辑当前用户的环境变量,增加一下这些参数
CLASSPATH=$CLASSPATH:/usr/local/lib/tokyocabinet.jar
LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib
export CLASSPATH LD_LIBRARY_PATH
重新登陆让环境变量生效,或者执行source ~/.bashrc (ubuntu下是这个文件)
=================================================
四、linux下的一些使用命令:
1.telnet 10.0.8.9 11211
2.stats 查看tt的状态
3.get 13400126409(key) 通过key查看value
五、调用
1、任何Memcached客户端均可直接调用tokyotyrant。
2、还可以通过HTTP方式调用,下面以Linux的curl命令为例,介绍如何操作tokyotyrant:
(1)、写数据,将数据“value”写入到“key”中:
curl -X PUT http://127.0.0.1:11211/key -d "value"
(2)、读数据,读取“key”中数据:
curl http://127.0.0.1:11211/key
(3)、删数据,删除“key”:
curl -X DELETE http://127.0.0.1:11211/key
=================================================
3.数据库支持类型说明
A.如果数据库名为”*”,表示内存hash数据库.内存hash数据库支持”bnum”,”capnum”和”capsiz”
B.如果数据库名为”+”表示内存tree数据库.内存tree数据库支持”capnum”和”capsiz”.
“capnum”指定记录的最大容量,”capsiz”指定最大的内存使用量(在内存数据库中),记录通过存储的顺序移除.
C.如果数据库名为”.tch”,则数据库为hash数据库.
hash数据库支持”mode”, “bnum”, “apow”, “fpow”, “opts”, “rcnum”, 和 “xmsiz”.
“rcnum” 指定最大的缓存记录数。如果它不大于零,那么缓存记录不可用。默认不可用
“xmsiz” 指定外部内存的大小。如果不大于0,内存不可用。默认是67108864,即64M。
“bnum”指定bucket存储桶的数量.如果指定的数目不大于0,将会使用默认的数值131071.推荐数量应该在所有需要存储的记录总数的0.4-4倍
“apow” 跟一个key关联的记录数,2的N次方表示.如果不指定,默认2^4=16.
“fpow” specifies the maximum number of elements of the free block pool by power of 2.默认2^10=1024.
“opts” 指定选项,位或:”HDBTLARGE” 指定数据库的大小通过使用64位数组桶能够超过2G.
“HDBTDEFLATE” 指定每个记录被 Deflate encoding压缩.
“HDBTBZIP” 指定每个记录被 BZIP2 encoding压缩
“HDBTTCBS” 指定每个记录被 TCBS encoding压缩.
D.如果数据库名的后缀为”.tcb”,数据库将为B+ tree数据库。
B+ tree数据库支持”mode”, “lmemb”, “nmemb”, “bnum”, “apow”, “fpow”, “opts”, “lcnum”, “ncnum”, 和 “xmsiz”.
通过指定”#lcnum=xxx#bnum=yyy” 来提高性能.
第一个参数指定被缓存的最大叶子节点数,受内存容量限制,第二个参数指定桶的数量,它应该大于总记录数的1/128
E.如果数据库名的后缀为”.tcf”.则数据库将为fixed-length数据库。
Fixed-length 数据库 支持 “mode”, “width”, and “limsiz”.
F.如果数据库名的后缀为”.tct”,则数据将为一个table数据库(有表的概念).
Table 数据库支持 “mode”, “bnum”, “apow”, “fpow”, “opts”, “rcnum”, “lcnum”, “ncnum”, “xmsiz”, 和 “idx”
“idx”指定表的索引。
“mode”可以包含 “w” 写, “r” 读, “c” 创建, “t” 截断,”e” 无锁,和”f” 非阻塞锁.默认的的mod为”wc”。
三、测试:
写入数据
curl -X PUT http://127.0.0.1:11211/my_key -d "this is value 100"
取数据
curl http://127.0.0.1:11211/my_key
删除数据
curl -X DELETE http://127.0.0.1:11211/my_key
================================================
安装好ttserve之后,在/usr/local/bin里面会有个tcrmttest命令,可以用它测试一下ttserver的性能
1.写测试
./tcrmttest write -port 11211 10.0.8.3 1000000
2.读测试
./tcrmttest read -port 11211 10.0.8.3
================================================
实时查看ttserver的并发连接数:
watch "netstat -ant |grep 10.0.8.3:11211 |wc -l"
实时查看ttserver的状态
watch "echo stats | nc 10.0.8.3 11211"
====================================================
我们在实际使用的时候 Tokyo Tyrant服务端的端口有时候会telnet 不上去 应该是和连击数过大有关
一般Tokyo Tyrant服务端在双核2.6 4G内存的服务器上能撑到1000并发连击数,过了1000有时候会telnet 不上去,这时候无法同步新数据,但是还是可以的查询原有的数据。
让处于TIME_WAIT状态的连接重用,可以提高 Tokyo Tyrant并发数
在/etc/sysctl.conf中加上:
net.ipv4.tcp_fin_timeout = 30
net.ipv4.tcp_keepalive_time = 300
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.ip_local_port_range = 5000 65000
然后
/sbin/sysctl -p
分享到:
相关推荐
在 Linux 系统中,通常可以通过包管理器安装 memcached,例如使用 apt-get (Ubuntu/Debian) 或 yum (CentOS/RHEL)。安装完成后,可以使用以下命令启动 memcached 服务: ```bash # 启动 memcached sudo service ...
1. 键值(Key-Value)存储数据库:以键值对的形式存储数据,典型产品包括Redis、Tokyo Cabinet/Tyrant等。主要应用在内容缓存的场景中,优势是快速查询,劣势是存储的数据缺少结构化。 2. 列存储数据库:采用列簇式...
1. **键值(Key-Value)存储数据库**:这类数据库通过键值对的形式存储数据,例如Tokyo Cabinet/Tyrant、Redis、Voldemort、Berkeley DB。它们适用于内容缓存等需要处理大量数据的高访问负载场景。优点在于能够实现...
1. **键值(Key-Value)存储数据库**:如Tokyo Cabinet/Tyrant、Redis、Voldemort等。这类数据库适用于需要高速访问的大规模数据存储场景。其数据模型为一系列键值对,具有快速查询的优势,但存储的数据缺少结构化特性...
人脸识别项目实战
内容概要:本文详细描述了一个完整的Web应用程序的开发过程。该项目主要采用了Hono作为服务器框架,Prisma作为ORM工具,JWT用于认证鉴权,以及一系列现代化的最佳实践确保系统的健壮性和安全性。项目初期构建了基础架构,并设置了必要的依赖和工具。在后端方面涵盖了公共API接口的设计、CRUD增删改查逻辑、用户认证和授权等功能。此外还特别关注到了API的安全保护,如输入输出的校验,跨站请求伪造CSRF的防范,XSS防御等措施;为确保代码的质量引入了代码检测(比如ESLint搭配Prettier),并建立了完善的测试框架以保障后续开发阶段的功能正确。对于可能出现的问题预先定义了一组规范化的异常响应,并提供OpenAPI文档以方便开发者理解和调用。数据存储层面上利用了关系型与非关系型数据库各自的特性,实现了数据的有效组织,最后提供了实用的脚本,可用于种子数据插入以及执行必要的初始化工作。 适合人群:面向具有一定JavaScript/TypeScript开发经验,尤其是Node.js后台服务搭建经验的中级程序员和技术团队。 使用场景及目标:这份材料非常适合那些需要快速建立安全高效的RES
【资源介绍】 1、该资源包括项目的全部源码,下载可以直接使用! 2、本项目适合作为计算机、数学、电子信息等专业的课程设计、期末大作业和毕设项目,也可以作为小白实战演练和初期项目立项演示的重要参考借鉴资料。 3、本资源作为“学习资料”如果需要实现其他功能,需要能看懂代码,并且热爱钻研和多多调试实践。 掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip
手势识别项目实战
(参考GUI)MATLAB BP的交通标志系统.zip
人脸识别项目实战
内容概要:本文详细介绍了 C++ 函数的基础概念及其实战技巧。内容涵盖了函数的基本结构(定义、声明、调用)、多种参数传递方式(值传递、引用传递、指针传递),各类函数类型(无参无返、有参无返、无参有返、有参有返),以及高级特性(函数重载、函数模板、递归函数)。此外,通过实际案例展示了函数的应用,如统计数组元素频次和实现冒泡排序算法。最后,总结了C++函数的重要性及未来的拓展方向。 适合人群:有一定编程基础的程序员,特别是想要深入了解C++编程特性的开发人员。 使用场景及目标:① 学习C++中函数的定义与调用,掌握参数传递方式;② 掌握不同类型的C++函数及其应用场景;③ 深入理解函数重载、函数模板和递归函数的高级特性;④ 提升实际编程能力,通过实例强化所学知识。 其他说明:文章以循序渐进的方式讲解C++函数的相关知识点,并提供了实际编码练习帮助理解。阅读过程中应当边思考边实践,动手实验有助于更好地吸收知识点。
Comsol光学仿真模型:包括纳米球 柱 Mie散射多级分解 ,Comsol光学仿真模型; 纳米球; 柱; Mie散射; 多级分解,Comsol光学仿真模型:纳米结构Mie散射多级分解
永磁同步电机全速域控制高频方波注入法、滑模观测器法SMO、加权切矢量控制Simulink仿真模型 低速域采用高频方波注入法HF,高速域采用滑膜观测器法SMO,期间采用加权形式切 送前方法 1、零低速域,来用无数字滤波器高频方波注入法, 2.中高速域采用改进的SMO滑模观测器,来用的是sigmoid函数,PLL锁相环 3、转速过渡区域采用加权切法 该仿真各个部分清晰分明,仿真波形效果良好内附详细控制方法资料lunwen 带有参考文献和说明文档,仿真模型 ,核心关键词: 1. 永磁同步电机; 2. 全速域控制; 3. 高频方波注入法; 4. 滑模观测器法SMO; 5. 加权切换矢量控制; 6. Simulink仿真模型; 7. 零低速域控制; 8. 中高速域控制; 9. 转速过渡区域控制; 10. 仿真波形效果; 11. 详细控制方法资料; 12. 参考文献和说明文档。,永磁同步电机多域控制策略的仿真研究
基于蜣螂优化算法的无人机三维路径规划【23年新算法应用】可直接运行 Matlab语言 主要内容:读取地形数据,利用蜣螂算法DBO优化三维路径,目标函数为总路径最短,同时不能撞到障碍物,效果如图所示,包括迭代曲线图、三维路径图、二维平面图等等 ,基于蜣螂优化算法;无人机;三维路径规划;总路径最短;障碍物避免;Matlab语言;迭代曲线图;三维路径图;二维平面图,蜣螂算法优化无人机三维路径规划:实时避障、路径最短新应用
清华大学2024年研究生复试上机考试题.zip
南京理工大学研究生入学考试2011年复试上机试题
手势识别项目实战
这里是3501的内容,用于复习资料
异步电动机变压变频调速系统,包含六千多字的文档、框架图、Simulink仿真模型,电力拖动、电机控制仿真设计 仿真模型+报告 开关闭环对比仿真都有,资料如图所见如所得 ,异步电动机;变压变频调速系统;六千字文档;框架图;Simulink仿真模型;电力拖动;电机控制仿真设计;开闭环对比仿真;资料如图。,异步电机控制仿真系统:六千字详解与图解
人脸识别项目实战