redis--客户端
redis客户端
一、redis自带的客户端
Ø 指定主机和端口
[root@localhost-0723 bin]# ./redis-cli -h 127.0.0.1 -p 6379 |
-h:redis服务器的ip地址
-p:redis实例的端口号
Ø 如果不指定主机和端口也可以
[root@localhost-0723 bin]# ./redis-cli |
默认主机地址是127.0.0.1
默认端口是6379
二、图形化界面客户端
前提:需要安装图形界面管理器
远程连接redis服务,需要关闭或者修改防火墙配置。
第一步:编辑iptables
[root@redis01 bin]# vim /etc/sysconfig/iptables |
在命令模式下,选定要复制的那一行的末尾,然后点击键盘yyp,就完成复制,然后修改。
第二步:重启防火墙
[root@localhost-0723 redis-3.0.0]# service iptables restart iptables:清除防火墙规则: [确定] iptables:将链设置为政策 ACCEPT:filter [确定] iptables:正在卸载模块: [确定] iptables:应用防火墙规则: [确定] [root@localhost-0723 redis-3.0.0]# |
注意:
默认一共是16个数据库,每个数据库之间是相互隔离。数据库的数量是在redis.conf中配置的。
选择数据库的方式:
使用select 加上数据库的下标就可以选择指定的数据库来使用,下标从0开始
127.0.0.1:6379> select 15
OK
127.0.0.1:6379[15]>
切换数据库使用命令:select 数据库编号
例如:select 1
三、Java客户端Jedis
1、jedis介绍
Redis不仅是使用命令来操作,现在基本上主流的语言都有客户端支持,比如java、C、C#、C++、php、Node.js、Go等。
在官方网站里列一些Java的客户端,有Jedis、Redisson、Jredis、JDBC-Redis、等其中官方推荐使用Jedis和Redisson。
在企业中用的最多的就是Jedis,下面我们就重点学习下Jedis。
Jedis同样也是托管在github上,地址:https://github.com/xetorthio/jedis
2、添加jar包
3、单实例连接
@Testpublic void testJedis() {//创建一个Jedis的连接Jedis jedis = new Jedis("127.0.0.1", 6379);//执行redis命令jedis.set("mytest", "hello world, this is jedis client!");//从redis中取值String result = jedis.get("mytest");//打印结果System.out.println(result);//关闭连接jedis.close();}
4、连接池连接
@Testpublic void testJedisPool() {//创建一连接池对象JedisPool jedisPool = new JedisPool("127.0.0.1", 6379);//从连接池中获得连接Jedis jedis = jedisPool.getResource();String result = jedis.get("mytest");System.out.println(result);//关闭连接jedis.close();//关闭连接池jedisPool.close();}
5、Spring整合jedisPool
Ø 添加spring的jar包
Ø 配置spring配置文件applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"xmlns:context="http://www.springframework.org/schema/context"xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd "><!-- 连接池配置 --><bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"><!-- 最大连接数 --><property name="maxTotal" value="30" /><!-- 最大空闲连接数 --><property name="maxIdle" value="10" /><!-- 每次释放连接的最大数目 --><property name="numTestsPerEvictionRun" value="1024" /><!-- 释放连接的扫描间隔(毫秒) --><property name="timeBetweenEvictionRunsMillis" value="30000" /><!-- 连接最小空闲时间 --><property name="minEvictableIdleTimeMillis" value="1800000" /><!-- 连接空闲多久后释放, 当空闲时间>该值 且 空闲连接>最大空闲连接数 时直接释放 --><property name="softMinEvictableIdleTimeMillis" value="10000" /><!-- 获取连接时的最大等待毫秒数,小于零:阻塞不确定的时间,默认-1 --><property name="maxWaitMillis" value="1500" /><!-- 在获取连接的时候检查有效性, 默认false --><property name="testOnBorrow" value="false" /><!-- 在空闲时检查有效性, 默认false --><property name="testWhileIdle" value="true" /><!-- 连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true --><property name="blockWhenExhausted" value="false" /></bean><!-- redis单机 通过连接池 --><bean id="jedisPool" class="redis.clients.jedis.JedisPool"destroy-method="close"><constructor-arg name="poolConfig" ref="jedisPoolConfig" /><constructor-arg name="host" value="192.168.242.130" /><constructor-arg name="port" value="6379" /></bean>
</beans>
Ø 测试代码
@Testpublic void testJedisPool() {JedisPool pool = (JedisPool) applicationContext.getBean("jedisPool");Jedis jedis = null;try {jedis = pool.getResource();jedis.set("name", "lisi");String name = jedis.get("name");System.out.println(name);} catch (Exception ex) {ex.printStackTrace();} finally {if (jedis != null) {// 关闭连接jedis.close();}}}
redis--客户端相关推荐
- 功能强大的 C++ redis 客户端库增加至 acl 项目中
虽然 redis 开发库已有不少,但 C/C++ 的客户端库好用的并不多,虽然官方也提供了 C 版的客户端库,但易用性较差,而且不支持连接池功能,相对于 C/C++ 的库,JAVA 版的 jedis ...
- [ 搭建Redis本地服务器实践系列三 ] :图解Redis客户端工具连接Redis服务器
原文:[ 搭建Redis本地服务器实践系列三 ] :图解Redis客户端工具连接Redis服务器 上一章 [ 搭建Redis本地服务器实践系列二 ] :图解CentOS7配置Redis 介绍了Red ...
- Redis实现分布式锁全局锁—Redis客户端Redisson中分布式锁RLock实现
2019独角兽企业重金招聘Python工程师标准>>> 1. 前因 以前实现过一个Redis实现的全局锁, 虽然能用, 但是感觉很不完善, 不可重入, 参数太多等等. 最近看到了一个 ...
- redis 用中文做key_推荐一款Redis客户端工具
日常开发过程中,项目常常都会使用Redis来做缓存或者Session服务器,为了更直观方便,开发者常常会使用一些可视化工具,如 Redis Desktop Manager.Redis Clent等,但 ...
- Java开发-Redis客户端Jedis
1.部署Redis后启动服务端: 2.Jedis网址:https://github.com/xetorthio/jedis/tree/2.6 应用maven管理jar包依赖:新建maven项目(ecl ...
- 推荐一款好用的redis客户端工具
为什么80%的码农都做不了架构师?>>> 推荐一款好用的redis客户端工具 redis官方客户端(redis-cli)每次都要指定连接IP与端口,连接成功后还要执行auth命令进行 ...
- 几款开源的图形化Redis客户端管理软件推荐
几款开源的图形化Redis客户端管理软件推荐 摘要: Redis是一个超精简的基于内存的键值对数据库(key-value),一般对并发有一定要求的应用都用其储存session,乃至整个数据库.不过它公 ...
- 阿里云专访Redisson作者Rui Gu:构建开源企业级Redis客户端之路
摘要: 本文为阿里云同学在RedisConf2018上对Redisson开源客户端作者Rui Gu做的一个专访,主要介绍了Rui Gu参与开启Redisson客户端开发的历程,同时也详细介绍了Redi ...
- DotNetCore三大Redis客户端对比和使用心得
前言 稍微复杂一点的互联网项目,技术选型都会涉及Redis,.NetCore的生态越发完善,支持.NetCore的Redis客户端越来越多, 下面三款常见的Redis客户端,相信大家平时或多或少用到一 ...
- 错误使用.Net Redis客户端CSRedisCore,自己挖坑自己填
本文2019年中原创首发于博客园,当时使用CSRedisCore的排障思路引起很大反响,当时被张队公众号翻牌,本次转回公号. 背景 上次Redis MQ分布式改造之后,编排的容器稳定运行一个多月,昨天 ...
最新文章
- Nginx禁止特定用户代理(User Agents)访问(转)
- java中try-catch另外一种用法:try(){}语法使用
- vue实现查询多条记录_vue.js 实现天气查询
- extjs combobox分页加载数据不显示
- javascript的compile()函数使用
- [cocos2dx]斗地主随机发牌界面生成
- java集成 腾讯信鸽_移动推送 腾讯信鸽集成
- nc交换平台翻译器翻译仓库问题以及解决方法
- 如何更改微信标签名字_微信如何设置备注及标签 来学习吧
- 一元四次方程c语言程序编写,一元高次方程数值解法C程序实现探讨..doc
- Flipped 阅读笔记
- 拦截一切的CoordinatorLayout Behavior
- 玛丽·娜拉(Marie Neurath)遗失的遗产
- R 语言的表格合并(实际运用)
- 手游人类一败涂地联机一直连接服务器,人类一败涂地手游怎么联机
- 导出公众号历史文章,批量下载微信公众号数据分析
- 阅读源码-理解torch.utils.data、torch.utils.data.Dataset、torch.utils.data.DataLoader的工作方式
- SpaceX龙飞船成本
- 数据结构--三角矩阵的压缩存储
- Elasticsearch实战 | match_phrase搜不出来,怎么办?