IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Java使用Redis及其优化 -> 正文阅读

[大数据]Java使用Redis及其优化

所有坚韧不拔的努力迟早会取得报酬的。—— 安格尔

开启远程连接

Redis默认是不支持远程连接的,这里需要手动开启远程连接。

  1. 关闭本机IP绑定,允许远程连接。找到redis.conf中的bind:127.0.0.1将其注释。
    在这里插入图片描述
  2. 开启密码校验。找到redis.conf中的requirepass去掉其注释并设置密码。在这里插入图片描述

Jedis连接Redis

创建一个Maven项目,导入Jedis依赖。

<dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <type>jar</type>
            <scope>compile</scope>
</dependency>

测试链接是否成功。

public static void main(String[] args) {
        //创建Jedis对象 如果使用的是默认端口 则可忽略 (本次使用的是Docker创建的Redis)
        Jedis jedis = new Jedis("127.0.0.1", 6379);
        //密码认证
        jedis.auth("123456");
        //测试连接
        String res = jedis.ping();
        //输出PONG表示连接成功 抛出异常则失败
        System.out.println(res);
    }

在这里插入图片描述使用Redis中写入一些值。不熟悉基本操作的可以查看Redis基本操作
在这里插入图片描述

//获取值
System.out.println(jedis.get("name"));
//写入值
String result = jedis.set("gender", "male");
System.out.println(result);

在这里插入图片描述
紧接着再去redis中查看刚才写入的gender
在这里插入图片描述
Jedis中提供的方法和Redis的命令基本上是一样的,所以这里的操作就不做过多的赘述了。
在这里插入图片描述

封装Jedis进行操作

Jedis对象不是线城安全的,所以在实际开发中,一般我们都是通过连接池来获取,使用完成后再还给连接池。

public interface JedisCall {
    void call(Jedis jedis);
}
public class RedisDemo {

    private JedisPool jedisPool;

    public RedisDemo(){
        GenericObjectPoolConfig config = new GenericObjectPoolConfig();
        //设置连接池最大空闲数
        config.setMaxIdle(100);
        //最大连接数
        config.setMaxTotal(300);
        //设置最大等待时间 -1表示无限制
        config.setMaxWaitMillis(30000);
        //开启空闲时间检查有效性
        config.setTestOnBorrow(true);
        //连接redis
        jedisPool = new JedisPool(config, "127.0.0.1", 6379, 30000);
    }

    public void execute(JedisCall jedisCall) {
    	//try resource
        try (Jedis jedis = jedisPool.getResource()) {
            jedisCall.call(jedis);
        }
    }
}
public class JedisTest {
    public static void main(String[] args) {
        RedisDemo redisDemo = new RedisDemo();
        redisDemo.execute(jedis -> {
            //TODO
			//做一些操作
        });
    }
}
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-12-06 15:20:17  更:2021-12-06 15:21:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 9:56:43-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码