SpringBoot-swagger、Redis

1、SpringBoot、Swagger

是Java Web的开发框架,Swagger是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。总体目标是使客户端和文件系统作为服务器以同样的速度来更新。文件的方法,参数和模型紧密集成到服务器端的代码,允许API来始终保持同步。

在项目开发中,根据业务代码自动生成API文档,给前端提供在线测试,自动显示JSON格式,方便了后端与前端的沟通与调试成本。

Swagger有一个缺点就是侵入性模式,必须配置在具体的代码里。

2、使用swagger集成

(1)添加相关依赖

添加Maven相关依赖, web和Swagger
Web:

<dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
</dependency>

Swagger:

<!-- swagger -->
<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-swagger2</artifactId>
    <version>2.9.2</version>
</dependency>
<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-swagger-ui</artifactId>
    <version>2.9.2</version>
</dependency>
(2)添加配置类

添加一个swagger 配置类,在工程下新建 config 包并添加一个 SwaggerConfig 配置类。

SwaggerConfig.java

package com.my.configuration;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

@Configuration
@EnableSwagger2
public class SwaggerConfig {
    @Bean
    public Docket createRestApi(){
        return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo())
                .select()
                .apis(RequestHandlerSelectors.any())
                .paths(PathSelectors.any()).build();
    }

    private ApiInfo apiInfo(){
        return new ApiInfoBuilder()
                .title("Kitty API Doc")
                .description("This is a restful api document of Kitty.")
                .version("1.0")
                .build();
    }
}
(3)添加控制器

添加一个控制器,在工程下新建 controller包并添加一个 HelloController控制器。
HelloController.java

package com.my.control;

import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

/*类注解*/
@Api(value = "desc of class")
@RestController
public class HelloController {
    /*方法注解*/
    @ApiOperation(value = "desc of method",notes =  "")
    @GetMapping(value = "/hello")
    public Object hello(/*参数注解*/@ApiParam(value = "desc of param",required = true) @RequestParam String name){
        return "Hello "+name+"!";
    }


}
(4)测试

打开浏览器,访问:http://localhost:8080/swagger-ui.html,进入swagger接口文档界面

展开hello-controller的hello接口,输入参数并点击执行,就可以看到接口测试结果了。
在这里插入图片描述

Redis

是 key-value存储系统,支持存储的value类型包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。

1、数据类型

(1)String (字符串)
一个key对应一个value,最大存储512MB。

redis 127.0.0.1:6379> SET runoob "String 字符串"
redis 127.0.0.1:6379> GET runoob

以上是redis的SET、GET命令,键为runoob,对应的值是 String 字符串。

(2)Hash(哈希)
一个键值(key=>value)对集合

redis 127.0.0.1:6379> HMSET runoob field1 "Hello" field2 "World"
->"OK"
redis 127.0.0.1:6379> HGET runoob field1
->"Hello"
redis 127.0.0.1:6379> HGET runoob field2
->"World"

使用了Redis HMSET,HGET命令,HMSET设置了两个field=>value对,HGET获取对应的field对应的value。

可用场景:存储、读取、修改用户属性。

(3)List(列表)
简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列的头部(左边)或者尾部(右边)。

redis 127.0.0.1:6379> lpush runoob redis
(integer) 1
redis 127.0.0.1:6379> lpush runoob mongodb
(integer) 2
redis 127.0.0.1:6379> lpush runoob rabitmq
(integer) 3
redis 127.0.0.1:6379> lrange runoob 0 10
1) "rabitmq"
2) "mongodb"
3) "redis"

可用场景:最新消息排行等功能,消息队列

(4)Set(集合)
Set是String类型的无序集合。集合是通过哈希表实现的,所以添加、删除、查找的复杂度都是O(1).

sadd命令
添加一个String元素到key对应的set集合中,成功返回1,如果元素已经在集合中返回0。

sadd key member



redis 127.0.0.1:6379> sadd runoob redis
(integer) 1
redis 127.0.0.1:6379> sadd runoob mongodb
(integer) 1
redis 127.0.0.1:6379> sadd runoob rabitmq
(integer) 1
redis 127.0.0.1:6379> sadd runoob rabitmq
(integer) 0
redis 127.0.0.1:6379> smembers runoob

1) "redis"
2) "rabitmq"
3) "mongodb"

以上实例中 rabitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略

可用场景:共同好友、利用唯一性,统计访问网站的所有独立ip、好友推荐时,根据tag求交集,大于某个阈值就可以推荐。
(5)zset(sorted set:有序集合)

zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。

zadd命令
添加元素到集合,元素在集合中存在则更新对应score

zadd key score member


redis 127.0.0.1:6379> zadd runoob 0 redis
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 mongodb
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 rabitmq
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 rabitmq
(integer) 0
redis 127.0.0.1:6379> > ZRANGEBYSCORE runoob 0 1000
1) "mongodb"
2) "rabitmq"
3) "redis"

可用场景:排行榜、带权重的消息队列

2、命令

(1)启动语法
启动 redis客户端:打开服务器,输入命令redis-cil,该命令会连接本地的redis服务。

$ redis-cli
redis 127.0.0.1:6379>
redis 127.0.0.1:6379> PING

PONG

在以上实例中我们连接到本地的 redis 服务并执行 PING 命令,该命令用于检测 redis 服务是否启动。

cmd 切换目录 => d: 打开文件=>cd/redis
在这里插入图片描述
该图展示了切换目录并启动redis客户端,设置一个值myKey,并取出 得到“abc”
输入PING 返回PONG 表示已连接到服务器

(2)键
设置一个键为srunoobkey,并删除。
如果键被删除成功,命令执行后输出 (integer) 1,否则将输出 (integer) 0

在这里插入图片描述

序号命令及描述
1DEL key
2DUMP 序列化给定key,并返回被序列化的值
3EXISTS key 检查给定 key 是否存在。
4EXPIRE key seconds 为给定 key 设置过期时间,以秒计。
5EXPIREAT key timestamp EXPIREAT 的作用和 EXPIRE 类似,都用于为 key 设置过期时间。 不同在于 EXPIREAT 命令接受的时间参数是 UNIX 时间戳(unix timestamp)。
6PEXPIRE key milliseconds 设置 key 的过期时间以毫秒计。
7PEXPIREAT key milliseconds-timestamp 设置 key 过期时间的时间戳(unix timestamp) 以毫秒计
8KEYS pattern 查找所有符合给定模式( pattern)的 key 。
9MOVE key db 将当前数据库的 key 移动到给定的数据库 db 当中。
10PERSIST key 移除 key 的过期时间,key 将持久保持。
11PTTL key以毫秒为单位返回 key 的剩余的过期时间。
12TTL key 以秒为单位,返回给定 key 的剩余生存时间(TTL, time to live)。
13RANDOMKEY 从当前数据库中随机返回一个 key 。
14RENAME key newkey 修改 key 的名称
15RENAMENX key newkey 仅当 newkey 不存在时,将 key 改名为 newkey 。
16SCAN cursor [MATCH pattern] [COUNT count] 迭代数据库中的数据库键。
17TYPE key 返回 key 所储存的值的类型。

在这里插入图片描述
设置String 类型的键值keyTest 值为“123”
序列化 keyTest
keyTest 是否存在,存在 返回1
设置keyTest的过期时间为60秒
再次查看keyTest 是否存在, 不存在 返回0
设置String 类型的键值keyTest1 值为“14687”
查看类型 为String

(2)字符串 string

序号命令及描述
1SET key value 设置指定 key 的值
2GET key 获取指定 key 的值。
3GETRANGE key start end
4GETSET key value 将给定 key 的值设为 value ,并返回 key 的旧值(old value)。
5GETBIT key offset 对 key 所储存的字符串值,获取指定偏移量上的位(bit)。
6MGET key1 [key2…] 获取所有(一个或多个)给定 key 的值。
7SETBIT key offset value 对 key 所储存的字符串值,设置或清除指定偏移量上的位(bit)。
8SETEX key seconds value 将值 value 关联到 key ,并将 key 的过期时间设为 seconds (以秒为单位)。
9SETNX key value 只有在 key 不存在时设置 key 的值。
10SETRANGE key offset value 用 value 参数覆写给定 key 所储存的字符串值,从偏移量 offset 开始。
11STRLEN key 返回 key 所储存的字符串值的长度。
12MSET key value [key value …] 同时设置一个或多个 key-value 对。
13MSETNX key value [key value …] 同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在。
14PSETEX key milliseconds value 这个命令和 SETEX 命令相似,但它以毫秒为单位设置 key 的生存时间,而不是像 SETEX 命令那样,以秒为单位。
15INCR key 将 key 中储存的数字值增一。
16INCRBY key increment 将 key 所储存的值加上给定的增量值(increment) 。
17INCRBYFLOAT key increment 将 key 所储存的值加上给定的浮点增量值(increment) 。
18DECR key 将 key 中储存的数字值减一。
19DECRBY key decrement key 所储存的值减去给定的减量值(decrement) 。
20APPEND key value 如果 key 已经存在并且是一个字符串, APPEND 命令将指定的 value 追加到该 key 原来值(value)的末尾。

