文档章节

java数据提交到mencached 和redis

石头哥哥
 石头哥哥
发布于 2012/10/25 15:11
字数 577
阅读 666
收藏 7

今天捣鼓了下mencached 还不错


依赖库

commons-pool-1.5.6

java_memcached-release_2.6.6

slf4j-api-1.6.1

slf4j-simple-1.6.1

mencached

第三方维护的win32版

http://splinedancer.com/memcached-win32/


package com.Mencached;

import com.danga.MemCached.MemCachedClient;
import com.danga.MemCached.SockIOPool;

import java.util.Date;

/**
 * Created with IntelliJ IDEA.
 * User: CHENLEI
 * Date: 12-10-25
 * Time: 下午2:15
 * To change this template use File | Settings | File Templates.
 * java数据提交到mencached 测试
 */
public class MenCached {

    private static MemCachedClient mcc = new MemCachedClient();

    // set up connection pool once at class load
    static {
        // server list and weights
        String[] servers =
                {
                        "127.0.0.1:11211",
//                        "server2.mydomain.com:1624",
//                        "server3.mydomain.com:1624"
                };

        Integer[] weights = { 3 };

        // SockIOPool
        SockIOPool pool = SockIOPool.getInstance();

        // set the servers and the weights
        pool.setServers( servers );
        pool.setWeights( weights );

        // initialize、最小和最大连接数以及最大处理时间
        pool.setInitConn( 5 );
        pool.setMinConn( 5 );
        pool.setMaxConn( 250 );
        pool.setMaxIdle( 1000 * 60 * 60 * 6 );


        pool.setMaintSleep(10);//thread sleep


        pool.setNagle( false );
        pool.setSocketTO( 3000 ); //timeout read  3secs
        pool.setSocketConnectTO( 0 );

        // initialize the connection pool
        pool.initialize();
    }

    private  MenCached(){}

   //获取MenCached操作引用
    public static MenCached getInstance()
    {
        return singlton.mencached;
    }
    private static final class singlton{
        private static final MenCached mencached=new MenCached();
    }

    /**
     * 添加一个指定的值到缓存中.
     * @param key
     * @param value
     * @return
     */
    public boolean add(String key, Object value)
    {
        return mcc.add(key, value);
    }

    public boolean add(String key, Object value, Date expiry)
    {
        return mcc.add(key, value, expiry);
    }

    /**
     * 替换一个指定的值到缓存中.
     * @param key
     * @param value
     * @return
     */
    public boolean replace(String key, Object value)
    {
        return mcc.replace(key, value);
    }

    /**
     *
     * @param key
     * @param value
     * @param expiry  过期
     * @return
     */
    public boolean replace(String key, Object value, Date expiry)
    {
        return mcc.replace(key, value, expiry);
    }

    /**
     * 删除一个指定的值到缓存中.
     * @param key
     * @param
     * @return
     */
    public boolean delete(String key)
    {
        return mcc.delete(key);
    }


    /**
     * 根据指定的关键字获取对象.
     * @param key
     * @return
     */
    public Object get(String key)
    {
        return mcc.get(key);
    }

    public static void main(String[] args)
    {
        MenCached cache = MenCached.getInstance();
        long t1=System.currentTimeMillis();
        for (int i=0;i<10;i++){
            cache.add(i+"",i) ;
            System.out.println("value:"+cache.get(i+""));
        }
        System.out.println(System.currentTimeMillis()-t1);
//        System.out.println("get value : " + cache.get("key"));
    }
}

对于redis ,你需要下载redis,这里我用的是window版本,配置好redis.conf后  start redis-server.exe redis.conf启动redis.

测试,你需要https://github.com/xetorthio/jedis/downloads

jedis

java客户端

使用简单,但是相关的文献较少,要想掌握,看api,或则看看源码咯,也不是很多

package com.Mencached;

import redis.clients.jedis.Jedis;

/**
 * Created with IntelliJ IDEA.
 * User: CHENLEI
 * Date: 12-10-27
 * Time: 上午11:34
 * To change this template use File | Settings | File Templates.
 * redis test
 */
