java连接linux Redis遇到的问题

   昨天在Linux搭建了Redis服务,今天使用java连接测试了一下。要想使用java连接redis服务,就离不开jedis-2.6.1.jar。使用jedis连接redis十分方便。下面我们测试一下是否连接上redis服务:

package com.coinvs.redis.util;
import redis.clients.jedis.Jedis;
//import redis.clients.jedis.Jedis;
public class RadisDemo {
      public static void main(String[] args) {
    //连接本地的 Redis 服务
    Jedis jedis = new Jedis("192.168.1.66",);
    System.out.println("Connection to server sucessfully");
    //查看服务是否运行
    System.out.println("Server is running: "+jedis.ping());
   }
}

如果出现下图,这说明没有连接成功,不过不用担心,这很好解决。

连接redis失败

出现这种错误的原因有以下几种:

  1. redis服务没有开启;
  2. 没有正确输入,ip、端口;
  3. Linux系统防火墙没有关闭;
  4. 防火墙关闭了,但是访问者ip,在redis.conf文件的bind之外。

简单设置一下,应该就可以连接上了!

下面我们简单说一下,jedis API的使用:

  1.redis存储字符串
//   @Test
   public void testString() {
       //-----添加数据----------
       jedis.set("name","往往");//向key-->name中放入了value--xinxin
       System.out.println(jedis.get("name"));//执行结果:xinxin
       jedis.append("name", " is my lover"); //拼接
       System.out.println(jedis.get("name"));
       jedis.del("name");  //删除某个键
       System.out.println(jedis.get("name"));
       //设置多个键值对
       jedis.mset("name","liuling","age","23","qq","476777XXX");
       System.out.println(jedis.get("age"));
       jedis.incr("age"); //进行加1操作
       System.out.println(jedis.get("age"));
       System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq"));
   }

  2.redis操作Map
//    @Test
   public void testMap() {
       //-----添加数据----------
       Map<String, String> map = new HashMap<String, String>();
       map.put("name", "xinxin");
       map.put("age", "22");
       map.put("qq", "123456");
       jedis.hmset("user",map);
       //取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List
       //第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数
       List<String> rsmap = jedis.hmget("user", "name", "age", "qq");
       System.out.println(rsmap);
       //删除map中的某个键值
       jedis.hdel("user","age");
       System.out.println(jedis.hmget("user", "age")); //因为删除了,所以返回的是null
       System.out.println(jedis.hlen("user")); //返回key为user的键中存放的值的个数2
       System.out.println(jedis.exists("user"));//是否存在key为user的记录 返回true
       System.out.println(jedis.hkeys("user"));//返回map对象中的所有key
       System.out.println(jedis.hvals("user"));//返回map对象中的所有value
       Iterator<String> iter=jedis.hkeys("user").iterator();
       while (iter.hasNext()){
           String key = iter.next();
           System.out.println(key+":"+jedis.hmget("user",key));
       }
   }
  3.jedis操作List
//    @Test
   public void testList(){
       //开始前,先移除所有的内容
       jedis.del("java framework");
       System.out.println(jedis.lrange("java framework",,-));
       //先向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",,-));
       jedis.del("java framework");
       jedis.rpush("java framework","spring");
       jedis.rpush("java framework","struts");
       jedis.rpush("java framework","hibernate");
       System.out.println(jedis.lrange("java framework",,-));
   }

  4. jedis操作Set
//    @Test
   public void testSet(){
       jedis.del("user");
       //添加
       jedis.sadd("user","liuling");
       jedis.sadd("user","xinxin");
       jedis.sadd("user","ling");
       jedis.sadd("user","zhangxinxin");
       jedis.sadd("user","who");
       //移除noname
       jedis.srem("user","who");
       System.out.println(jedis.smembers("user"));//获取所有加入的value
       System.out.println(jedis.sismember("user", "xinxin"));//判断 who 是否是user集合的元素
       System.out.println(jedis.srandmember("user")); //随机返回一个user中元素的value
       System.out.println(jedis.scard("user"));//返回集合的元素个数
   } 

5.jedis 排序

@Test
   public void test() throws InterruptedException {
       //
       //注意,此处的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",,-));// [9, 3, 6, 1]
       System.out.println(jedis.sort("a")); //[1, 3, 6, 9]  //输入排序后结果
       System.out.println(jedis.lrange("a",,-));
   }
 
简单的学习一下jedis的API,后续还会补充!

