fix(Redis监控): fix review
parent
a8ebc56472
commit
c0b1f62afd
|
@ -4,19 +4,25 @@ import cn.iocoder.yudao.framework.common.pojo.CommonResult;
|
||||||
import cn.iocoder.yudao.framework.redis.core.RedisKeyDefine;
|
import cn.iocoder.yudao.framework.redis.core.RedisKeyDefine;
|
||||||
import cn.iocoder.yudao.framework.redis.core.RedisKeyRegistry;
|
import cn.iocoder.yudao.framework.redis.core.RedisKeyRegistry;
|
||||||
import cn.iocoder.yudao.module.infra.controller.admin.redis.vo.RedisKeyRespVO;
|
import cn.iocoder.yudao.module.infra.controller.admin.redis.vo.RedisKeyRespVO;
|
||||||
|
import cn.iocoder.yudao.module.infra.controller.admin.redis.vo.RedisKeyValueRespVO;
|
||||||
import cn.iocoder.yudao.module.infra.controller.admin.redis.vo.RedisMonitorRespVO;
|
import cn.iocoder.yudao.module.infra.controller.admin.redis.vo.RedisMonitorRespVO;
|
||||||
import cn.iocoder.yudao.module.infra.controller.admin.redis.vo.RedisValuesRespVO;
|
|
||||||
import cn.iocoder.yudao.module.infra.convert.redis.RedisConvert;
|
import cn.iocoder.yudao.module.infra.convert.redis.RedisConvert;
|
||||||
import io.swagger.annotations.Api;
|
import io.swagger.annotations.Api;
|
||||||
import io.swagger.annotations.ApiOperation;
|
import io.swagger.annotations.ApiOperation;
|
||||||
import org.springframework.data.redis.connection.RedisServerCommands;
|
import org.springframework.data.redis.connection.RedisServerCommands;
|
||||||
|
import org.springframework.data.redis.core.Cursor;
|
||||||
import org.springframework.data.redis.core.RedisCallback;
|
import org.springframework.data.redis.core.RedisCallback;
|
||||||
|
import org.springframework.data.redis.core.ScanOptions;
|
||||||
import org.springframework.data.redis.core.StringRedisTemplate;
|
import org.springframework.data.redis.core.StringRedisTemplate;
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
import org.springframework.web.bind.annotation.*;
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import java.util.*;
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Properties;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
|
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
|
||||||
|
|
||||||
|
@ -50,45 +56,61 @@ public class RedisController {
|
||||||
return success(RedisConvert.INSTANCE.convertList(keyDefines));
|
return success(RedisConvert.INSTANCE.convertList(keyDefines));
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/get-key/{keyDefine}")
|
@GetMapping("/get-key-Defines")
|
||||||
@ApiOperation("获得 Redis keys 键名列表")
|
@ApiOperation("获得 Redis keys 键名列表")
|
||||||
@PreAuthorize("@ss.hasPermission('infra:redis:get-key-list')")
|
@PreAuthorize("@ss.hasPermission('infra:redis:get-key-list')")
|
||||||
public CommonResult<Set<String>> getKeyDefineKeys(@PathVariable("keyDefine") String keyDefine) {
|
public CommonResult<Set<String>> getKeyDefines(@RequestParam("keyDefine") String keyDefine) {
|
||||||
Set<String> Keys = stringRedisTemplate.keys(keyDefine + "*");
|
Set<String> keys = new HashSet<>();
|
||||||
return success(Keys);
|
stringRedisTemplate.execute((RedisCallback<Set<String>>) connection -> {
|
||||||
|
try (Cursor<byte[]> cursor = connection.scan(ScanOptions.scanOptions()
|
||||||
|
.match(keyDefine + "*")
|
||||||
|
.count(Integer.MAX_VALUE).build())) {
|
||||||
|
while (cursor.hasNext()) {
|
||||||
|
keys.add(new String(cursor.next(), StandardCharsets.UTF_8));
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
return keys;
|
||||||
|
});
|
||||||
|
return success(keys);
|
||||||
}
|
}
|
||||||
|
|
||||||
@DeleteMapping("/clear-key-define/{keyDefine}")
|
@DeleteMapping("/delete-key-defines")
|
||||||
@ApiOperation("删除 Redis Key 根据模板")
|
@ApiOperation("删除 Redis Key 根据模板")
|
||||||
@PreAuthorize("@ss.hasPermission('infra:redis:get-key-list')")
|
@PreAuthorize("@ss.hasPermission('infra:redis:get-key-list')")
|
||||||
public CommonResult<Boolean> clearKeyDefineKeys(@PathVariable("keyDefine") String keyDefine) {
|
public CommonResult<Boolean> deleteKeyDefines(@RequestParam("keyDefine") String keyDefine) {
|
||||||
stringRedisTemplate.delete(Objects.requireNonNull(stringRedisTemplate.keys(keyDefine + "*")));
|
Set<String> keys = stringRedisTemplate.keys(keyDefine + "*");
|
||||||
|
if(keys != null && keys.isEmpty()){
|
||||||
|
stringRedisTemplate.delete(keys);
|
||||||
|
}
|
||||||
return success(Boolean.TRUE);
|
return success(Boolean.TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/get-key/{keyDefine}/{cacheKey}")
|
@GetMapping("/get-key-value")
|
||||||
@ApiOperation("获得 Redis key 内容")
|
@ApiOperation("获得 Redis key 内容")
|
||||||
@PreAuthorize("@ss.hasPermission('infra:redis:get-key-list')")
|
@PreAuthorize("@ss.hasPermission('infra:redis:get-key-list')")
|
||||||
public CommonResult<RedisValuesRespVO> getKeyValue(@PathVariable("keyDefine") String keyDefine, @PathVariable("cacheKey") String cacheKey) {
|
public CommonResult<RedisKeyValueRespVO> getKeyValue(@RequestParam("keyDefine") String keyDefine, @RequestParam("cacheKey") String cacheKey) {
|
||||||
String cacheValue = stringRedisTemplate.opsForValue().get(cacheKey);
|
String cacheValue = stringRedisTemplate.opsForValue().get(cacheKey);
|
||||||
return success(new RedisValuesRespVO(keyDefine, cacheKey, cacheValue));
|
return success(RedisKeyValueRespVO.of(keyDefine, cacheKey, cacheValue));
|
||||||
}
|
}
|
||||||
|
|
||||||
@DeleteMapping("/clear-key/{cacheKey}")
|
@DeleteMapping("/delete-key-value")
|
||||||
@ApiOperation("删除 Redis Key 根据key")
|
@ApiOperation("删除 Redis Key 根据key")
|
||||||
@PreAuthorize("@ss.hasPermission('infra:redis:get-key-list')")
|
@PreAuthorize("@ss.hasPermission('infra:redis:get-key-list')")
|
||||||
public CommonResult<Boolean> clearCacheKey(@PathVariable String cacheKey) {
|
public CommonResult<Boolean> deleteKeyValue(@RequestParam("cacheKey") String cacheKey) {
|
||||||
stringRedisTemplate.delete(cacheKey);
|
stringRedisTemplate.delete(cacheKey);
|
||||||
return success(Boolean.TRUE);
|
return success(Boolean.TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@DeleteMapping("/clear-cache-all")
|
@DeleteMapping("/delete-cache-all")
|
||||||
@ApiOperation(value="删除 所有缓存", notes="不使用该接口")
|
@ApiOperation(value="删除 所有缓存", notes="不使用该接口")
|
||||||
@PreAuthorize("@ss.hasPermission('infra:redis:get-key-list')")
|
@PreAuthorize("@ss.hasPermission('infra:redis:get-key-list')")
|
||||||
public CommonResult<Boolean> clearCacheAll() {
|
public CommonResult<Boolean> deleteCacheAll() {
|
||||||
Collection<String> cacheKeys = stringRedisTemplate.keys("*");
|
return success(stringRedisTemplate.execute((RedisCallback<Boolean>) connection -> {
|
||||||
stringRedisTemplate.delete(cacheKeys);
|
connection.flushAll();
|
||||||
return success(Boolean.TRUE);
|
return Boolean.TRUE;
|
||||||
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package cn.iocoder.yudao.module.infra.controller.admin.redis.vo;
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModel;
|
import io.swagger.annotations.ApiModel;
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Builder;
|
import lombok.Builder;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
@ -9,7 +10,8 @@ import org.apache.commons.lang3.StringUtils;
|
||||||
@ApiModel("管理后台 - Redis Key Value onse VO")
|
@ApiModel("管理后台 - Redis Key Value onse VO")
|
||||||
@Data
|
@Data
|
||||||
@Builder
|
@Builder
|
||||||
public class RedisValuesRespVO {
|
@AllArgsConstructor
|
||||||
|
public class RedisKeyValueRespVO {
|
||||||
|
|
||||||
@ApiModelProperty(value = "oauth2_access_token:%s", required = true, example = "String")
|
@ApiModelProperty(value = "oauth2_access_token:%s", required = true, example = "String")
|
||||||
private String keyTemplate;
|
private String keyTemplate;
|
||||||
|
@ -20,10 +22,12 @@ public class RedisValuesRespVO {
|
||||||
@ApiModelProperty(required = true, example = "String")
|
@ApiModelProperty(required = true, example = "String")
|
||||||
private String value;
|
private String value;
|
||||||
|
|
||||||
public RedisValuesRespVO(String keyTemplate, String key, String value){
|
public static RedisKeyValueRespVO of(String keyTemplate, String key, String value){
|
||||||
this.keyTemplate = StringUtils.replace(keyTemplate, ":", "");
|
return RedisKeyValueRespVO.builder()
|
||||||
this.key = StringUtils.replace(key, keyTemplate, "");
|
.keyTemplate(StringUtils.replace(keyTemplate, ":", ""))
|
||||||
this.value = value;
|
.key(StringUtils.replace(key, keyTemplate, ""))
|
||||||
|
.value(value)
|
||||||
|
.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,9 +17,9 @@ export function getKeyList() {
|
||||||
}
|
}
|
||||||
|
|
||||||
// 获取键名列表
|
// 获取键名列表
|
||||||
export function getKeyDefineKeys(keyDefine) {
|
export function getKeyDefines(keyDefine) {
|
||||||
return request({
|
return request({
|
||||||
url: '/infra/redis/get-key/' + keyDefine,
|
url: '/infra/redis/get-key-Defines?keyDefine=' + keyDefine,
|
||||||
method: 'get'
|
method: 'get'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -27,15 +27,15 @@ export function getKeyDefineKeys(keyDefine) {
|
||||||
// 获取缓存内容
|
// 获取缓存内容
|
||||||
export function getKeyValue(keyDefine, key) {
|
export function getKeyValue(keyDefine, key) {
|
||||||
return request({
|
return request({
|
||||||
url: '/infra/redis/get-key/' + keyDefine + "/" + key,
|
url: '/infra/redis/get-key-value?keyDefine=' + keyDefine + "&cacheKey=" + key,
|
||||||
method: 'get'
|
method: 'get'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// 根据键名删除缓存
|
// 根据键名删除缓存
|
||||||
export function clearCacheKey(key) {
|
export function deleteKeyValue(key) {
|
||||||
return request({
|
return request({
|
||||||
url: '/infra/redis/clear-key/' + key,
|
url: '/infra/redis/delete-key-value?cacheKey=' + key,
|
||||||
method: 'delete'
|
method: 'delete'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -188,7 +188,7 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { getCache, getKeyList, getKeyDefineKeys, getKeyValue, clearCacheKey } from "@/api/infra/redis";
|
import { getCache, getKeyList, getKeyDefines, getKeyValue, deleteKeyValue } from "@/api/infra/redis";
|
||||||
import echarts from "echarts";
|
import echarts from "echarts";
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
|
@ -303,7 +303,7 @@ export default {
|
||||||
// 获取键名列表
|
// 获取键名列表
|
||||||
handleCacheKeys (keyDefine){
|
handleCacheKeys (keyDefine){
|
||||||
const cacheName = keyDefine !== undefined ? keyDefine : this.keyTemplate;
|
const cacheName = keyDefine !== undefined ? keyDefine : this.keyTemplate;
|
||||||
getKeyDefineKeys(cacheName).then(response => {
|
getKeyDefines(cacheName).then(response => {
|
||||||
this.cachekeys = response.data
|
this.cachekeys = response.data
|
||||||
this.cacheForm = {}
|
this.cacheForm = {}
|
||||||
})
|
})
|
||||||
|
@ -324,7 +324,7 @@ export default {
|
||||||
|
|
||||||
// 删除缓存
|
// 删除缓存
|
||||||
handleClearCacheKey(key){
|
handleClearCacheKey(key){
|
||||||
clearCacheKey(key).then(response =>{
|
deleteKeyValue(key).then(response =>{
|
||||||
this.$modal.msgSuccess("清理缓存键名[" + key + "]成功");
|
this.$modal.msgSuccess("清理缓存键名[" + key + "]成功");
|
||||||
this.handleCacheKeys();
|
this.handleCacheKeys();
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in New Issue