redis系列——Redis的客户端连接(二)

迈不过友情╰ 2023-10-09 12:25 138阅读 0赞

一、Redis自带的客户端

  1. 客户端启动命令为:./redis-cli -h 127.0.0.1 -p 6379

20190925175708847.png

  • -h:指定访问的redis服务器的ip地址
  • -p:指定访问的redis服务器的port端口
  • -a:指定访问的redis服务器的密码口令

此外还可以缩写成:./redis-cli,使用默认配置,默认的ip【127.0.0.1】,默认的port【6379】。关闭方式为:Ctrl+c或者quit。

二、图形界面客户端

  1. windows程序,下载链接为链接:https://pan.baidu.com/s/1Zmbcn3dEDKfHw8gl6GN\_Gw 提取码:tp2l

安装后创建连接如下:

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzIyMTcyMTMz_size_16_color_FFFFFF_t_70

连接后如下:

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzIyMTcyMTMz_size_16_color_FFFFFF_t_70 1

  1. 默认一共是16个数据库,每个数据库之间是相互隔离。数据库的数量是在redis.conf中配置的。如下:

2019092517595456.png

默认将数据存储到小标为0的数据库中。切换数据库使用命令:select 数据库编号

20190925180004511.png

退出为:quit

附加:如果无法访问可能是Linux防火墙拦截了该端口,可以进行相关设置。解决办法如下:

第一步:编辑iptables

  1. vim /etc/sysconfig/iptables

在命令模式下,选定要复制的那一行的末尾,然后点击键盘yyp,就完成复制,然后修改。

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzIyMTcyMTMz_size_16_color_FFFFFF_t_70 2

第二步:重启防火墙

  1. [root@localhost-0723 redis-3.0.0]# service iptables restart
  2. iptables:清除防火墙规则: [确定]
  3. iptables:将链设置为政策 ACCEPTfilter [确定]
  4. iptables:正在卸载模块: [确定]
  5. iptables:应用防火墙规则: [确定]
  6. [root@localhost-0723 redis-3.0.0]#

如果还是无法访问可能是开启了保护模式,进入redis.conf文件发现 bind 127.0.0.1配置,注释该配置,重启。如果还是连不上,在配置文件中开启密码认证

  1. #requirepass foobared 【foobared为密码】

三、Java客户端Jedis

1、jedis介绍

  1. Redis不仅是使用命令来操作,现在基本上主流的语言都有客户端支持,比如javaCC\#C++、phpNode.jsGo等。在官方网站里列一些Java的客户端,有JedisRedissonJredisJDBC-Redis、等其中官方推荐使用JedisRedisson 在企业中用的最多的就是Jedis Jedis同样也是托管在github上,地址:[https://github.com/xetorthio/jedis][https_github.com_xetorthio_jedis]

2、使用举例

1.单实例连接

测试如下:

  1. @Test
  2. public void testJedis() {
  3. //创建一个Jedis的连接
  4. Jedis jedis = new Jedis("172.25.0.163", 6379);
  5. //执行redis命令
  6. jedis.set("mytest", "hello world, this is jedis client!");
  7. //从redis中取值
  8. String result = jedis.get("mytest");
  9. //打印结果
  10. System.out.println(result);
  11. //关闭连接
  12. jedis.close();
  13. }

2.连接池连接

测试如下:

  1. @Test
  2. public void testJedisPool() {
  3. //创建一连接池对象
  4. JedisPool jedisPool = new JedisPool("172.25.0.163", 6379);
  5. //从连接池中获得连接
  6. Jedis jedis = jedisPool.getResource();
  7. String result = jedis.get("mytest");
  8. System.out.println(result);
  9. //关闭连接
  10. jedis.close();
  11. //关闭连接池
  12. jedisPool.close();
  13. }

3.Spring整合jedisPool

需要配置的spring文件如下:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
  8. http://www.springframework.org/schema/mvc
  9. http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
  10. http://www.springframework.org/schema/context
  11. http://www.springframework.org/schema/context/spring-context-3.2.xsd
  12. http://www.springframework.org/schema/aop
  13. http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
  14. http://www.springframework.org/schema/tx
  15. http://www.springframework.org/schema/tx/spring-tx-3.2.xsd ">
  16. <!-- 连接池配置 -->
  17. <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
  18. <!-- 最大连接数 -->
  19. <property name="maxTotal" value="30" />
  20. <!-- 最大空闲连接数 -->
  21. <property name="maxIdle" value="10" />
  22. <!-- 每次释放连接的最大数目 -->
  23. <property name="numTestsPerEvictionRun" value="1024" />
  24. <!-- 释放连接的扫描间隔(毫秒) -->
  25. <property name="timeBetweenEvictionRunsMillis" value="30000" />
  26. <!-- 连接最小空闲时间 -->
  27. <property name="minEvictableIdleTimeMillis" value="1800000" />
  28. <!-- 连接空闲多久后释放, 当空闲时间>该值 且 空闲连接>最大空闲连接数 时直接释放 -->
  29. <property name="softMinEvictableIdleTimeMillis" value="10000" />
  30. <!-- 获取连接时的最大等待毫秒数,小于零:阻塞不确定的时间,默认-1 -->
  31. <property name="maxWaitMillis" value="1500" />
  32. <!-- 在获取连接的时候检查有效性, 默认false -->
  33. <property name="testOnBorrow" value="false" />
  34. <!-- 在空闲时检查有效性, 默认false -->
  35. <property name="testWhileIdle" value="true" />
  36. <!-- 连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true -->
  37. <property name="blockWhenExhausted" value="false" />
  38. </bean>
  39. <!-- redis单机 通过连接池 -->
  40. <bean id="jedisPool" class="redis.clients.jedis.JedisPool"
  41. destroy-method="close">
  42. <constructor-arg name="poolConfig" ref="jedisPoolConfig" />
  43. <constructor-arg name="host" value="192.168.242.130" />
  44. <constructor-arg name="port" value="6379" />
  45. </bean>
  46. </beans>

然后测试类如下:

  1. @Test
  2. public void testJedisPool() {
  3. JedisPool pool = (JedisPool) applicationContext.getBean("jedisPool");
  4. Jedis jedis = null;
  5. try {
  6. jedis = pool.getResource();
  7. jedis.set("name", "lisi");
  8. String name = jedis.get("name");
  9. System.out.println(name);
  10. } catch (Exception ex) {
  11. ex.printStackTrace();
  12. } finally {
  13. if (jedis != null) {
  14. // 关闭连接
  15. jedis.close();
  16. }
  17. }
  18. }

发表评论

表情:
评论列表 (有 0 条评论,138人围观)

还没有评论,来说两句吧...

相关阅读