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
1f7be484
Commit
1f7be484
authored
Jan 05, 2025
by
duanruiming
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[add] 信控控制指令日志;排查锁定问题
parent
018866b7
Changes
3
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
122 additions
and
101 deletions
+122
-101
ControlCommandServiceImpl.java
...i/utc/hisense/service/impl/ControlCommandServiceImpl.java
+5
-4
ControlCommandStrategyServiceImpl.java
...rvice/control/impl/ControlCommandStrategyServiceImpl.java
+91
-79
CommandFaildTask.java
...ce/src/main/java/net/wanji/utc/task/CommandFaildTask.java
+26
-18
No files found.
signal-utc-hisense-service/src/main/java/net/wanji/utc/hisense/service/impl/ControlCommandServiceImpl.java
View file @
1f7be484
...
...
@@ -33,6 +33,7 @@ import org.springframework.stereotype.Service;
import
javax.annotation.Resource
;
import
java.util.ArrayList
;
import
java.util.Arrays
;
import
java.util.List
;
import
java.util.Map
;
...
...
@@ -235,9 +236,9 @@ public class ControlCommandServiceImpl implements ControlCommandService {
// boolean isOk = true;
if
(
isOk
)
{
return
jsonViewObject
.
fail
(
"第 "
+
i
+
1
+
" 次相位步进失败,取消步进成功,路口号: "
+
code
);
return
jsonViewObject
.
fail
(
"第 "
+
(
i
+
1
)
+
" 次相位步进失败,取消步进成功,路口号: "
+
code
);
}
else
{
return
jsonViewObject
.
fail
(
"第 "
+
i
+
1
+
" 次相位步进失败,取消步进失败,路口号: "
+
code
);
return
jsonViewObject
.
fail
(
"第 "
+
(
i
+
1
)
+
" 次相位步进失败,取消步进失败,路口号: "
+
code
);
}
}
//停顿10ms
...
...
@@ -252,9 +253,9 @@ public class ControlCommandServiceImpl implements ControlCommandService {
// boolean isOk = true;
if
(
isOk
)
{
return
jsonViewObject
.
fail
(
"第 "
+
i
+
1
+
" 次相位步进失败,但取消步进成功,路口号: "
+
code
);
return
jsonViewObject
.
fail
(
"第 "
+
(
i
+
1
)
+
" 次相位步进失败,但取消步进成功,路口号: "
+
code
);
}
else
{
return
jsonViewObject
.
fail
(
"第 "
+
i
+
1
+
" 次相位步进失败,取消步进失败,路口号: "
+
code
);
return
jsonViewObject
.
fail
(
"第 "
+
(
i
+
1
)
+
" 次相位步进失败,取消步进失败,路口号: "
+
code
);
}
}
...
...
signal-utc-service/src/main/java/net/wanji/utc/service/control/impl/ControlCommandStrategyServiceImpl.java
View file @
1f7be484
This diff is collapsed.
Click to expand it.
signal-utc-service/src/main/java/net/wanji/utc/task/CommandFaildTask.java
View file @
1f7be484
...
...
@@ -52,26 +52,32 @@ public class CommandFaildTask {
@Scheduled
(
cron
=
"0/5 * * * * ?"
)
public
void
commandFaildTask
()
throws
Exception
{
LambdaQueryWrapper
<
SignalCommandPO
>
lambdaQueryWrapper
=
new
LambdaQueryWrapper
<>();
lambdaQueryWrapper
.
eq
(
SignalCommandPO:
:
getCommandResult
,
2
);
List
<
SignalCommandPO
>
crossInfoPOList
=
signalCommandPOMapper
.
selectList
(
lambdaQueryWrapper
);
log
.
info
(
"定时任务恢复控制指令,需要执行恢复路口集合crossInfoPOList = {}"
,
crossInfoPOList
);
if
(
ObjectUtil
.
isNotEmpty
(
crossInfoPOList
))
{
for
(
SignalCommandPO
signalCommandPO
:
crossInfoPOList
)
{
String
crossId
=
signalCommandPO
.
getCrossId
();
Integer
commandType
=
signalCommandPO
.
getCommandType
();
Integer
updateCount
=
signalCommandPO
.
getUpdateCount
();
if
(
ObjectUtil
.
isNull
(
updateCount
))
{
updateCount
=
0
;
}
try
{
log
.
info
(
"定时任务自动恢复开始执行(不保证恢复成功),crossId={},commandType={},updateCount={}"
,
crossId
,
commandType
,
updateCount
);
//处理数据
handlerCommand
(
crossId
,
commandType
,
updateCount
);
}
catch
(
Exception
e
)
{
log
.
error
(
"定时任务自动恢复报错,crossId={},commandType={},updateCount={}"
,
crossId
,
commandType
,
updateCount
);
try
{
LambdaQueryWrapper
<
SignalCommandPO
>
lambdaQueryWrapper
=
new
LambdaQueryWrapper
<>();
lambdaQueryWrapper
.
eq
(
SignalCommandPO:
:
getCommandResult
,
2
);
List
<
SignalCommandPO
>
crossInfoPOList
=
signalCommandPOMapper
.
selectList
(
lambdaQueryWrapper
);
log
.
info
(
"定时任务恢复控制指令,需要执行恢复路口集合size:{}, crossInfoPOList = {}"
,
crossInfoPOList
.
size
(),
crossInfoPOList
);
if
(
ObjectUtil
.
isNotEmpty
(
crossInfoPOList
))
{
for
(
SignalCommandPO
signalCommandPO
:
crossInfoPOList
)
{
String
crossId
=
signalCommandPO
.
getCrossId
();
Integer
commandType
=
signalCommandPO
.
getCommandType
();
Integer
updateCount
=
signalCommandPO
.
getUpdateCount
();
if
(
ObjectUtil
.
isNull
(
updateCount
))
{
updateCount
=
0
;
}
try
{
log
.
info
(
"定时任务自动恢复开始执行(不保证恢复成功),crossId={},commandType={},updateCount={}"
,
crossId
,
commandType
,
updateCount
);
//处理数据
handlerCommand
(
crossId
,
commandType
,
updateCount
);
}
catch
(
Exception
e
)
{
log
.
error
(
"定时任务自动恢复报错,crossId={},commandType={},updateCount={}"
,
crossId
,
commandType
,
updateCount
);
throw
new
Exception
(
e
);
}
}
}
}
catch
(
Exception
e
)
{
log
.
error
(
"commandFaildTask定时任务执行异常:"
,
e
);
throw
new
RuntimeException
(
e
);
}
}
...
...
@@ -254,6 +260,8 @@ public class CommandFaildTask {
}
else
{
log
.
info
(
"定时任务 更新t_signal_command失败,crossId = {},commandType = {},time = {},update = {}"
,
jsonObject
.
getString
(
"crossId"
),
commandType
,
LocalDateTimeUtil
.
formatNow
(
LocalDateTimeUtil
.
TIMEFORMATTER
),
update
);
}
List
<
SignalCommandPO
>
signalCommandPOS
=
signalCommandPOMapper
.
selectList
(
lambdaQueryWrapper
);
log
.
error
(
"定时任务 更新t_signal_command成功,数据库中查询结果集:{}"
,
signalCommandPOS
);
}
}
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