导航:首页 > 编程语言 > redisclientjava

redisclientjava

发布时间:2023-06-07 20:35:20

『壹』 为什么redis在java是同步缓存,而在nodejs是异步缓存

我看了一下node redis代码,来client.get直接返回的结果是!自client.shou_buffer。而且对于异步操作的js,这个值肯定是它向redis发送请求之前就被返回了的。

var returned = client.get(key,function(err,repy){
value = repy;
console.log(‘value is ’,value);
client.quit();
})
console.log(‘returned is ’,returned)
你可以看看哪个被先打印出来。 而且不要在返回数据之后就quit,因为你还要接着存取数据,下次难道还要用client手动连接上吗?这不是php。

『贰』 java代码怎么正则删除redis的数据

java代码怎么正则删除redis的数据,即批量删除符合一定条件的redis数据,现在介绍批量删除已某些字符开头的redis数据:

在Java中连接Redis,并进行操作,首先得加载以JAR包形式存在的Java中的Redis Client,我们这里选择Jedis。以下是使用Jedis的具体步骤:

  1. 在Maven项目中,在pom.xml中增加如下语句(即加载Jedis jar包):

    <dependency>

    <groupId>redis.clients</groupId>

    <artifactId>jedis</artifactId>

    <version>2.7.2</version>

    <type>jar</type>

    </dependency>

    如不是Maven工程,就自行下载Jedis jar包引用即可。

  2. 在加载Jedis JAR包之后,可以直接使用新建一个Jedis实例的方法,来建立一个到Redis的连接,并进行操作。不过跟Mysql一样,每次操作的时候,都建立连接,很耗费性能。解决方法就是从一个连接池中取出连接对象,用完还回去。使用连接池的方案还能解决很多同步性问题。

    在Jedis中,管理Redis连接的类是JedisPool

    package com.atzy


    importredis.clients.jedis.Jedis;

    importredis.clients.jedis.JedisPool;

    publicclassRedisHelper{

    publicstaticvoidmain(String[]args){

    JedisPooljedisPool=newJedisPool("localhost",6379);

    Jedisjedis=null;

    try{

    jedis=jedisPool.getResource();

    Stringpre_str="ab";

    Set<String>set=jedis.keys(pre_str+"*");

    Iterator<String>it=set.iterator();

    while(it.hasNext()){

    StringkeyStr=it.next();

    System.out.println(keyStr);

    jedis.del(keyStr);

    }

    }catch(Exceptione){

    e.printStackTrace();

    }finally{

    if(jedis!=null)

    jedis.close();

    }

    jedisPool.destroy();

    }

    }

以上代码则是批量删除以某字符串前缀的key 。

『叁』 java redis set怎样设置key

RedisClient.set("定义名" , 内容, 时间);
eg:
RedisClient.set("loginStatus" , phone.toString(), 15 * 1000);

『肆』 java代码中 单表查询出的list集合 怎么读写到redis中

查询出来的结果集是返回一个List,然后你倒序添加数据到redis里面就可以了。
// 返回一个数据库查询结果集,list
List<Map> list = userService.getUserList();

//倒序把数据放进去就好了,不然取出来的数据,跟你查询出来的结果数据是相反的
for (int i = list.size() - 1; i >= 0; i--) {
RedisPool.getClient().lpush("userList", list.get(i).toString());
}
----------------------------下面是RedisPool类-------------

import redis.clients.jedis.Jedis;

/**
* redis缓存运用
*
* @author TongJun
*
*/
public class RedisPool {

// redis 对象
private static Jedis jedis = null;
private static final String IP = "127.0.0.1";
private static final int PROT = 6379;

/**
* 单例模式构造redis对象
*
* @return
*/
public static synchronized Jedis getClient() {
if (jedis == null) {
jedis = new Jedis(IP, PROT);
}
return jedis;
}

}

『伍』 redis是怎么实现的

第一:Redis 是什么?

Redis是基于内存、可持久化的日志型、Key-Value数据库 高性能存储系统,并提供多种语言的API.

第二:出现背景

『陆』 如何用java获取redis的info

