实时轨迹事件缓存代码更新优化

master
one 2023-12-02 13:28:27 +08:00
parent ef1a65d841
commit 17c2990300
4 changed files with 181 additions and 18 deletions

View File

@ -116,6 +116,11 @@
<artifactId>god-common-datasource</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
<!-- God Common DataScope -->
<dependency>
<groupId>com.god</groupId>

View File

@ -8,8 +8,10 @@ import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.List;
import java.util.HashMap;
import java.util.Map;
/**
*
@ -23,13 +25,14 @@ public class RealTimeTrajectoryEvent implements EventService {
@Autowired
private RedisService redisService;
// @Autowired
// private RedisTemplate<String,Object> redisTemplate;
@Autowired
private RabbitTemplate rabbitTemplate;
/**
*
*/
public static final String LOCUS = "locus";
/**
*
*/
@ -49,20 +52,45 @@ public class RealTimeTrajectoryEvent implements EventService {
carMessage.getLongitude(),
carMessage.getLatitude()
);
//判断是否有key 有则更新数据
if (redisService.hasKey(LOCUS + carMessage.getVin())){
//获取所有车辆数据
List<Object> cacheList = redisService.getCacheList(carMessage.getVin());
//添加车辆信息
cacheList.add(carMessage);
//redis更新
redisService.setCacheList(LOCUS + carMessage.getVin(), cacheList);;
}else {//没有创建对应缓存
ArrayList<CarMessage> carMessages = new ArrayList<>();
carMessages.add(carMessage);
redisService.setCacheList(LOCUS + carMessage.getVin(),carMessages);
//新建一个用于存经纬度的集合 保存精度和维度
ArrayList<BigDecimal> bigDecimals = new ArrayList<>();
//增加经纬度数据
bigDecimals.add(carMessage.getLongitude());
bigDecimals.add(carMessage.getLatitude());
//预防redis空值 避免查询不存在的key返回导致无法操作
if (redisService.hasKey(LOCUS + carMessage.getVin())){//vin轨迹的键存在
//获取键 对应的 值
Map<String, Object> cacheMap = redisService.getCacheMap(LOCUS + carMessage.getVin());
//前端需要格式 [ [..] , [..] ] 所以需要再次新建一个集合来存之前的集合
ArrayList<ArrayList<BigDecimal>> orDefault = (ArrayList<ArrayList<BigDecimal>>) cacheMap.getOrDefault(carMessage.getVin(), new ArrayList<ArrayList<BigDecimal>>());
addLocusRedisInfo(cacheMap,
orDefault,
bigDecimals,
carMessage.getVin());
}else {
//代表当前vin没有实时轨迹相关数据 直接新建集合存储即可
addLocusRedisInfo(new HashMap<>(),
new ArrayList<>(),
bigDecimals,
carMessage.getVin());
}
//rabbit进行通知开启实时轨迹
}
/**
* redis
* @param map
* @param lists
* @param list
* @param vin
*/
private void addLocusRedisInfo(Map<String,Object> map,
ArrayList<ArrayList<BigDecimal>> lists,
ArrayList<BigDecimal> list,
String vin) {
lists.add(list);
map.put(vin,lists);
redisService.setCacheMap(LOCUS + vin,map);
}
/**

View File

@ -0,0 +1,121 @@
package com.god.data.test;
import com.god.common.redis.service.RedisService;
import com.god.data.common.domain.CarMessage;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.FactoryBean;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
/**
* Description:
*
* @Author: sun-cool-boy
* @Date: 2023/12/1
* @info:
*/
@SpringBootTest
public class SJZTest {
/**
*
*/
public static final String ALL_LOCUS_INFO = "all_locus_info";
/**
*
*/
public static final String LOCUS = "locus";
@Autowired
private RedisService redisService;
@Test
public void testRedis(){
ArrayList<BigDecimal> bigDecimals = new ArrayList<>();
bigDecimals.add(BigDecimal.valueOf(12.222));
bigDecimals.add(BigDecimal.valueOf(35.232));
ArrayList<ArrayList<BigDecimal>> arrayLists = new ArrayList<>();
arrayLists.add(bigDecimals);
HashMap<String, ArrayList<ArrayList<BigDecimal>>> map = new HashMap<>();
map.put("vim",arrayLists);
redisService.setCacheMap("123",map);
Map<String, Object> cacheMap = redisService.getCacheMap("123");
cacheMap.forEach((key,value)->{
System.out.println(key + " " +value);
});
}
@Test
public void test2(){
CarMessage one = CarMessage.builder()
.vin("vin5211314")
.longitude(BigDecimal.valueOf(22.4512439))
.latitude(BigDecimal.valueOf(23.49785))
.build();
CarMessage two = CarMessage.builder()
.vin("vin5211314")
.longitude(BigDecimal.valueOf(44.91230))
.latitude(BigDecimal.valueOf(55.45456))
.build();
CarMessage three = CarMessage.builder()
.vin("vin5211314")
.longitude(BigDecimal.valueOf(29.41235))
.latitude(BigDecimal.valueOf(36.41235))
.build();
ArrayList<CarMessage> list = new ArrayList<>();
list.add(one);
list.add(two);
list.add(three);
for (CarMessage carMessage : list) {
//新建一个用于存经纬度的集合 保存精度和维度
ArrayList<BigDecimal> bigDecimals = new ArrayList<>();
bigDecimals.add(carMessage.getLongitude());
bigDecimals.add(carMessage.getLatitude());
if (redisService.hasKey(ALL_LOCUS_INFO)){//vin轨迹的键存在
//获取键 对应的 值
Map<String, Object> cacheMap = redisService.getCacheMap(ALL_LOCUS_INFO);
//前端需要格式 [ [..] , [..] ] 所以需要再次新建一个集合来存之前的集合
ArrayList<ArrayList<BigDecimal>> orDefault = (ArrayList<ArrayList<BigDecimal>>) cacheMap.getOrDefault(carMessage.getVin(), new ArrayList<ArrayList<BigDecimal>>());
addLocusRedisInfo(cacheMap,
orDefault,
bigDecimals,
carMessage.getVin());
}else {
//代表当前vin没有实时轨迹相关数据 直接新建集合存储即可
addLocusRedisInfo(new HashMap<>(),
new ArrayList<>(),
bigDecimals,
carMessage.getVin());
}
}
}
private void addLocusRedisInfo(Map<String, Object> map,
ArrayList<ArrayList<BigDecimal>> lists,
ArrayList<BigDecimal> list,
String vin) {
lists.add(list);
map.put(vin,lists);
redisService.setCacheMap(ALL_LOCUS_INFO,map);
}
@Test
public void testThree(){
Map<String, Object> cacheMap = redisService.getCacheMap(ALL_LOCUS_INFO);
ArrayList<ArrayList<BigDecimal>> orDefault = (ArrayList<ArrayList<BigDecimal>>) cacheMap.getOrDefault("vin123123123", new ArrayList<ArrayList<BigDecimal>>());
ArrayList<BigDecimal> bigDecimals = orDefault.get(orDefault.size() - 1);
bigDecimals.forEach(obj -> {
System.out.println(obj);
});
}
}

View File

@ -1,9 +1,16 @@
package com.god.data.test;
import com.alibaba.fastjson2.JSONObject;
import com.god.common.redis.service.RedisService;
import com.god.data.common.domain.CarMessage;
import com.god.data.utils.AnalyzeUtils;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import javax.annotation.Resource;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
/**
* @description:
@ -12,6 +19,7 @@ import org.junit.jupiter.api.Test;
*/
public class Test007 {
/**
* showStr
*/
@ -31,4 +39,5 @@ public class Test007 {
System.out.println(carMessage);
}
}