redis-如何在工程中使用redis

时间:2023-03-09 22:18:56
redis-如何在工程中使用redis

    这里,我们介绍下如何使用redis作为缓存服务器使用在我们的工程中。

  使用思路

    对于java中的使用redis提供了一个jedis的jar包。我们在安装好我们的redis服务器以后,只需要通过redis提供的jra包的相应方法进行访问就可以得到数据了。为了尽可能的简单,我们就实现用java代码实现对redis的添加和读取。

  创建工程

    首先是创建一个测试的工程

    redis-如何在工程中使用redis

    然后,创建一个lib目录引入jar包,我引入的jar包是2.7.2的包,这是一个客户端链接redis的包,同学可以自行从网上下载相应的jar包。

    然后将这个jar包进行build path,然后得到的项目列表如下图:

    redis-如何在工程中使用redis

    在我们的jar包引入完成后,就是测试代码的编写了。

  测试

    首先我们创建一个测试的jar包(写不写都行,但是个人习惯把所有的代码都写在包里面),然后写一个jedisTest类。我直接把代码粘上来,具体说明写在代码注释中吧。

    

 package cn.test;

 import org.junit.Test;

 import redis.clients.jedis.Jedis;

 public class JedisTest {
//书写测试类
@Test
public void TestJedis(){
//创建jedis对象,相当于创建了一个客户端和reidis服务器的链接。需要ip和端口号,IP就是安装有redis服务的linux服务器的地址,端口号默认为6379
Jedis jedis= new Jedis("192.168.37.161",6379);
//ping redis服务器,这是它的一个方法,如果服务正常,会回复一个pong
String pong = jedis.ping();
System.out.println("如果服务器可用请返回pong,谢谢合作:"+pong);
//先用第一个键去取一次值,这个时候redis中没有数据返回应该是空的。
String value = jedis.get("key");
System.out.println("第一次访问的时候取到的值="+value);
//将数据存入reidis服务器中
jedis.set("key","第一次存入的值");
//将数据取出
value = jedis.get("key");
System.out.println("存入相应的值以后取到的值="+value);
//关闭和redis的链接
jedis.close();
} }

    测试代码运行完的结果如下:

    redis-如何在工程中使用redis

  redis的连接池

    我们刚才也看到了,我们的redis的链接每次都需要创建链接和关闭链接,这是很浪费资源的,所以,我们redis也有链接池的技术。以下为使用连接池的时候的代码,跟之前的测试代码相当类似,这里就不再赘述了。

  
 public class JedisPoolTest {

     public static void main(String[] args) {
// 1. 创建连接池JedisPool
JedisPool jedisPool = new JedisPool("192.168.37.161", 6379); // 2. 从连接池获取连接jedis
Jedis jedis = jedisPool.getResource(); // 3. 使用连接jedis操作redis
jedis.select(2); String pong = jedis.ping();
System.out.println(pong); String key = "jedisPoll";
String setResult = jedis.set(key, "hello redis!");
System.out.println(setResult); String getResult = jedis.get(key);
System.out.println(getResult); // 4.释放资源,每次用完jedis连接,必须close(),指的就是还回连接池
jedis.close(); // 程序结束,销毁连接池
jedisPool.close();
}
}