预备
jedis-2.5.2
commons-pool2-2.2.jar
使用单连接
此方式仅建议用于开发环境做调试用。
// 创建连接
String host = "192.168.56.102";
int port = 6379;
Jedis client = new Jedis(host, port);
// 执行set指令
String result = client.set("key-string", "Hello, Redis!");
System.out.println( String.format("set指令执行结果:%s", result) );
// 执行get指令
String value = client.get("key-string");
System.out.println( String.format("get指令执行结果:%s", value) );
运行上述代码,控制台输出:
set指令执行结果:OK
get指令执行结果:Hello, Redis!
使用连接池
此方式适用于仅使用单个Redis实例的场景。
// 生成连接池配置信息
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxIdle(10);
config.setMaxTotal(30);
config.setMaxWaitMillis(3*1000);

// 在应用初始化的时候生成连接池
JedisPool pool = new JedisPool(config, "192.168.56.102", 6379);

// 在业务操作时,从连接池获取连接
Jedis client = pool.getResource();
try {
// 执行指令
String result = client.set("key-string", "Hello, Redis!");
System.out.println( String.format("set指令执行结果:%s", result) );
String value = client.get("key-string");
System.out.println( String.format("get指令执行结果:%s", value) );
} catch (Exception e) {
// TODO: handle exception
} finally {
// 业务操作完成,将连接返回给连接池
if (null != client) {
pool.returnResource(client);
}
} // end of try block

// 应用关闭时,释放连接池资源
pool.destroy();

运行上述代码,控制台输出:

set指令执行结果:OK
get指令执行结果:Hello, Redis!
使用连接池+分布式
在规模较大的系统中,往往会有多个Redis实例做负载均衡。并且还实现主从备份,当主实例发生故障时,切换至从实例提供服务。
类似于Memcached的客户端,Jedis也提供了客户端分布式操作的方式,采用一致性哈希算法。
// 生成多机连接信息列表
List<JedisShardInfo> shards = new ArrayList<JedisShardInfo>();
shards.add( new JedisShardInfo("127.0.0.1", 6379) );
shards.add( new JedisShardInfo("192.168.56.102", 6379) );

// 生成连接池配置信息
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxIdle(10);
config.setMaxTotal(30);
config.setMaxWaitMillis(3*1000);

// 在应用初始化的时候生成连接池
ShardedJedisPool pool = new ShardedJedisPool(config, shards);

// 在业务操作时,从连接池获取连接
ShardedJedis client = pool.getResource();
try {
// 执行指令
String result = client.set("key-string", "Hello, Redis!");
System.out.println( String.format("set指令执行结果:%s", result) );
String value = client.get("key-string");
System.out.println( String.format("get指令执行结果:%s", value) );
} catch (Exception e) {
// TODO: handle exception
} finally {
// 业务操作完成,将连接返回给连接池
if (null != client) {
pool.returnResource(client);
}
} // end of try block

// 应用关闭时,释放连接池资源
pool.destroy();

运行上述代码,控制台输出:

set指令执行结果:OK
get指令执行结果:Hello, Redis!

阅读全文

与redisclientjava相关的资料

热点内容
word使用教程下载 浏览:295
电脑文件平铺图片默认大小 浏览:115
文件查看设置信息失败 浏览:668
编程如何编出乌鸦喝水的课文 浏览:20
国家反诈app报案助手怎么使用 浏览:439
秘密文件丢失多少天 浏览:237
js中csstext 浏览:382
目标文件名过长复制 浏览:892
乐动力计步器老版本 浏览:933
压缩文件链接怎么编辑 浏览:808
如何锁定PDF文件里的图章 浏览:89
数据库超时是什么 浏览:649
文件怎么改整列内容 浏览:764
360压缩文件发邮件空白 浏览:813
上哪里查自己大数据 浏览:907
编程语言怎么学车 浏览:189
编程该怎么学才能先找工作 浏览:524
文件刻制光盘多少钱 浏览:861
校园网的网络组成结构 浏览:862
u盘系统复制文件过大 浏览:843

友情链接