在这里插入图片描述
设置String类型的keyString 值为“zhouqiyun”
得到keyString的值,返回“zhouqiyun”
获得从1到4的字符串
对 key 所储存的字符串值,获取指定偏移量上的位(bit)
获取所有(一个或多个)给定 key 的值。

(3)哈希(hash)

序号命令及描述
1HDEL key field1 [field2] 删除一个或多个哈希表字段
2HEXISTS key field 查看哈希表 key 中,指定的字段是否存在。
3HGET key field 获 取存储在哈希表中指定字段的值。
4HGETALL key 获取在哈希表中指定 key 的所有字段和值
5HINCRBY key field increment 为哈希表 key 中的指定字段的整数值加上增量 increment 。
6HINCRBYFLOAT key field increment 为哈希表 key 中的指定字段的浮点数值加上增量 increment 。
7HKEYS key 获取所有哈希表中的字段
8HLEN key 获取哈希表中字段的数量
9HMGET key field1 [field2] 获取所有给定字段的值
10HMSET key field1 value1 [field2 value2 ] 同时将多个 field-value (域-值)对设置到哈希表 key 中。
11HSET key field value 将哈希表 key 中的字段 field 的值设为 value 。
12HSETNX key field value 只有在字段 field 不存在时,设置哈希表字段的值。
13HVALS key 获取哈希表中所有值。
14HSCAN key cursor [MATCH pattern] [COUNT count] 迭代哈希表中的键值对。

在这里插入图片描述
设置了 redis 的一些描述信息(name, description) 到哈希表的 keyhash中。
获取在哈希表中keyhash的所有字段和值
查看哈希表keyhash中,name字段是否存在,存在,返回1
获取在哈希表中keyhash的name字段的值

(4)列表(List)
在这里插入图片描述
使用了 LPUSH 将三个值插入了名为 keyList 的列表当中,并取出。

序号命令及描述
1BLPOP key1 [key2 ] timeout 移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
2BRPOP key1 [key2 ] timeout 移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
3BRPOPLPUSH source destination timeout 从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
4LINDEX key index 通过索引获取列表中的元素
5LINSERT key BEFORE
6LLEN key 获取列表长度
7LPOP key 移出并获取列表的第一个元素
8LPUSH key value1 [value2] 将一个或多个值插入到列表头部
9LPUSHX key value
10LRANGE key start stop 获取列表指定范围内的元素
11LREM key count value 移除列表元素
12LSET key index value 通过索引设置列表元素的值
13LTRIM key start stop 对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。
14RPOP key 移除列表的最后一个元素,返回值为移除的元素。
15RPOPLPUSH source destination 移除列表的最后一个元素,并将该元素添加到另一个列表并返回
16RPUSH key value1 [value2] 在列表中添加一个或多个值
17RPUSHX key value 为已存在的列表添加值

(5)集合(set)
Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

配置教程

网址:https://www.jianshu.com/p/5596c3a4978d

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot项目中,有三种方式可以集成Redis集群,包括使用Jedis、Lettuce和RedisTemplate。 对于Jedis的整合步骤,你需要先导入相应的依赖,包括spring-boot-starter-data-redis和lettuce-core。然后,你可以通过配置类来修改Swagger配置,以便适应你的项目需求。具体的代码实现可以参考上面给出的示例。 对于Lettuce的整合步骤,你同样需要导入相应的依赖,包括spring-boot-starter-data-redis和lettuce-core。然后,你可以在配置类中根据需要修改Swagger配置。具体的代码实现可以参考上面给出的示例。 对于RedisTemplate的整合步骤,你同样需要导入相应的依赖,包括spring-boot-starter-data-redis和lettuce-core。然后,你可以在配置类中根据需要修改Swagger配置。具体的代码实现可以参考上面给出的示例。 总结来说,不论是使用Jedis、Lettuce还是RedisTemplate,你都需要导入相应的依赖并进行相应的配置,以便在Spring Boot项目中实现Redis集群的整合。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [springboot整合redis集群](https://blog.csdn.net/m0_68574821/article/details/129899360)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [SpringBoot整合Redis](https://blog.csdn.net/l_zl2021/article/details/129368515)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值