ttServer缓存的简单使用
ttserver是一款 DBM 数据库,该数据库读写非常快,哈希模式写入100万条数据只需0.643秒,读取100万条数据只需0.773秒,是 Berkeley DB 等 DBM 的几倍。利用Tokyo Tyrant构建兼容Memcached协议、支持故障转移、高并发的分布式key-value持久存储系统。key-value分布式存储系统查询速度快、存放数据量大、支持高并发,非常适合通过主键进行查询,但不能进行复杂的条件查询。
- import java.util.Properties;
- import org.apache.commons.logging.Log;
- import org.apache.commons.logging.LogFactory;
- import org.springframework.core.io.ClassPathResource;
- import tokyotyrant.MRDB;
- import tokyotyrant.networking.NodeAddress;
- import tokyotyrant.transcoder.StringTranscoder;
- /**
- * 和ttServer服务端连接的工具类
- * 使用jar包:tokyotyrant-0.11.jar
- * @author 7q
- */
- public class TokyoTyrantDB {
- private static TokyoTyrantDB db = new TokyoTyrantDB();
- //默认值
- private String IP = "127.0.0.1";
- private String PORT = "8888";
- MRDB rdb = null;
- private Log logger = LogFactory.getLog(TokyoTyrantDB.class);
- /**
- * 创建对象的时候,加载配置文件,创建和ttServer服务器的连接
- */
- private TokyoTyrantDB() {
- try {
- /*
- * 读取配置文件(配置文件放在src下,或者放在src下的META-INF文件夹下,没有这个文件夹可以创建一个)
- * ip=192.168.0.100
- * port=99
- */
- ClassPathResource resource = new ClassPathResource("tt.properties");
- Properties properties = new Properties();
- properties.load(resource.getInputStream());
- if (properties.getProperty("ip") != null) {
- IP = properties.getProperty("ip");
- }
- //System.out.println(IP);
- if (properties.getProperty("port") != null) {
- PORT = properties.getProperty("port");
- }
- //System.out.println(PORT);
- rdb = new MRDB();
- //创建连接
- rdb.open(NodeAddress.addresses("tcp://" + IP + ":" + PORT));
- } catch (Exception e) {
- logger.error(e.getMessage(), e);
- }
- }
- public static TokyoTyrantDB getInstance() {
- return db;
- }
- /**
- * 保存数据到ttServer
- * @param key
- * @param value
- * @return 保存成功,返回true,保存失败,返回false
- */
- public boolean save(String key, String value) {
- try {
- if (rdb.put(key, value).get()) {
- return true;
- } else {
- return false;
- }
- } catch (Exception e) {
- logger.error(e.getMessage(), e);
- //如果保存数据出异常,重试再连接一次
- try {
- if (rdb == null) {
- rdb = new MRDB();
- rdb.open(NodeAddress.addresses("tcp://" + IP + ":" + PORT));
- }
- } catch (Exception ex) {
- logger.error(ex.getMessage(), ex);
- }
- return false;
- }
- }
- /**
- * 通过key获取value
- * @param key
- * @return 通过key获取value
- */
- public String getValueByKey(String key) {
- try {
- Object object = rdb.get(key, new StringTranscoder()).get();
- if (object != null) {
- return object.toString();
- }
- return null;
- } catch (Exception e) {
- logger.error(e.getMessage(), e);
- try {
- if (rdb == null) {
- rdb = new MRDB();
- rdb.open(NodeAddress.addresses("tcp://" + IP + ":" + PORT));
- }
- } catch (Exception ex) {
- logger.error(ex.getMessage(), ex);
- }
- return null;
- }
- }
- }
使用方式:
- public static void main(String[] args) {
- TokyoTyrantDB.getInstance().save(key, value);
- TokyoTyrantDB.getInstance().getValueByKey(key);
- }
ttServer缓存的简单使用的更多相关文章
- [原创]关于mybatis中一级缓存和二级缓存的简单介绍
关于mybatis中一级缓存和二级缓存的简单介绍 mybatis的一级缓存: MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果结果缓存起来,当下次查询的时候 ...
- 使用Spring缓存的简单Demo
使用Spring缓存的简单Demo 1. 首先创建Maven工程,在Pom中配置 <dependency> <groupId>org.springframework</g ...
- 关于mybatis中一级缓存和二级缓存的简单介绍
关于mybatis中一级缓存和二级缓存的简单介绍 mybatis的一级缓存: MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果结果缓存起来,当下次查询的时候 ...
- java项目中ehcache缓存最简单用法
java项目中ehcache缓存最简单用法: 1.下载ehcache-core-2.4.3.jar复制到项目的lib目录下 2.新建ehcache.xml文件,放置在项目src目录下的resour ...
- android APP是否需要缓存?+简单架构
问题的由来 昨天,当我写完我的第一篇博客之后,我便百无聊赖的玩起了手机!当我打开Google自带的一些app的时候,发现他们直接叫我连接网络,并没有缓存上次从网络获取的数据.这就让我感到很奇怪!于是我 ...
- Mybatis缓存(1)--------系统缓存及简单配置介绍
前言 Mybatis的缓存主要有两种: 系统缓存,也就是我们一级缓存与二级缓存: 自定义的缓存,比如Redis.Enhance等,需要额外的单独配置与实现,具体日后主要学习介绍. 在这里主要记录系统缓 ...
- Android 多用户多缓存的简单处理方案
需求:1.在缓存中记录用户登录信息.例如:用户名,密码 2.记录用户操作数据.例如:是否记住用户名密码.设置7天内自动登录等 简单设计:1)使用sqlite设计一张用户数据表,有用户名.密码.操作数据 ...
- C#中缓存的简单方法及使用Sql设置缓存依赖项
概述 使用Cache高速缓存可以提高数据的读取速度,减少服务器与客户端之间的数据交互.因为Cache一经创建就会占用服务器上的资源,所以Cache并不是越多越好,一般用于数据较固定,使用较频繁的地方. ...
- 【Java/Android性能优 6】Android 图片SD卡缓存 使用简单 支持预取 支持多种缓存算法 支持不同网络类型 支持序列化
本文转自:http://www.trinea.cn/android/android-imagesdcardcache/ 本文主要介绍一个支持图片自动预取.支持多种缓存算法.支持数据保存和恢复的图片Sd ...
随机推荐
- WMware给centos6.8虚拟机添加硬盘
背景 用WMware运行系统经常遇见系统磁盘不够用的情况,通常解决这个问题有两种方式: 1) 给现有磁盘扩容: 2) 给虚拟机添加一块虚拟硬盘: 磁盘扩容我还没试验成功,这里我先把给虚拟机添加一块硬盘 ...
- 一个自动安装LNMP的简洁Shell脚本
此脚本在生产服务器上使用了一年多,本脚本崇尚简单唯美,只需要一个脚本就可以在任何一台有网络的服务器上自动配置LNMP.本脚本会在脚本执行目录下,建packages目录用于存放LNMP所需要的软件.大家 ...
- Java设计模式中适配器模式的实现方法
在Java开发中,我们常常需要用到Java接口型模式中的适配器模式,那适配器设计模式到底是什么模式呢? 适配器模式(Adapter)就是把一个类的接口变换成客户端所期待的另一种接口,从而使原本接口不匹 ...
- hdu 1007 Quoit Design (最近点对问题)
Quoit Design Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- [洛谷P1972][SDOI2009]HH的项链
题目大意:给你一串数字,多次询问区间内数字的种类数 题解:莫队 卡点:洛谷数据加强,开了个$O(2)$ C++ Code: #include <cstdio> #include <a ...
- thr [树链剖分+dp]
题面 思路 首先,可以有一个$dp$的思路 不难发现本题中,三个点如果互相距离相同,那么一定有一个"中心点"到三个点的距离都相同 那么我们可以把本题转化计算以每个点为根的情况下,从 ...
- BZOJ4652 [Noi2016]循环之美 【数论 + 莫比乌斯反演 + 杜教筛】
题目链接 BZOJ 题解 orz 此题太优美了 我们令\(\frac{x}{y}\)为最简分数,则\(x \perp y\)即,\(gcd(x,y) = 1\) 先不管\(k\)进制,我们知道\(10 ...
- 有趣的数(number)
有趣的数(number) 题目描述 这些天 nodgd 在研究一类有趣的数.定义函数 f(n) f(n) f(n) 表示 n n n 在十进制表示下的数字之和.如果一个正整数 n n n 满足 f(n ...
- python代理池的实现
https://github.com/wangqifan/ProxyPool http://python.jobbole.com/86994/
- 转:mysql grant
本文实例,运行于 MySQL 5.0 及以上版本. MySQL 赋予用户权限命令的简单格式可概括为: grant 权限 on 数据库对象 to 用户 一.grant 普通数据用户,查询.插入.更新.删 ...