Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
ssssssss-team
magic-api
提交
310df934
M
magic-api
项目概览
ssssssss-team
/
magic-api
11 个月 前同步成功
通知
41
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
M
magic-api
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
310df934
编写于
2月 28, 2022
作者:
M
mxd
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
修复用户在线状态会自动掉线的问题。
上级
39b4a178
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
19 addition
and
12 deletion
+19
-12
magic-api/src/main/java/org/ssssssss/magicapi/core/config/MessageType.java
...n/java/org/ssssssss/magicapi/core/config/MessageType.java
+6
-4
magic-api/src/main/java/org/ssssssss/magicapi/core/config/WebSocketSessionManager.java
...sssssss/magicapi/core/config/WebSocketSessionManager.java
+7
-2
magic-api/src/main/java/org/ssssssss/magicapi/core/handler/MagicWebSocketDispatcher.java
...sssss/magicapi/core/handler/MagicWebSocketDispatcher.java
+3
-1
magic-api/src/main/java/org/ssssssss/magicapi/core/handler/MagicWorkbenchHandler.java
...ssssssss/magicapi/core/handler/MagicWorkbenchHandler.java
+3
-5
未找到文件。
magic-api/src/main/java/org/ssssssss/magicapi/core/config/MessageType.java
浏览文件 @
310df934
...
@@ -23,8 +23,9 @@ public enum MessageType {
...
@@ -23,8 +23,9 @@ public enum MessageType {
ONLINE_USERS
,
ONLINE_USERS
,
/* 通知客户端,他人进入文件*/
/* 通知客户端,他人进入文件*/
INTO_FILE_ID
,
INTO_FILE_ID
,
/* PONG */
/* ping */
PONG
,
PING
,
/* C -> S message */
/* C -> S message */
/* 设置断点 */
/* 设置断点 */
...
@@ -35,8 +36,9 @@ public enum MessageType {
...
@@ -35,8 +36,9 @@ public enum MessageType {
LOGIN
,
LOGIN
,
/* 设置当前所在文件 */
/* 设置当前所在文件 */
SET_FILE_ID
,
SET_FILE_ID
,
/* ping */
/* PONG */
PING
,
PONG
,
/* S <-> S -> C message*/
/* S <-> S -> C message*/
/* 获取当前在线用户 */
/* 获取当前在线用户 */
...
...
magic-api/src/main/java/org/ssssssss/magicapi/core/config/WebSocketSessionManager.java
浏览文件 @
310df934
...
@@ -29,6 +29,10 @@ public class WebSocketSessionManager {
...
@@ -29,6 +29,10 @@ public class WebSocketSessionManager {
private
static
String
instanceId
;
private
static
String
instanceId
;
private
static
final
int
CHECK_INTERVAL
=
20
;
private
static
final
int
KEEPALIVE_TIMEOUT
=
60
*
1000
;
private
static
final
List
<
Pair
<
String
,
String
>>
MESSAGE_CACHE
=
new
ArrayList
<>(
200
);
private
static
final
List
<
Pair
<
String
,
String
>>
MESSAGE_CACHE
=
new
ArrayList
<>(
200
);
public
static
void
add
(
MagicConsoleSession
session
)
{
public
static
void
add
(
MagicConsoleSession
session
)
{
...
@@ -43,7 +47,7 @@ public class WebSocketSessionManager {
...
@@ -43,7 +47,7 @@ public class WebSocketSessionManager {
// 1秒1次发送日志
// 1秒1次发送日志
new
ScheduledThreadPoolExecutor
(
1
,
r
->
new
Thread
(
r
,
"magic-api-send-log-task"
)).
scheduleAtFixedRate
(
WebSocketSessionManager:
:
flushLog
,
1
,
1
,
TimeUnit
.
SECONDS
);
new
ScheduledThreadPoolExecutor
(
1
,
r
->
new
Thread
(
r
,
"magic-api-send-log-task"
)).
scheduleAtFixedRate
(
WebSocketSessionManager:
:
flushLog
,
1
,
1
,
TimeUnit
.
SECONDS
);
// 60秒检测一次是否在线
// 60秒检测一次是否在线
new
ScheduledThreadPoolExecutor
(
1
,
r
->
new
Thread
(
r
,
"magic-api-websocket-clean-task"
)).
scheduleAtFixedRate
(
WebSocketSessionManager:
:
checkSession
,
60
,
60
,
TimeUnit
.
SECONDS
);
new
ScheduledThreadPoolExecutor
(
1
,
r
->
new
Thread
(
r
,
"magic-api-websocket-clean-task"
)).
scheduleAtFixedRate
(
WebSocketSessionManager:
:
checkSession
,
CHECK_INTERVAL
,
CHECK_INTERVAL
,
TimeUnit
.
SECONDS
);
}
}
public
static
Collection
<
MagicConsoleSession
>
getSessions
()
{
public
static
Collection
<
MagicConsoleSession
>
getSessions
()
{
...
@@ -193,8 +197,9 @@ public class WebSocketSessionManager {
...
@@ -193,8 +197,9 @@ public class WebSocketSessionManager {
private
static
void
checkSession
()
{
private
static
void
checkSession
()
{
try
{
try
{
long
activateTime
=
System
.
currentTimeMillis
()
-
20
*
1000
;
long
activateTime
=
System
.
currentTimeMillis
()
-
KEEPALIVE_TIMEOUT
;
SESSIONS
.
entrySet
().
stream
()
SESSIONS
.
entrySet
().
stream
()
.
peek
(
it
->
WebSocketSessionManager
.
sendBySession
(
it
.
getValue
(),
WebSocketSessionManager
.
buildMessage
(
MessageType
.
PING
)))
.
filter
(
it
->
it
.
getValue
().
getActivateTime
()
<
activateTime
)
.
filter
(
it
->
it
.
getValue
().
getActivateTime
()
<
activateTime
)
.
collect
(
Collectors
.
toList
())
.
collect
(
Collectors
.
toList
())
.
forEach
(
entry
->
{
.
forEach
(
entry
->
{
...
...
magic-api/src/main/java/org/ssssssss/magicapi/core/handler/MagicWebSocketDispatcher.java
浏览文件 @
310df934
...
@@ -104,7 +104,9 @@ public class MagicWebSocketDispatcher extends TextWebSocketHandler {
...
@@ -104,7 +104,9 @@ public class MagicWebSocketDispatcher extends TextWebSocketHandler {
MagicConsoleSession
mcsession
=
MagicConsoleSession
.
from
(
session
);
MagicConsoleSession
mcsession
=
MagicConsoleSession
.
from
(
session
);
WebSocketSessionManager
.
remove
(
mcsession
);
WebSocketSessionManager
.
remove
(
mcsession
);
MagicConsoleSession
.
remove
(
session
);
MagicConsoleSession
.
remove
(
session
);
WebSocketSessionManager
.
sendToAll
(
MessageType
.
USER_LOGOUT
,
mcsession
.
getAttributes
());
if
(
mcsession
.
getClientId
()
!=
null
&&
mcsession
.
getAttributes
()
!=
null
&&
!
mcsession
.
getAttributes
().
isEmpty
()){
WebSocketSessionManager
.
sendToAll
(
MessageType
.
USER_LOGOUT
,
mcsession
.
getAttributes
());
}
}
}
@Override
@Override
...
...
magic-api/src/main/java/org/ssssssss/magicapi/core/handler/MagicWorkbenchHandler.java
浏览文件 @
310df934
...
@@ -75,11 +75,9 @@ public class MagicWorkbenchHandler {
...
@@ -75,11 +75,9 @@ public class MagicWorkbenchHandler {
}
}
}
}
@Message
(
MessageType
.
PING
)
@Message
(
MessageType
.
PONG
)
public
void
ping
(
MagicConsoleSession
session
){
public
void
pong
(
MagicConsoleSession
session
){
long
activateTime
=
System
.
currentTimeMillis
();
session
.
setActivateTime
(
System
.
currentTimeMillis
());
session
.
setActivateTime
(
activateTime
);
WebSocketSessionManager
.
sendBySession
(
session
,
WebSocketSessionManager
.
buildMessage
(
MessageType
.
PONG
,
activateTime
));
}
}
private
List
<
Map
<
String
,
Object
>>
getOnlineUsers
(){
private
List
<
Map
<
String
,
Object
>>
getOnlineUsers
(){
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录