在windows下安裝的redis,在安裝目錄找到redis.windows.conf
文件,修改如下字段(按實際狀況設置):javascript
slowlog-log-slower-than 100
slowlog-max-len 1000000複製代碼
slowlog-log-slower-than:是配置須要日誌記錄的命令執行時間,單位是微秒,也就是說配置爲100,會記錄命令執行時間爲0.1ms以上的記錄。若是設置爲0,就會記錄全部執行過的命令。java
slowlog-max-len:是配置日誌記錄的條數,由於這個日誌也是存儲在內存中的,因此不須要擔憂記錄日誌會影響性能,可是會消耗必定內存。git
完成對這些信息的獲取主要仍是利用redis的一些命令,若是是win系統下安裝的redis,在安裝目錄運行redis-cli.exe
這個文件,輸入info
,再回車,就能夠看到輸出不少字段的參數,部分具體參數對應的意思以下:redis
上面是命令窗的方式,使用java的話,咱們就是藉助jedis這個框架來幫咱們完成:spring
@Component
public class RedisUtil {
@Autowired
JedisPool jedisPool;
// 獲取redis 服務器信息
public String getRedisInfo() {
Jedis jedis = null;
try {
jedis = jedisPool.getResource();
Client client = jedis.getClient();
client.info();
String info = client.getBulkReply();
return info;
} finally {
// 返還到鏈接池
jedis.close();
}
}
// 獲取日誌列表
public List<Slowlog> getLogs(long entries) {
Jedis jedis = null;
try {
jedis = jedisPool.getResource();
List<Slowlog> logList = jedis.slowlogGet(entries);
return logList;
} finally {
// 返還到鏈接池
jedis.close();
}
}
// 獲取日誌條數
public Long getLogsLen() {
Jedis jedis = null;
try {
jedis = jedisPool.getResource();
long logLen = jedis.slowlogLen();
return logLen;
} finally {
// 返還到鏈接池
jedis.close();
}
}
// 清空日誌
public String logEmpty() {
Jedis jedis = null;
try {
jedis = jedisPool.getResource();
return jedis.slowlogReset();
} finally {
// 返還到鏈接池
jedis.close();
}
}
// 獲取佔用內存大小
public Long dbSize() {
Jedis jedis = null;
try {
jedis = jedisPool.getResource();
// TODO 配置redis服務信息
Client client = jedis.getClient();
client.dbSize();
return client.getIntegerReply();
} finally {
// 返還到鏈接池
jedis.close();
}
}
}複製代碼
這樣輸出的都是和控制檯同樣的字符串,因此還須要sevice來對數據進行封裝:數據庫
@Service
public class RedisService {
@Autowired
RedisUtil redisUtil;
public List<RedisInfoDetail> getRedisInfo() {
//獲取redis服務器信息
String info = redisUtil.getRedisInfo();
List<RedisInfoDetail> ridList = new ArrayList<RedisInfoDetail>();
String[] strs = info.split("\n");
RedisInfoDetail rif = null;
if (strs != null && strs.length > 0) {
for (int i = 0; i < strs.length; i++) {
rif = new RedisInfoDetail();
String s = strs[i];
String[] str = s.split(":");
if (str != null && str.length > 1) {
String key = str[0];
String value = str[1];
rif.setKey(key);
rif.setValue(value);
ridList.add(rif);
}
}
}
return ridList;
}
//獲取redis日誌列表
public List<Operate> getLogs(long entries) {
List<Slowlog> list = redisUtil.getLogs(entries);
List<Operate> opList = null;
Operate op = null;
boolean flag = false;
if (list != null && list.size() > 0) {
opList = new LinkedList<Operate>();
for (Slowlog sl : list) {
String args = JSON.toJSONString(sl.getArgs());
if (args.equals("[\"PING\"]") || args.equals("[\"SLOWLOG\",\"get\"]") || args.equals("[\"DBSIZE\"]") || args.equals("[\"INFO\"]")) {
continue;
}
op = new Operate();
flag = true;
op.setId(sl.getId());
op.setExecuteTime(getDateStr(sl.getTimeStamp() * 1000));
op.setUsedTime(sl.getExecutionTime()/1000.0 + "ms");
op.setArgs(args);
opList.add(op);
}
}
if (flag)
return opList;
else
return null;
}
//獲取日誌總數
public Long getLogLen() {
return redisUtil.getLogsLen();
}
//清空日誌
public String logEmpty() {
return redisUtil.logEmpty();
}
//獲取當前數據庫中key的數量
public Map<String,Object> getKeysSize() {
long dbSize = redisUtil.dbSize();
Map<String,Object> map = new HashMap<String, Object>();
map.put("create_time", new Date().getTime());
map.put("dbSize", dbSize);
return map;
}
//獲取當前redis使用內存大小狀況
public Map<String,Object> getMemeryInfo() {
String[] strs = redisUtil.getRedisInfo().split("\n");
Map<String, Object> map = null;
for (int i = 0; i < strs.length; i++) {
String s = strs[i];
String[] detail = s.split(":");
if (detail[0].equals("used_memory")) {
map = new HashMap<String, Object>();
map.put("used_memory",detail[1].substring(0, detail[1].length() - 1));
map.put("create_time", new Date().getTime());
break;
}
}
return map;
}
private String getDateStr(long timeStmp) {
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
return dateFormat.format(new Date(timeStmp));
}
}複製代碼
上面我只是貼了部分核心代碼,想具體去了解的能夠去下載個人項目跑一下。windows
因爲這個沒有什麼難度,只是就只是貼了些代碼。後續也會一直更新,一步步將這個系統完善起來。api
·······················································································································································緩存
我的博客:z77z.oschina.io/springboot
此項目下載地址:git.oschina.net/z77z/spring…
·······················································································································································