Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
T
traffic-signal-platform
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
signal
traffic-signal-platform
Commits
4ae96a01
Commit
4ae96a01
authored
Oct 08, 2023
by
hanbing
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/master'
parents
d95eb09d
bc538598
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
71 additions
and
32 deletions
+71
-32
DataCenterProcessTask.java
...c/main/java/net/wanji/opt/task/DataCenterProcessTask.java
+71
-32
No files found.
signal-optimize-service/src/main/java/net/wanji/opt/task/DataCenterProcessTask.java
View file @
4ae96a01
package
net
.
wanji
.
opt
.
task
;
package
net
.
wanji
.
opt
.
task
;
import
com.fasterxml.jackson.core.JsonProcessingException
;
import
com.fasterxml.jackson.core.type.TypeReference
;
import
com.fasterxml.jackson.core.type.TypeReference
;
import
com.fasterxml.jackson.databind.ObjectMapper
;
import
com.fasterxml.jackson.databind.ObjectMapper
;
import
lombok.RequiredArgsConstructor
;
import
lombok.RequiredArgsConstructor
;
import
lombok.extern.slf4j.Slf4j
;
import
net.wanji.common.utils.tool.BeanListUtils
;
import
net.wanji.common.utils.tool.BeanListUtils
;
import
net.wanji.common.utils.tool.JacksonUtils
;
import
net.wanji.common.utils.tool.JacksonUtils
;
import
net.wanji.common.utils.tool.StringUtils
;
import
net.wanji.common.utils.tool.StringUtils
;
...
@@ -11,6 +13,7 @@ import net.wanji.databus.po.*;
...
@@ -11,6 +13,7 @@ import net.wanji.databus.po.*;
import
net.wanji.opt.kafka.ConsumerHandler
;
import
net.wanji.opt.kafka.ConsumerHandler
;
import
org.springframework.scheduling.annotation.Scheduled
;
import
org.springframework.scheduling.annotation.Scheduled
;
import
org.springframework.stereotype.Component
;
import
org.springframework.stereotype.Component
;
import
org.springframework.transaction.annotation.Transactional
;
import
org.springframework.util.CollectionUtils
;
import
org.springframework.util.CollectionUtils
;
import
java.util.ArrayList
;
import
java.util.ArrayList
;
...
@@ -23,6 +26,7 @@ import java.util.stream.Collectors;
...
@@ -23,6 +26,7 @@ import java.util.stream.Collectors;
*/
*/
@Component
@Component
@RequiredArgsConstructor
@RequiredArgsConstructor
@Slf4j
public
class
DataCenterProcessTask
{
public
class
DataCenterProcessTask
{
private
final
CrossDirDataRealtimeMapper
crossDirDataRealTimeMapper
;
private
final
CrossDirDataRealtimeMapper
crossDirDataRealTimeMapper
;
...
@@ -39,35 +43,52 @@ public class DataCenterProcessTask {
...
@@ -39,35 +43,52 @@ public class DataCenterProcessTask {
* @param
* @param
* @return void
* @return void
*/
*/
@Scheduled
(
fixedRate
=
5
*
60
*
1000
)
@Scheduled
(
fixedRate
=
5
*
60
*
1000
)
public
void
realTimeDataSave
()
throws
Exception
{
public
void
realTimeDataSave
()
throws
Exception
{
ObjectMapper
instance
=
JacksonUtils
.
getInstance
();
ObjectMapper
instance
=
JacksonUtils
.
getInstance
();
String
crossRealTimeData
=
ConsumerHandler
.
getTopicMessage
(
"cross_real_time_data"
);
try
{
if
(
StringUtils
.
isNotBlank
(
crossRealTimeData
))
{
saveCrossRealTimeData
(
instance
);
List
<
CrossDataRealtimePO
>
crossDataRealtimePOS
=
instance
.
readValue
(
crossRealTimeData
,
new
TypeReference
<
List
<
CrossDataRealtimePO
>>()
{});
}
catch
(
Exception
e
)
{
if
(!
CollectionUtils
.
isEmpty
(
crossDataRealtimePOS
))
{
log
.
error
(
"路口实时数据插入失败"
,
e
);
crossDataRealTimeMapper
.
deleteBatch
(
crossDataRealtimePOS
.
stream
().
map
(
CrossDataRealtimePO:
:
getCrossId
).
collect
(
Collectors
.
toList
()));
crossDataRealTimeMapper
.
insertBatch
(
crossDataRealtimePOS
);
List
<
CrossDataHistPO
>
crossDataHistPOS
=
new
ArrayList
<>(
crossDataRealtimePOS
.
size
());
BeanListUtils
.
populateList
(
crossDataRealtimePOS
,
crossDataHistPOS
,
CrossDataHistPO
.
class
);
crossDataHistMapper
.
insertBatch
(
crossDataHistPOS
);
}
}
try
{
saveCrossRealTimeDirData
(
instance
);
}
catch
(
Exception
e
)
{
log
.
error
(
"路口方向实时数据插入失败"
,
e
);
}
}
String
crossRealTimeDirData
=
ConsumerHandler
.
getTopicMessage
(
"cross_real_time_dir_data"
);
try
{
if
(
StringUtils
.
isNotBlank
(
crossRealTimeDirData
))
{
saveCrossRealTimeTurnData
(
instance
);
List
<
CrossDirDataRealtimePO
>
crossDirDataRealtimePOS
=
instance
.
readValue
(
crossRealTimeDirData
,
new
TypeReference
<
List
<
CrossDirDataRealtimePO
>>()
{});
}
catch
(
Exception
e
)
{
if
(!
CollectionUtils
.
isEmpty
(
crossDirDataRealtimePOS
))
{
log
.
error
(
"路口转向实时数据插入失败"
,
e
);
crossDirDataRealTimeMapper
.
deleteBatch
(
crossDirDataRealtimePOS
.
stream
().
map
(
CrossDirDataRealtimePO:
:
getCrossId
).
collect
(
Collectors
.
toList
()));
}
crossDirDataRealTimeMapper
.
insertBatch
(
crossDirDataRealtimePOS
);
List
<
CrossDirDataHistPO
>
list
=
new
ArrayList
<>(
crossDirDataRealtimePOS
.
size
());
try
{
BeanListUtils
.
populateList
(
crossDirDataRealtimePOS
,
list
,
CrossDirDataHistPO
.
class
);
saveCrossRealTimeLaneData
(
instance
);
crossDirDataHistMapper
.
insertBatch
(
list
);
}
catch
(
Exception
e
)
{
log
.
error
(
"路口车道实时数据插入失败"
,
e
);
}
}
}
}
@Transactional
public
void
saveCrossRealTimeLaneData
(
ObjectMapper
instance
)
throws
JsonProcessingException
{
String
crossRealTimeLaneData
=
ConsumerHandler
.
getTopicMessage
(
"cross_real_time_lane_data"
);
if
(
StringUtils
.
isNotBlank
(
crossRealTimeLaneData
))
{
List
<
CrossLaneDataRealTimePO
>
crossLaneDataRealTimePOS
=
instance
.
readValue
(
crossRealTimeLaneData
,
new
TypeReference
<
List
<
CrossLaneDataRealTimePO
>>()
{});
if
(!
CollectionUtils
.
isEmpty
(
crossLaneDataRealTimePOS
))
{
crossLaneDataRealTimeMapper
.
deleteBatch
(
crossLaneDataRealTimePOS
.
stream
().
map
(
CrossLaneDataRealTimePO:
:
getCrossId
).
collect
(
Collectors
.
toList
()));
crossLaneDataRealTimeMapper
.
insertBatch
(
crossLaneDataRealTimePOS
);
List
<
CrossLaneDataHistPO
>
crossLaneDataHistPOS
=
new
ArrayList
<>(
crossLaneDataRealTimePOS
.
size
());
BeanListUtils
.
populateList
(
crossLaneDataRealTimePOS
,
crossLaneDataHistPOS
,
CrossLaneDataHistPO
.
class
);
crossLaneDataHistMapper
.
insertBatch
(
crossLaneDataHistPOS
);
}
}
}
@Transactional
public
void
saveCrossRealTimeTurnData
(
ObjectMapper
instance
)
throws
JsonProcessingException
{
String
crossRealTimeTurnData
=
ConsumerHandler
.
getTopicMessage
(
"cross_real_time_turn_data"
);
String
crossRealTimeTurnData
=
ConsumerHandler
.
getTopicMessage
(
"cross_real_time_turn_data"
);
if
(
StringUtils
.
isNotBlank
(
crossRealTimeTurnData
))
{
if
(
StringUtils
.
isNotBlank
(
crossRealTimeTurnData
))
{
List
<
CrossTurnDataRealtimePO
>
crossTurnDataRealtimePOS
=
instance
.
readValue
(
crossRealTimeTurnData
,
new
TypeReference
<
List
<
CrossTurnDataRealtimePO
>>()
{});
List
<
CrossTurnDataRealtimePO
>
crossTurnDataRealtimePOS
=
instance
.
readValue
(
crossRealTimeTurnData
,
new
TypeReference
<
List
<
CrossTurnDataRealtimePO
>>()
{});
...
@@ -79,16 +100,34 @@ public class DataCenterProcessTask {
...
@@ -79,16 +100,34 @@ public class DataCenterProcessTask {
crossTurnDataHistMapper
.
insertBatch
(
list
);
crossTurnDataHistMapper
.
insertBatch
(
list
);
}
}
}
}
}
String
crossRealTimeLaneData
=
ConsumerHandler
.
getTopicMessage
(
"cross_real_time_lane_data"
);
@Transactional
if
(
StringUtils
.
isNotBlank
(
crossRealTimeLaneData
))
{
public
void
saveCrossRealTimeDirData
(
ObjectMapper
instance
)
throws
JsonProcessingException
{
List
<
CrossLaneDataRealTimePO
>
crossLaneDataRealTimePOS
=
instance
.
readValue
(
crossRealTimeLaneData
,
new
TypeReference
<
List
<
CrossLaneDataRealTimePO
>>()
{});
String
crossRealTimeDirData
=
ConsumerHandler
.
getTopicMessage
(
"cross_real_time_dir_data"
);
if
(!
CollectionUtils
.
isEmpty
(
crossLaneDataRealTimePOS
))
{
if
(
StringUtils
.
isNotBlank
(
crossRealTimeDirData
))
{
crossLaneDataRealTimeMapper
.
deleteBatch
(
crossLaneDataRealTimePOS
.
stream
().
map
(
CrossLaneDataRealTimePO:
:
getCrossId
).
collect
(
Collectors
.
toList
()));
List
<
CrossDirDataRealtimePO
>
crossDirDataRealtimePOS
=
instance
.
readValue
(
crossRealTimeDirData
,
new
TypeReference
<
List
<
CrossDirDataRealtimePO
>>()
{});
crossLaneDataRealTimeMapper
.
insertBatch
(
crossLaneDataRealTimePOS
);
if
(!
CollectionUtils
.
isEmpty
(
crossDirDataRealtimePOS
))
{
List
<
CrossLaneDataHistPO
>
crossLaneDataHistPOS
=
new
ArrayList
<>(
crossLaneDataRealTimePOS
.
size
());
crossDirDataRealTimeMapper
.
deleteBatch
(
crossDirDataRealtimePOS
.
stream
().
map
(
CrossDirDataRealtimePO:
:
getCrossId
).
collect
(
Collectors
.
toList
()));
BeanListUtils
.
populateList
(
crossLaneDataRealTimePOS
,
crossLaneDataHistPOS
,
CrossLaneDataHistPO
.
class
);
crossDirDataRealTimeMapper
.
insertBatch
(
crossDirDataRealtimePOS
);
crossLaneDataHistMapper
.
insertBatch
(
crossLaneDataHistPOS
);
List
<
CrossDirDataHistPO
>
list
=
new
ArrayList
<>(
crossDirDataRealtimePOS
.
size
());
BeanListUtils
.
populateList
(
crossDirDataRealtimePOS
,
list
,
CrossDirDataHistPO
.
class
);
crossDirDataHistMapper
.
insertBatch
(
list
);
}
}
}
@Transactional
public
void
saveCrossRealTimeData
(
ObjectMapper
instance
)
throws
JsonProcessingException
{
String
crossRealTimeData
=
ConsumerHandler
.
getTopicMessage
(
"cross_real_time_data"
);
if
(
StringUtils
.
isNotBlank
(
crossRealTimeData
))
{
List
<
CrossDataRealtimePO
>
crossDataRealtimePOS
=
instance
.
readValue
(
crossRealTimeData
,
new
TypeReference
<
List
<
CrossDataRealtimePO
>>()
{});
if
(!
CollectionUtils
.
isEmpty
(
crossDataRealtimePOS
))
{
crossDataRealTimeMapper
.
deleteBatch
(
crossDataRealtimePOS
.
stream
().
map
(
CrossDataRealtimePO:
:
getCrossId
).
collect
(
Collectors
.
toList
()));
crossDataRealTimeMapper
.
insertBatch
(
crossDataRealtimePOS
);
List
<
CrossDataHistPO
>
crossDataHistPOS
=
new
ArrayList
<>(
crossDataRealtimePOS
.
size
());
BeanListUtils
.
populateList
(
crossDataRealtimePOS
,
crossDataHistPOS
,
CrossDataHistPO
.
class
);
crossDataHistMapper
.
insertBatch
(
crossDataHistPOS
);
}
}
}
}
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment