當前位置:首頁 » 編程語言 » redisjava

redisjava

發布時間: 2022-01-20 06:13:24

A. 如何用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!

B. redis java客戶端有哪些

Redis Desktop Manager 、Redis Client、Redis Studio、jedis

C. redis 鍵怎麼管理java

Java代碼
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

import javax.sound.midi.Soundbank;
import java.util.*;

/**
* @author: flychao88
* Time: 2012.5.7 16:23:15
*/
public class RedisTest {
JedisPool pool;
Jedis jedis;
@Before
public void setUp() {
pool = new JedisPool(new JedisPoolConfig(), "172.16.100.184");

jedis = pool.getResource();
jedis.auth("password");
}

/**
* Redis存儲初級的字元串
* CRUD
*/
@Test
public void testBasicString(){
//-----添加數據----------
jedis.set("name","minxr");//向key-->name中放入了value-->minxr
System.out.println(jedis.get("name"));//執行結果:minxr

//-----修改數據-----------
//1、在原來基礎上修改
jedis.append("name","jarorwar"); //很直觀,類似map 將jarorwar append到已經有的value之後
System.out.println(jedis.get("name"));//執行結果:minxrjarorwar

//2、直接覆蓋原來的數據
jedis.set("name","閔曉榮");
System.out.println(jedis.get("name"));//執行結果:閔曉榮

//刪除key對應的記錄
jedis.del("name");
System.out.println(jedis.get("name"));//執行結果:null

/**
* mset相當於
* jedis.set("name","minxr");
* jedis.set("jarorwar","閔曉榮");
*/
jedis.mset("name","minxr","jarorwar","閔曉榮");
System.out.println(jedis.mget("name","jarorwar"));

}

/**
* jedis操作Map
*/
@Test
public void testMap(){
Map<String,String> user=new HashMap<String,String>();
user.put("name","minxr");
user.put("pwd","password");
jedis.hmset("user",user);
//取出user中的name,執行結果:[minxr]-->注意結果是一個泛型的List
//第一個參數是存入redis中map對象的key,後面跟的是放入map中的對象的key,後面的key可以跟多個,是可變參數
List<String> rsmap = jedis.hmget("user", "name");
System.out.println(rsmap);

//刪除map中的某個鍵值
// jedis.hdel("user","pwd");
System.out.println(jedis.hmget("user", "pwd")); //因為刪除了,所以返回的是null
System.out.println(jedis.hlen("user")); //返回key為user的鍵中存放的值的個數1
System.out.println(jedis.exists("user"));//是否存在key為user的記錄 返回true
System.out.println(jedis.hkeys("user"));//返回map對象中的所有key [pwd, name]
System.out.println(jedis.hvals("user"));//返回map對象中的所有value [minxr, password]

Iterator<String> iter=jedis.hkeys("user").iterator();
while (iter.hasNext()){
String key = iter.next();
System.out.println(key+":"+jedis.hmget("user",key));
}

}

/**
* jedis操作List
*/
@Test
public void testList(){
//開始前,先移除所有的內容
jedis.del("java framework");
System.out.println(jedis.lrange("java framework",0,-1));
//先向key java framework中存放三條數據
jedis.lpush("java framework","spring");
jedis.lpush("java framework","struts");
jedis.lpush("java framework","hibernate");
//再取出所有數據jedis.lrange是按范圍取出,
// 第一個是key,第二個是起始位置,第三個是結束位置,jedis.llen獲取長度 -1表示取得所有
System.out.println(jedis.lrange("java framework",0,-1));
}

/**
* jedis操作Set
*/
@Test
public void testSet(){
//添加
jedis.sadd("sname","minxr");
jedis.sadd("sname","jarorwar");
jedis.sadd("sname","閔曉榮");
jedis.sadd("sanme","noname");
//移除noname
jedis.srem("sname","noname");
System.out.println(jedis.smembers("sname"));//獲取所有加入的value
System.out.println(jedis.sismember("sname", "minxr"));//判斷 minxr 是否是sname集合的元素
System.out.println(jedis.srandmember("sname"));
System.out.println(jedis.scard("sname"));//返回集合的元素個數
}

@Test
public void test() throws InterruptedException {
//keys中傳入的可以用通配符
System.out.println(jedis.keys("*")); //返回當前庫中所有的key [sose, sanme, name, jarorwar, foo, sname, java framework, user, braand]
System.out.println(jedis.keys("*name"));//返回的sname [sname, name]
System.out.println(jedis.del("sanmdde"));//刪除key為sanmdde的對象 刪除成功返回1 刪除失敗(或者不存在)返回 0
System.out.println(jedis.ttl("sname"));//返回給定key的有效時間,如果是-1則表示永遠有效
jedis.setex("timekey", 10, "min");//通過此方法,可以指定key的存活(有效時間) 時間為秒
Thread.sleep(5000);//睡眠5秒後,剩餘時間將為<=5
System.out.println(jedis.ttl("timekey")); //輸出結果為5
jedis.setex("timekey", 1, "min"); //設為1後,下面再看剩餘時間就是1了
System.out.println(jedis.ttl("timekey")); //輸出結果為1
System.out.println(jedis.exists("key"));//檢查key是否存在
System.out.println(jedis.rename("timekey","time"));
System.out.println(jedis.get("timekey"));//因為移除,返回為null
System.out.println(jedis.get("time")); //因為將timekey 重命名為time 所以可以取得值 min

//jedis 排序
//注意,此處的rpush和lpush是List的操作。是一個雙向鏈表(但從表現來看的)
jedis.del("a");//先清除數據,再加入數據進行測試
jedis.rpush("a", "1");
jedis.lpush("a","6");
jedis.lpush("a","3");
jedis.lpush("a","9");
System.out.println(jedis.lrange("a",0,-1));// [9, 3, 6, 1]
System.out.println(jedis.sort("a")); //[1, 3, 6, 9] //輸入排序後結果
System.out.println(jedis.lrange("a",0,-1));

}

D. redis在實際開發中,使用Java哪個框架

1、存儲簡單數據

try {
Jedis jedis = new Jedis();
jedis.set("name", "JackGSmith");
} catch (Exception e) {
//如果緩存連不上,則不處理
System.out.println("登錄無法更新該用戶緩存");
}

從redis緩存中獲取key為「name」的值,使用jedis.get("name"),用一個String變數接收即可。
2、存儲對象、集合
存對象集合用序列化的方式存儲,用反序列化的方式取值。存儲的key和value都是轉化成位元組碼的形式。
先定義一個抽象類:SerializeTranscoder.java,代碼如下:

package cn.com.taiji.sample.utils;

import java.io.Closeable;
import java.io.IOException;

public abstract class SerializeTranscoder {

public abstract byte[] serialize(Object value);

E. java redis 連接池有哪幾種

我只知道redis.clients.jedis.Jedis里有
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
能有,你可以搜索試下。

F. java操作redis有哪些方法

電腦安裝Redis,然後通過JRedis(jar包)下的JRedis redis = new JRedis(address,port);就可以操作了,比連接資料庫還簡單,如果是windows的話 建議裝虛擬機用linux安裝redis,其他的只要你懂redis,用java操作redis太簡單了

G. 如何在java中使用redis

publicclassRedisListJava{
publicstaticvoidmain(String[]args){
//連接本地的Redis服務
Jedisjedis=newJedis("localhost");
System.out.println("Connectiontoserversucessfully");
//存儲數據到列表中
jedis.lpush("tutorial-list","Redis");
jedis.lpush("tutorial-list","Mongodb");
jedis.lpush("tutorial-list","Mysql");
//獲取存儲的數據並輸出
List<String>list=jedis.lrange("tutorial-list",0,5);
for(inti=0;i<list.size();i++){
System.out.println("Storedstringinredis::"+list.get(i));
}
}
}

H. 怎麼在java中實現redis的添加數據

第一步,在windows下載安裝配置好redis資料庫。這里我就不再概述了。下載jedis-2.4.2.jar,當然最好是下載最新版本的jar包。這個在網路搜索下就出來的。下載後,放在一個文件夾下面,一會會需要到。

第二步。打開eclipse,新建一個java工程。如下圖所示:

第三步:在Test這個java工程裡面,我們新建一個folder,命名lib,把剛才下載的jedis-2.4.2.jar包放在我們新建的lib的包下面,如下圖所示:

第四步,在eclipse中,選中jar包,build path下。然後我們再Test這個項目裡面我們新建一個class,class名字為TestConnect。

第五步,在類裡面,我們輸入如下的內容:
// Connecting to Redis server on localhost
//實例化一個客戶端
Jedis jedis = new Jedis("localhost");
//=================================================
// check whether server is running or not
//ping下,看看是否通的
System.out.println("Server is running: " + jedis.ping());
//保存一個
jedis.set("leiTest", "localhost Connection  sucessfully");
//獲取一個
System.out.println("通過key獲取value:    " + jedis.get("leiTest"));

第六步,對剛才的類進行運行,ctrl+f11快捷鍵運行下,如下圖所示:

第七步,進一步驗證我們是否在redis上是否保存了數據,並且能夠取出來,我們到redis安裝包的目錄,如下圖,打開紅色框內的 redis-cli.exe,打開後,我們進入下面的第二個圖片的界面。

第八步:我們在redis的客戶端的界面 輸入  get leiTest  這個指令。leiTest是剛才在eclipse中我們存入redis資料庫中的一個String類型的鍵。如下圖,證明我們確實成功了,你也試試吧。

I. redis keys* 用java代碼怎麼寫

代碼如下:
local food=redis.call('hget',KEYS[1],'food');
food=food+ARGV[1];
redis.call('hset',KEYS[1],'food',food);
local diamond=redis.call('hget',KEYS[1],'diamond');
diamond=diamond+ARGV[2];
redis.call('hset',KEYS[1],'diamond',diamond);

熱點內容
android桌面動畫 發布:2024-12-31 03:27:22 瀏覽:326
小說緩存網 發布:2024-12-31 02:55:29 瀏覽:921
安卓手機上的簡訊放在哪個文件 發布:2024-12-31 02:55:19 瀏覽:541
樂視1s什麼配置 發布:2024-12-31 02:48:55 瀏覽:225
python等待線程結束 發布:2024-12-31 02:41:58 瀏覽:401
沈陽php網站 發布:2024-12-31 02:41:58 瀏覽:958
烤冷麵存儲 發布:2024-12-31 02:39:56 瀏覽:494
android引用資源文件 發布:2024-12-31 02:27:37 瀏覽:36
html刪除緩存 發布:2024-12-31 02:11:32 瀏覽:835
全球現有存儲空間價值 發布:2024-12-31 02:01:12 瀏覽:982