JAVA - Redis的连接的更多相关文章

  1. Java Redis系列3(Jedis的使用+jedis连接池技术)

    Jedis的使用 什么是Jedis? 一款Java操作redis数据库的工具 使用步骤 1.下载redis所需的java包 2.使用步骤 import org.junit.Test; public c ...

  2. (转)java redis使用之利用jedis实现redis消息队列

    应用场景 最近在公司做项目,需要对聊天内容进行存储,考虑到数据库查询的IO连接数高.连接频繁的因素,决定利用缓存做. 从网上了解到redis可以对所有的内容进行二进制的存储,而java是可以对所有对象 ...

  3. redis运用连接池报错解决

    redis使用连接池报错解决redis使用十几小时就一直报异常 redis.clients.jedis.exceptions.JedisConnectionException: Could not g ...

  4. Springboot监控之一:SpringBoot四大神器之Actuator之2--spring boot健康检查对Redis的连接检查的调整

    因为项目里面用到了redis集群,但并不是用spring boot的配置方式,启动后项目健康检查老是检查redis的时候状态为down,导致注册到eureka后项目状态也是down.问下能不能设置sp ...

  5. Springboot2.x整合Redis以及连接哨兵模式/集群模式

    依赖: <!--spirngboot版本为2.x--><!-- 加载spring boot redis包,springboot2.0中直接使用jedis或者lettuce配置连接池, ...

  6. java中myeclipse连接mysql问题(java.lang.ClassNotFoundException: com.mysql.jdbc.Driver)

    java中myeclipse连接mysql问题(java.lang.ClassNotFoundException: com.mysql.jdbc.Driver) 1.往项目中添加mysql-conne ...

  7. Redis高级实践之————Redis短连接性能优化

    摘要: 对于Redis服务,通常我们推荐用户使用长连接来访问Redis,但是由于某些用户在连接池失效的时候还是会建立大量的短连接或者用户由于客户端限制还是只能使用短连接来访问Redis,而原生的Red ...

  8. JAVA使用jdbc连接MYSQL简单示例

    以下展示的为JAVA使用jdbc连接MYSQL简单示例: import java.sql.DriverManager; import java.sql.ResultSet; import java.s ...

  9. Redis操作Set工具类封装,Java Redis Set命令封装

    Redis操作Set工具类封装,Java Redis Set命令封装 >>>>>>>>>>>>>>>>& ...

随机推荐

  1. 淘宝UWP桌面版已经发布

    目前正在等待应用商店的检测,很快会可以下载. 谢谢各位园主针对淘宝UWP 桌面版(又叫PC版,HD版等等)给予的feedback,在这里统一回复一下,就不一一感谢了. 有一件事需要说明一下,请看下图: ...

  2. Java设计模式11:外观模式

    外观模式 外观模式是对象的结构模式,外部与一个子系统的通信必须通过一个统一的外观对象进行.外观模式是一个高层次的接口,使得子系统更易于使用. 医院的例子 现代的软件系统都是比较复杂的.假如把医院比作一 ...

  3. 作业二:在github上过程

    注册Github

  4. 浅谈Excel开发:五 Excel RTD函数

        上文介绍了Excel中的UDF函数,本文介绍一下同样重要的RTD函数.从Excel 2002开始,Excel引入了一种新的查看和更新实时数据的机制,即real-time data简称RTD函数 ...

  5. 使用mybatis访问sql server

    原创文章转载请注明出处:@协思, http://zeeman.cnblogs.com mybatis作为一种半自动化的ORM工具,可以提供更大的灵活性,逐渐受到社区的欢迎. 官方下载地址是:https ...

  6. js数组转json

    function arrayToJson(o) { var r = []; if (typeof o == "string") return "\"" ...

  7. mysql C API的使用

    <MySQL++简介>介绍了如何使用C++来访问mysql,本文记录下使用C API访问mysql,mysql++就是对本文介绍的C-API的封装. 常用函数(名字就能告诉我们用法): M ...

  8. 爱上MVC3~布局页的继承与扩展

    回到 目录 在MVC3中引入了Razor引擎,这对于代码的表现力上是个突破,同时母板页也变成了_Layout,所以,我们就习惯上称它为布局页面,在razor里,布局页面是可以继承的,即,一个上下公用的 ...

  9. FreeMarker 学习

    一.FreeMarker FreeMarker是一款模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页.电子邮件.配置文件.源代码等)的通用工具. 它不是面向最终用户的,而是 ...

  10. hibernate(七) hibernate中查询方式详解

    序言 之前对hibernate中的查询总是搞混淆,不明白里面具体有哪些东西.就是因为缺少总结.在看这篇文章之前,你应该知道的是数据库的一些查询操作,多表查询等,如果不明白,可以先去看一下 MySQL数 ...