public class redisDeamo {
    //在redis.conf中配置hosts prot
    private static final Jedis jedis = new Jedis("127.0.0.1",9090);
    public static redisDeamo getInstance(){
        return sigtlon.redis;
    }
    private redisDeamo(){
    }
    private static  final class sigtlon{
      private static final redisDeamo redis=new redisDeamo();
    }

    public void setJedis(java.lang.String key, java.lang.String value){
        jedis.set(key, value);
    }

    public Object getJedis(java.lang.String key){
        return  jedis.get(key);
    }


     //test
    public static void main(String[]args){
        redisDeamo.getInstance().setJedis("foo","909090");

        String value = (String) redisDeamo.getInstance().getJedis("foo");
        System.out.println("获取的值:"+ value);

    }



}

实际的应用 还得深入的去考究 

© 著作权归作者所有

共有 人打赏支持
石头哥哥
粉丝 301
博文 204
码字总数 120417
作品 2
重庆
程序员
加载中

评论(2)

石头哥哥
石头哥哥

引用来自“震秦”的评论

添加代码的时候可以使用add code,选中java,可以代码高亮.你这样的看的眼花.

good idea
震秦
震秦
添加代码的时候可以使用add code,选中java,可以代码高亮.你这样的看的眼花.
Java中使用Jedis操作Redis

使用Java操作Redis需要jedis-2.1.0.jar,下载地址:http://files.cnblogs.com/liuling/jedis-2.1.0.jar.zip 如果需要使用Redis连接池的话,还需commons-pool-1.5.4.jar,下载地址:http://fil...

脸大的都是胖纸
2015/03/25
0
0
实际项目中是选用Map还是选用Redis作为缓存?为什么?

参考网页 https://segmentfault.com/q/1010000009106416 实际项目中是选用Map还是选用Redis作为缓存?为什么? 具体选择Map还是Redis作为缓存,要看具体的需求,具体的应用场景 本地缓存和分...

karma123
06/27
0
0
JAVA之JDBC简单事务处理

1、什么是Java事务 通常观念认为,事务与数据库有关。事务是访问数据库的一个操作序列,数据库应用系统通过事务集来完成对数据库的存取。事务的正确执行使得数据库从一种状态转换成另一种状态...

火龙战士
2015/08/17
0
5
wireshark和RawCap跟踪并解决中文乱码问题

一、问题概述 说下程序的架构。 有个后台管理系统A,在页面修改数据后,会用httpClient发http请求给系统B; 系统B做了异步机制,收到A发的请求后,将数据封装为Mq消息发给RabbitMq,然后结束...

三国梦回
08/10
0
0
redis缓存服务器(Nginx+Tomcat+redis+MySQL实现session会话共享

一、redis介绍 redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型...

腿毛的忧伤
06/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

C++ gflags

gflags是google一个开源的处理命令行参数的库,相比getopt,更加容易使用。 定义参数 gflags主要支持的参数类型包括 DEFINEbool: boolean DEFINEint32: 32-bit integer DEFINEint64: 64-bit ...

SibylY
33分钟前
0
0
intellij IDEA Properties中文unicode转码问题

在IDEA中创建了properties文件,发现默认中文不会自动进行unicode转码。如下 在project settings - File Encoding,在标红的选项上打上勾,确定即可 效果图如下: unicode转码后效果...

muzi1994
34分钟前
0
0
Java IO类库之PipedWriter

一、PipedWriter介绍 PipedWriter是字符管道输出流,继承自Writer,功能与PipedOutputStream类似,通过与PipedReader组合使用实现类似管道的功能,在多线程环境下,一个线程使用PipedWriter...

老韭菜
38分钟前
0
0
精简分页组件(手写)

需要引入CSS(没错就是这4行) .pagelist { text-align: center; color: #666; width: 100%; clear: both; margin: 20px 0; padding-top: 20px }.pagelist a { color: #666; margin: 0 2px;......

AK灬
39分钟前
3
0
29 岁成为阿里巴巴 P8,工作前 5 年完成晋升 3 连跳,他如何做到?

泡泡是我的好朋友。今年 31 岁,毕业后就进了阿里巴巴,工作五年内从 P4 晋升至 P6、P7、P8。 和他很少聊到工作,但总觉得他有很棒的职场心得,应该分享出来,于是有了这次采访。希望对职场新...

Java填坑之路
41分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部