WebSSH进阶之实时监控和强制下线,3分钟告诉你为什么要用Java开发高频交易系统
2021/12/31 14:08:47
本文主要是介绍WebSSH进阶之实时监控和强制下线,3分钟告诉你为什么要用Java开发高频交易系统,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
self.therecord.save()
async_to_sync(self.channel_layer.group_discard)(
self.group_name,
self.channel_name
)
self.ssh.close()
def receive(self, text_data=None):
text_data = json.loads(text_data)
if text_data.get(‘flag’) == ‘resize’:
self.ssh.resize_pty(cols=text_data[‘cols’], rows=text_data[‘rows’])
else:
self.ssh.shell(data=text_data.get(‘data’, ‘’))
def ssh_message(self, event):
self.send(text_data=json.dumps(
event[‘message’]
))
在connect连接建立时新建一条记录,存储主机、用户、group_name
、channel_name
以及初始窗口的cols
、rows
信息,同时标记is_connecting
为True,这里的group_name
命名与文章『堡垒机的核心武器:WebSSH录像实现』中我们定义的录像文件名规则一致,另外将这篇文章中新建录像记录的操作从SSHBridge.record
中给转到了连接建立的connect中来,更合理也更方便
在disconnect连接关闭时,将is_connecting
标记为False,这样我们在前端页面上就可以根据这个标记来判断WebSSH是否正在连接,如果连接则展示监控和强制结束按钮,否则展示播放和命令提取按钮
同时添加个ssh_message方法,用来接收发送到组的数据
到这里,我们已经将WebSSH改造成了支持layer的模式,那么接下来就是要在用户点击监控的时候将用户与服务端建立的连接channel加入到上述group中
新建一个名为MonitorConsumer
的consumer,主要用来处理监控连接
class MonitorConsumer(WebsocketConsumer):
def connect(self):
pk = self.scope[‘url_route’][‘kwargs’].get(‘id’)
self.group_name = Record.objects.get(id=pk).group
async_to_sync(self.channel_layer.group_add)(
self.group_name,
self.channel_name
)
self.accept()
判断用户已经结束了这个webssh连接时就关闭监控
self.connecting = Record.objects.get(id=pk).is_connecting
if not self.connecting:
self.close()
def disconnect(self, close_code):
async_to_sync(self.channel_layer.group_discard)(
self.group_name,
self.channel_name
)
self.close()
def receive(self, text_data=None):
pass
def ssh_message(self, event):
self.send(text_data=json.dumps(
event[‘message’]
))
MonitorConsumer与SSHConsumer有两个地方不一样,其一是SSHConsumer
中我们直接新生成了个group_name
,而MonitorConsumer
中需要在connect时获取到要监控的ID,然后通过ID拿到group_name
,将monitor连接加入到这个g
《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》
【docs.qq.com/doc/DSmxTbFJ1cmN1R2dB】 完整内容开源分享
roup,其二是监控只能看,不能操作,所以也不需要前端发送数据的term.on
和Consumer的receive
处理数据
最后需要修改SSHBridge
方法中发送给websocket的指令,从self.websocket.send
改为发送到group的模式,如下
async_to_sync(self.websocket.channel_layer.group_send)(
self.group_name,
{
‘type’: ‘ssh.message’,
‘message’: message
}
)
至此,监控功能就算完成了,什么?前端页面怎么弄?参考下之前的WebSSH界面,几乎可以完全复制
踢用户下线
踢用户下线就比较简单了,逻辑是点击页面上的强制结束按钮,给后端view发送个请求带上这条记录的ID,view拿到ID后,通过ID找到group_name,然后向group发送disconnect
消息,这个group里的所有channel在收到disconnect消息后就会断开连接了
from asgiref.sync import async_to_sync
from channels.layers import get_channel_layer
async_to_sync(get_channel_layer().group_send)(
Record.objects.get(id=pk).group,
{‘type’: ‘disconnect’}
)
演示与说明
这篇关于WebSSH进阶之实时监控和强制下线,3分钟告诉你为什么要用Java开发高频交易系统的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-11有哪些好用的家政团队管理工具?
- 2025-01-11营销人必看的GTM五个指标
- 2025-01-11办公软件在直播电商前期筹划中的应用与推荐
- 2025-01-11提升组织效率:上级管理者如何优化跨部门任务分配
- 2025-01-11酒店精细化运营背后的协同工具支持
- 2025-01-11跨境电商选品全攻略:工具使用、市场数据与选品策略
- 2025-01-11数据驱动酒店管理:在线工具的核心价值解析
- 2025-01-11cursor试用出现:Too many free trial accounts used on this machine 的解决方法
- 2025-01-11百万架构师第十四课:源码分析:Spring 源码分析:深入分析IOC那些鲜为人知的细节|JavaGuide
- 2025-01-11不得不了解的高效AI办公工具API