Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
C
clx-performance
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
姜武杰
clx-performance
Commits
e4c94f78
提交
e4c94f78
authored
5月 15, 2024
作者:
刘海泉
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
增加全平台车辆轨迹监控定时任务存储到es中
上级
6699d761
显示空白字符变更
内嵌
并排
正在显示
5 个修改的文件
包含
174 行增加
和
0 行删除
+174
-0
TruckTraceSyncMqParam.java
...clx/performance/param/mq/trace/TruckTraceSyncMqParam.java
+24
-0
RabbitKeyTraceConstants.java
...com/clx/performance/constant/RabbitKeyTraceConstants.java
+42
-0
PlatTruckTraceJob.java
...java/com/clx/performance/job/trace/PlatTruckTraceJob.java
+49
-0
TruckTraceMqServiceImpl.java
...rformance/service/impl/trace/TruckTraceMqServiceImpl.java
+49
-0
TruckTraceMqService.java
...om/clx/performance/service/trace/TruckTraceMqService.java
+10
-0
没有找到文件。
performance-api/src/main/java/com/clx/performance/param/mq/trace/TruckTraceSyncMqParam.java
0 → 100644
浏览文件 @
e4c94f78
package
com
.
clx
.
performance
.
param
.
mq
.
trace
;
import
lombok.Getter
;
import
lombok.NoArgsConstructor
;
import
lombok.Setter
;
import
lombok.ToString
;
/**
* @Author: aiqingguo
* @Description:
* @Date: 2023-10-19 15:45:25
* @Version: 1.0
*/
@Setter
@Getter
@ToString
@NoArgsConstructor
public
class
TruckTraceSyncMqParam
{
private
String
childNo
;
//运单编号
private
String
truckNo
;
//车牌号
private
String
beginTime
;
//开始时间
private
String
endTime
;
//结束时间
}
performance-web/src/main/java/com/clx/performance/constant/RabbitKeyTraceConstants.java
0 → 100644
浏览文件 @
e4c94f78
package
com
.
clx
.
performance
.
constant
;
/**
* @Author: aiqingguo
* @Description: 轨迹-mq
* @Date: 2023-10-19 15:10:10
* @Version: 1.0
*/
public
class
RabbitKeyTraceConstants
{
private
static
final
String
PREFIX
=
"clx-performance.trace."
;
private
static
final
String
EXCHANGE
=
".exchange"
;
private
static
final
String
QUEUE
=
".queue"
;
private
static
final
String
QUEUE_ROUTING_KEY
=
".routing.key"
;
private
static
final
String
DELAY_QUEUE
=
".delay.queue"
;
private
static
final
String
DELAY_ROUTING_KEY
=
".delay.routing.key"
;
private
static
final
String
DEAD_QUEUE
=
".dead.queue"
;
private
static
final
String
DEAD_ROUTING_KEY
=
".dead.routing.key"
;
private
RabbitKeyTraceConstants
()
{
}
/**
* 缺省交换机
*/
public
static
final
String
DEFAULT_EXCHANGE
=
PREFIX
+
"default"
+
EXCHANGE
;
/**
* 缺省延迟队列
*/
public
static
final
String
DEFAULT_DELAY_QUEUE
=
PREFIX
+
"default"
+
DELAY_QUEUE
;
public
static
final
String
DEFAULT_DELAY_ROUTING_KEY
=
PREFIX
+
"default"
+
DELAY_ROUTING_KEY
;
public
static
final
String
DEFAULT_DEAD_QUEUE
=
PREFIX
+
"default"
+
DEAD_QUEUE
;
public
static
final
String
DEFAULT_DEAD_ROUTING_KEY
=
PREFIX
+
"default"
+
DEAD_ROUTING_KEY
;
/**
* 车辆轨迹同步
*/
public
static
final
String
TRUCK_TRACE_SYNC_QUEUE
=
PREFIX
+
"truck.trace.update"
+
QUEUE
;
public
static
final
String
TRUCK_TRACE_SYNC_ROUTING_KEY
=
PREFIX
+
"truck.trace.update"
+
QUEUE_ROUTING_KEY
;
}
performance-web/src/main/java/com/clx/performance/job/trace/PlatTruckTraceJob.java
0 → 100644
浏览文件 @
e4c94f78
package
com
.
clx
.
performance
.
job
.
trace
;
import
com.clx.performance.service.trace.TruckTraceMqService
;
import
com.clx.performance.utils.LocalDateTimeUtils
;
import
com.clx.user.feign.UserClxFeign
;
import
com.msl.common.job.JobLog
;
import
com.msl.common.result.Result
;
import
com.xxl.job.core.handler.annotation.XxlJob
;
import
lombok.AllArgsConstructor
;
import
lombok.extern.slf4j.Slf4j
;
import
org.apache.commons.lang.exception.ExceptionUtils
;
import
org.springframework.stereotype.Component
;
import
java.time.LocalDateTime
;
import
java.util.List
;
@Slf4j
@Component
@AllArgsConstructor
public
class
PlatTruckTraceJob
{
private
final
UserClxFeign
userClxFeign
;
private
final
TruckTraceMqService
truckTraceMqService
;
/**
* 车辆轨迹同步
*/
@XxlJob
(
"platTruckTraceSync"
)
public
void
platTruckTraceSync
()
{
try
{
Result
<
List
<
String
>>
result
=
userClxFeign
.
getPlatformTruckList
();
if
(
result
.
succeed
()){
log
.
info
(
"平台车辆轨迹同步, size:{}"
,
result
.
getData
().
size
());
for
(
String
truckNo
:
result
.
getData
())
{
LocalDateTime
now
=
LocalDateTime
.
now
();
LocalDateTime
beginTime
=
now
.
minusSeconds
(
600
);
// 发送mq (同步车辆轨迹)
truckTraceMqService
.
truckTracSync
(
truckNo
,
LocalDateTimeUtils
.
formatTime
(
beginTime
),
LocalDateTimeUtils
.
formatTime
(
now
));
}
}
}
catch
(
Exception
e
)
{
log
.
warn
(
"平台车辆轨迹同步失败,异常原因:{}"
,
ExceptionUtils
.
getStackTrace
(
e
));
JobLog
.
error
(
"平台车辆轨迹同步失败,异常原因====================="
,
e
);
}
}
}
performance-web/src/main/java/com/clx/performance/service/impl/trace/TruckTraceMqServiceImpl.java
0 → 100644
浏览文件 @
e4c94f78
package
com
.
clx
.
performance
.
service
.
impl
.
trace
;
import
com.alibaba.fastjson.JSON
;
import
com.clx.performance.common.MqDelay
;
import
com.clx.performance.common.MqWrapper
;
import
com.clx.performance.constant.RabbitKeyTraceConstants
;
import
com.clx.performance.param.mq.trace.TruckTraceSyncMqParam
;
import
com.clx.performance.service.trace.TruckTraceMqService
;
import
lombok.extern.slf4j.Slf4j
;
import
org.springframework.amqp.core.Message
;
import
org.springframework.amqp.core.MessageBuilder
;
import
org.springframework.amqp.rabbit.core.RabbitTemplate
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
@Slf4j
@Service
public
class
TruckTraceMqServiceImpl
implements
TruckTraceMqService
{
@Autowired
private
RabbitTemplate
rabbitTemplate
;
@Override
public
void
truckTracSync
(
String
childNo
,
String
truckNo
,
String
beginTime
,
String
endTime
)
{
TruckTraceSyncMqParam
mq
=
new
TruckTraceSyncMqParam
();
mq
.
setChildNo
(
childNo
);
mq
.
setTruckNo
(
truckNo
);
mq
.
setBeginTime
(
beginTime
);
mq
.
setEndTime
(
endTime
);
MqDelay
delay
=
new
MqDelay
<>(
RabbitKeyTraceConstants
.
DEFAULT_EXCHANGE
,
RabbitKeyTraceConstants
.
TRUCK_TRACE_SYNC_ROUTING_KEY
,
new
MqWrapper
<>(
mq
));
Message
message
=
MessageBuilder
.
withBody
(
JSON
.
toJSONString
(
new
MqWrapper
<>(
delay
)).
getBytes
()).
build
();
message
.
getMessageProperties
().
setExpiration
(
"5000"
);
rabbitTemplate
.
send
(
RabbitKeyTraceConstants
.
DEFAULT_EXCHANGE
,
RabbitKeyTraceConstants
.
DEFAULT_DELAY_ROUTING_KEY
,
message
);
}
@Override
public
void
truckTracSync
(
String
truckNo
,
String
beginTime
,
String
endTime
)
{
TruckTraceSyncMqParam
mq
=
new
TruckTraceSyncMqParam
();
mq
.
setTruckNo
(
truckNo
);
mq
.
setBeginTime
(
beginTime
);
mq
.
setEndTime
(
endTime
);
MqDelay
delay
=
new
MqDelay
<>(
RabbitKeyTraceConstants
.
DEFAULT_EXCHANGE
,
RabbitKeyTraceConstants
.
TRUCK_TRACE_SYNC_ROUTING_KEY
,
new
MqWrapper
<>(
mq
));
Message
message
=
MessageBuilder
.
withBody
(
JSON
.
toJSONString
(
new
MqWrapper
<>(
delay
)).
getBytes
()).
build
();
message
.
getMessageProperties
().
setExpiration
(
"5000"
);
rabbitTemplate
.
send
(
RabbitKeyTraceConstants
.
DEFAULT_EXCHANGE
,
RabbitKeyTraceConstants
.
DEFAULT_DELAY_ROUTING_KEY
,
message
);
}
}
performance-web/src/main/java/com/clx/performance/service/trace/TruckTraceMqService.java
0 → 100644
浏览文件 @
e4c94f78
package
com
.
clx
.
performance
.
service
.
trace
;
public
interface
TruckTraceMqService
{
void
truckTracSync
(
String
childNo
,
String
truckNo
,
String
beginTime
,
String
endTime
);
void
truckTracSync
(
String
truckNo
,
String
beginTime
,
String
endTime
);
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论