Jedis和linux环境安装redis
- Jedis
- Jedis简介
- 编程语言与redis
- HelloWorld(Jedis版)
- 准备工作
- 客户端连接redis
- Jedis读写redis数据
- 案例:服务调用次数控制
- Jedis简易工具类开发
- 基于连接池获取连接
- 封装连接参数
- 加载配置信息
- 获取连接
- 可视化客户端
- Redis 安装(Linux)
- 基于Center OS7安装Redis
- Redis基础环境设置
- Redis服务启动
- Redis客户端连接
- Redis服务端配置
Jedis
Jedis简介
编程语言与redis
- Java语言连接redis服务
- Jedis
- SpringData Redis
- Lettuce
- C 、C++ 、C# 、Erlang、Lua 、Objective-C 、Perl 、PHP 、Python 、Ruby 、Scala
- 可视化连接redis客户端
- Redis Desktop Manager
- Redis Client
- Redis Studio
HelloWorld(Jedis版)
准备工作
jar包导入
- 下载地址:https://mvnrepository.com/artifact/redis.clients/jedis
基于maven
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>
客户端连接redis
// 1.连接 redis
Jedis jedis = new Jedis("127.0.0.1", 6379);
// 2.操作 redis
//jedis.set("name","zyj");
String name = jedis.get("name");
System.out.println(name);
// 3.关闭连接
jedis.close();
- API文档
Jedis读写redis数据
案例:服务调用次数控制
人工智能领域的语义识别与自动对话将是未来服务业机器人应答呼叫体系中的重要技术,百度自研用户评价语义识别服务,免费开放给企业试用,同时训练百度自己的模型。现对试用用户的使用行为进行限速,限制每个用户每分钟最多发起10次调用
案例要求
- ① 设定A、B、C三个用户
- ② A用户限制10次/分调用,B用户限制30次/分调用,C用户不限制
案例:需求分析
① 设定一个服务方法,用于模拟实际业务调用的服务,内部采用打印模拟调用
② 在业务调用前服务调用控制单元,内部使用redis进行控制,参照之前的方案
③ 对调用超限使用异常进行控制,异常处理设定为打印提示信息
④ 主程序启动3个线程,分别表示3种不同用户的调用
案例:实现步骤
- 设定业务方法
public void business(String id, long leftTimes) {
System.out.printf("%s业务操作执行,剩余次数:%d\n", id, Long.MAX_VALUE - leftTimes);
}
- 设定多线类,模拟用户调用
public void run() {
while (true) {
sc.service(Thread.currentThread().getName());
try {
Random r = new Random();
Thread.sleep(1000+ r.nextInt(1000));
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
- 设计redis控制方案
public void service(String id) {
Jedis jedis = new Jedis("localhost", 6379);
String uid = "compid:" + id;
String value = jedis.get(uid);
// 判断该值是否存在
try {
if (value == null) {
//不存在创建该值
jedis.setex(uid, 20, String.valueOf(Long.MAX_VALUE - 10));
} else {
//存在,自增调用业务
Long leftTimes = jedis.incr(uid);
business(uid, leftTimes);
}
} catch (JedisDataException e) {
System.out.println("使用已经到达次数上限请升级会员");
return;
} finally {
jedis.close();
}
}
- 设计启动主程序
public static void main(String[] args) {
MyThread a = new MyThread("a");
a.start();
}
后续1:对业务控制方案进行改造,设定不同用户等级的判定
后续2:将不同用户等级对应的信息、限制次数等设定到redis中,使用hash保存
Jedis简易工具类开发
基于连接池获取连接
JedisPool:Jedis提供的连接池技术
- poolConfig:连接池配置对象
- host:redis服务地址
- port:redis服务端口号
public JedisPool(GenericObjectPoolConfig poolConfig, String host, int port) {
this(poolConfig, host, port, 2000, (String)null, 0, (String)null);
}
封装连接参数
jedis.properties
jedis.host=localhost
jedis.port=6379
jedis.maxTotal=30//最大连接数
jedis.maxIdle=10//活动连接数
加载配置信息
静态代码块初始化资源
static{
// 读取配置文件 获得参数值
ResourceBundle rb = ResourceBundle.getBundle("jedis");
host = rb.getString("jedis.host");
port = Integer.parseInt(rb.getString("jedis.port"));
maxTotal = Integer.parseInt(rb.getString("jedis.maxTotal"));
maxIdle = Integer.parseInt(rb.getString("jedis.maxIdle"));
poolConfig = new JedisPoolConfig();
poolConfig.setMaxTotal(maxTotal);
poolConfig.setMaxIdle(maxIdle);
jedisPool = new JedisPool(poolConfig,host,port);
}
获取连接
对外访问接口,提供jedis连接对象,连接从连接池获取
public static Jedis getJedis(){
Jedis jedis = jedisPool.getResource();
return jedis;
}
可视化客户端
Redis Desktop Manager… …
Redis 安装(Linux)
基于Center OS7安装Redis
下载安装包
- wget http://download.redis.io/releases/redis-?.?.?.tar.gz
解压 - tar –xvf 文件名.tar.gz
编译 - make
安装 - make install [destdir=/目录]
Redis基础环境设置
创建软链接
- ln -s 原始目录名 快速访问目录名
创建配置文件管理目录 - mkdir conf
- mkdir config
创建数据文件管理目录 - mkdir data
Redis服务启动
默认配置启动
- redis-server
- redis-server --port 6379
- redis-server --port 6380 ……
指定配置文件启动 - redis-server redis.conf
- redis-server redis-6379.conf
- redis-server redis-6380.conf ……
- redis-server conf/redis-6379.conf
- redis-server config/redis-6380.conf ……
Redis客户端连接
默认连接
- redis-cli
连接指定服务器 - redis-cli -h 127.0.0.1
- redis-cli –port 6379
- redis-cli -h 127.0.0.1 –port 6379
Redis服务端配置
基本配置
daemonize yes
以守护进程方式启动,使用本启动方式,redis将以服务的形式存在,日志将不再打印到命令窗口中
port 6***
设定当前服务启动端口号
dir “/自定义目录/redis/data“
设定当前服务文件保存位置,包含日志文件、持久化文件(后面详细讲解)等 cat
logfile "6.log"
设定日志文件名,便于查阅