redis-jedis-java

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: redis-jedis-java

安装


参考:http://www.redis.cn/download.html

安装

下载,解压,编译:

$ wget http://download.redis.io/releases/redis-4.0.8.tar.gz

$ tar -zcvf redis-4.0.8.tar.gz

$ cd redis-4.0.8

$ make


启动

src/redis-server

内置的命令行工具command line interface

src/redis-cli

参考:http://www.cnblogs.com/liuling/p/2014-4-19-04.html


依赖

jedis:

<!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
            <dependency>
                <groupId>redis.clients</groupId>
                <artifactId>jedis</artifactId>
                <version>2.9.0</version>
            </dependency>

连接池:

<!-- https://mvnrepository.com/artifact/org.apache.commons/commons-pool2 -->
            <dependency>
                <groupId>org.apache.commons</groupId>
                <artifactId>commons-pool2</artifactId>
                <version>2.4.2</version>
            </dependency>

jedis操作redis

package impl.service.redis;
import face.service.RedisService;
import org.junit.Before;
import org.junit.Test;
import redis.clients.jedis.Jedis;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
/**
 * @author futao
 * Created on 18-2-28-下午5:15.
 */
public class RedisServiceImpl implements RedisService {
    private Jedis jedis;
    @Before
    public void setup() {
        /*连接redis服务器*/
        jedis = new Jedis("127.0.0.1", 6379);
        /*权限,密码*/
        //jedis.auth("");
    }
    /**
     * jedis存储字符串
     */
    @Test
    public void testString() {
        /*向redis中存String键值对 set*/
        jedis.set("name", "futao");
        /*从redis中读取String  get*/
        System.out.println(jedis.get("name"));
        /*拼接*/
        jedis.append("name", " is 666");
        System.out.println(jedis.get("name"));
        /*删除某个键值对*/
        jedis.del("name");
        System.out.println("del===" + jedis.get("name"));
        /*一次性添加多个键值对*/
        jedis.mset("k1", "v1", "k2", "v2", "age", "16");
        System.out.println(jedis.get("k1"));
        System.out.println(jedis.get("k2"));
        System.out.println(jedis.get("age"));
        /*age加一*/
        jedis.incr("age");
        System.out.println(jedis.get("age"));
        /*String类型的数据设置过期时间*/
        jedis.setex("name", 5, "Nicai");
        System.out.println(jedis.get("name"));
    }
    /**
     * jedis操作map
     */
    @Test
    public void testMap() {
        Map<String, String> map = new HashMap<>();
        map.put("user", "futao");
        map.put("age", "18");
        map.put("sex", "男");
        /*存hashMap数据,hmset()*/
        jedis.hmset("futaoInfo", map);
        /*设置过期时间*/
        jedis.expire("futaoInfo", 5);
        /*读取hashMap数据结构的数据。返回的是一个List*/
        System.out.println(jedis.hmget("futaoInfo", "sex", "user"));
        List<String> list = jedis.hmget("futaoInfo", "sex", "sex", "age");
        list.forEach(System.out::println);
        /*删除map中的某个键值对*/
        jedis.hdel("futaoInfo", "age");
        /*返回key为futaoInfo的键中存放的值的个数*/
        System.out.println("hlen===" + jedis.hlen("futaoInfo"));
        /*是否存在该key*/
        System.out.println("exist===" + jedis.exists("futaoInfo"));
        /*返回map对象中的所有key  */
        System.out.println("map-all-keys" + jedis.hkeys("futaoInfo"));
        /*返回map对象中的所有value */
        System.out.println("map-all-value" + jedis.hvals("futaoInfo"));
        Iterator<String> iterator = jedis.hkeys("futaoInfo").iterator();
        /*遍历map中存储的key-value*/
        while (iterator.hasNext()) {
            String key = iterator.next();
            System.out.println(key + "::" + jedis.hget("futaoInfo", key));
        }
        for (String key : jedis.hkeys("futaoInfo")) {
            System.out.println(key + "::" + jedis.hget("futaoInfo", key));
        }
    }
    /**
     * jedis操作list
     */
    @Test
    public void testList() {
        /*添加list数据*/
        jedis.lpush("javaFramework", "Spring", "SpringMVC", "Hibernate");
        /*获取list中的数据.-1表示获取所有数据*/
        List<String> javaFramework = jedis.lrange("javaFramework", 0, -1);
        for (String a : javaFramework) {
            System.out.println(a);
        }
    }
    /**
     * jedis操作set
     * **********************
     * * jedis支持有序set集合 *
     * **********************
     */
    @Test
    public void testSet() {
        /*存*/
        jedis.sadd("username", "futao");
        jedis.sadd("username", "futao1");
        jedis.sadd("username", "futao2");
        jedis.sadd("username", "futao3", "futao4", "futao5");
        /*读取set的所有value*/
        System.out.println(jedis.smembers("username"));
        /*判断futao是否是username的value*/
        System.out.println(jedis.sismember("username", "futao"));
        /*从key为username的set中随机读取一个值*/
        System.out.println(jedis.srandmember("username"));
        /*返回集合元素的个数*/
        System.out.println(jedis.scard("username"));
    }
    @Test
    public void test() {
        jedis.del("b");
        jedis.rpush("b", "7");
        jedis.lpush("b", "-5");
        jedis.lpush("b", "3");
        jedis.lpush("b", "99");
        jedis.lpush("b", "-666");
        System.out.print("before sort" + jedis.lrange("b", 0, -1));
        List<String> b = jedis.sort("b");
        System.out.println("B" + b);
        /*并不会改变原来的数据*/
        System.out.print("\nafter sort" + jedis.lrange("b", 0, -1));
    }
}

