文档章节

java数据提交到mencached 和redis

石头哥哥
 石头哥哥
发布于 2012/10/25 15:11
字数 577
阅读 685
收藏 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);

    }



}

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

© 著作权归作者所有

石头哥哥

石头哥哥

粉丝 303
博文 203
码字总数 120417
作品 2
广州
程序员
私信 提问
加载中

评论(2)

石头哥哥
石头哥哥 博主

引用来自“震秦”的评论

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

good idea
震秦
震秦
添加代码的时候可以使用add code,选中java,可以代码高亮.你这样的看的眼花.
Java程序员从阿里面试回来,这些面试题你们会吗?

前不久刚从阿里面试回来,为了这场面试可以说准备了一个半月,做的准备就是刷题和看视频看书充实自己的技术,话说是真难啊,不过还算顺利拿到了offer,有很多面试题我已经记不起来了,这些是...

java填坑路
2019/01/04
0
0
【高并发】高并发分布式锁架构解密,不是所有的锁都是分布式锁!!

写在前面 最近,很多小伙伴留言说,在学习高并发编程时,不太明白分布式锁是用来解决什么问题的,还有不少小伙伴甚至连分布式锁是什么都不太明白。明明在生产环境上使用了自己开发的分布式锁...

冰河团队
04/26
0
0
Maven + Springboot + redis 配置

前言 刚进入到Java 开发的世界,对于小白Java的我来说,使用Maven + SpringBoot 的项目下启动redis; 第一步 本地安装Redis 服务 关于redis的教程链接 点击这里:https://www.runoob.com/re...

osc_3z3urvvj
2019/07/16
1
0
阿里的面试官都喜欢问哪些技术问题?

金九银十是招聘的旺季,小编在这里也给大家整理了一套阿里面试官最喜欢问的问题或者出场率较高的面试题,助校招或者社招路上的你一臂之力! 首先我们需要明白一个事实,招聘的一个很关键的因...

Java填坑之路
2018/08/26
0
0
爬了各大搜索引擎,2019年Java面试题(集合+并发+调优+微服务)

Java集合22题 ArrayList 和 Vector 的区别。 说说 ArrayList,Vector, LinkedList 的存储性能和特性。 快速失败 (fail-fast) 和安全失败 (fail-safe) 的区别是什么? hashmap 的数据结构。 Ha...

Java架构师追风
2019/10/25
0
0

没有更多内容

加载失败,请刷新页面

加载更多

文献速递20200524

一 文献题目:Characterizing the Causal Pathway for Genetic Variants Associated with Neurological Phenotypes Using Human Brain-Derived Proteome Data 不想看英文题目:使用人脑蛋白质......

osc_mbhfa1vl
25分钟前
9
0
【Java入门】JDK安装和环境变量配置(Win7版)

系统环境:Windows7 x64 安装JDK和JRE版本:1.8.0_191 1、下载JDK安装包 Oracle官网下载网址:https://www.oracle.com/technetwork/java/javase/downloads/index.html 选择需要下载的JDK版本...

osc_s7aj86hu
26分钟前
11
0
Android Q 指纹解锁流程

Android Q 指纹解锁流程 // Authentation Finger Schedule: (close Screen, Authentation with finger(Success))        // PhoneWindowManager        mKeyguardDelegate.onStar......

osc_0qnrwmy3
28分钟前
12
0
List的扩容机制,你真的明白吗?

一:背景 1. 讲故事 在前一篇大内存排查中,我们看到了Dictionary正在做扩容操作,当时这个字典的count=251w,你把字典玩的66飞起,其实都是底层为你负重前行,比如其中的扩容机制,当你遇到...

osc_34b9n45c
29分钟前
14
0
2020.04.12软件更新公告

原创软件区升级ComicsViewer、DjVuToy、Pdg2Pic、PdgRenamer、PdgThumbViewer

osc_6tgtqi6v
30分钟前
23
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部