redis连接池

package impl.service.redis;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
/**
 * @author futao
 * Created on 18-2-28-下午7:13.
 */
public class RedisUtil {
    /*服务器地址*/
    private static final String HOST = "127.0.0.1";
    /*端口*/
    private static final int PORT = 6379;
    /*权限密码*/
    private static final String PASSWORD = null;
    //可用连接实例的最大数目,默认值为8;
    //如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。
    private static final int MAX_TOTAL = 1024;
    //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。
    private static final int MAX_IDLE = 200;
    //等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException;
    private static final int MAX_WAIT = 10000;
    private static final int TIMEOUT = 10000;
    //在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
    private static final boolean TEST_ON_BORROW = true;
    private static JedisPool jedisPool = null;
    static {
        JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
        jedisPoolConfig.setMaxTotal(MAX_TOTAL);
        jedisPoolConfig.setMaxIdle(MAX_IDLE);
        jedisPoolConfig.setMaxWaitMillis(MAX_WAIT);
        jedisPoolConfig.setTestOnBorrow(TEST_ON_BORROW);
        jedisPool = new JedisPool(jedisPoolConfig, HOST, PORT, TIMEOUT, PASSWORD);
    }
    /**
     * 获取jedis
     *
     * @return jedis实例
     */
    public synchronized static Jedis getJedis() {
        if (jedisPool != null) {
            Jedis resource = jedisPool.getResource();
            return resource;
        } else {
            return null;
        }
    }
    /**
     * 释放jedis资源
     *
     * @param jedis
     */
    public static void releaseResource(final Jedis jedis) {
        if (jedis != null) {
            jedisPool.returnResource(jedis);
        }
    }
}

@Test
    public void testRedisPool() {
        Jedis jedis = RedisUtil.getJedis();
        jedis.del("a");
        jedis.lpush("a", "111", "222", "333");
        List<String> a = jedis.lrange("a", 0, -1);
        for (String i : a) {
            System.out.println(i);
        }
        /*记得要释放资源*/
        RedisUtil.releaseResource(jedis);
    }


相关文章
|
1天前
|
云安全 监控 安全
|
7天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
836 5
|
12天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
1068 40
|
8天前
|
机器学习/深度学习 人工智能 数据可视化
1秒生图!6B参数如何“以小博大”生成超真实图像?
Z-Image是6B参数开源图像生成模型,仅需16GB显存即可生成媲美百亿级模型的超真实图像,支持中英双语文本渲染与智能编辑,登顶Hugging Face趋势榜,首日下载破50万。
627 36
|
12天前
|
人工智能 前端开发 算法
大厂CIO独家分享:AI如何重塑开发者未来十年
在 AI 时代,若你还在紧盯代码量、执着于全栈工程师的招聘,或者仅凭技术贡献率来评判价值,执着于业务提效的比例而忽略产研价值,你很可能已经被所谓的“常识”困住了脚步。
691 58
大厂CIO独家分享:AI如何重塑开发者未来十年
|
8天前
|
存储 自然语言处理 测试技术
一行代码,让 Elasticsearch 集群瞬间雪崩——5000W 数据压测下的性能避坑全攻略
本文深入剖析 Elasticsearch 中模糊查询的三大陷阱及性能优化方案。通过5000 万级数据量下做了高压测试,用真实数据复刻事故现场,助力开发者规避“查询雪崩”,为您的业务保驾护航。
444 28
|
15天前
|
数据采集 人工智能 自然语言处理
Meta SAM3开源:让图像分割,听懂你的话
Meta发布并开源SAM 3,首个支持文本或视觉提示的统一图像视频分割模型,可精准分割“红色条纹伞”等开放词汇概念,覆盖400万独特概念,性能达人类水平75%–80%,推动视觉分割新突破。
921 59
Meta SAM3开源:让图像分割,听懂你的话
|
5天前
|
弹性计算 网络协议 Linux
阿里云ECS云服务器详细新手购买流程步骤(图文详解)
新手怎么购买阿里云服务器ECS?今天出一期阿里云服务器ECS自定义购买流程:图文全解析,阿里云服务器ECS购买流程图解,自定义购买ECS的设置选项是最复杂的,以自定义购买云服务器ECS为例,包括付费类型、地域、网络及可用区、实例、镜像、系统盘、数据盘、公网IP、安全组及登录凭证详细设置教程:
202 114