简单分析实现运维利器—webssh终端

简单分析实现运维利器—webssh终端背景现在几乎所有东西都向往着自动化 在运维界更是如此 运维人员都向往自动化代替人工操作 解决人工操作大量重复性工作的问题 故障主动恢复 及时发现 流程 解决 运维规范化 角色定义和责任划分 流程化等 但这些种种的目的 都离不开非常细小的技术支持 下面我们就来讨论如何搭建一个自动化运维平台 本文先讲一讲运维平台较重要的技术之一的 webssh 一 技术选型 amp 实现思路 1 后端逻辑 选用 Django 框架 2 模拟 web 终端 选用 xterm3 实现远程主机连接 建立 ssh 通道 python 库 pa

背景

现在几乎所有东西都向往着自动化,在运维界更是如此,运维人员都向往自动化代替人工操作、解决人工操作大量重复性工作的问题、故障主动恢复:及时发现;流程;解决。运维规范化:角色定义和责任划分、流程化等。但这些种种的目的,都离不开非常细小的技术支持,下面我们就来讨论如何搭建一个自动化运维平台,本文先讲一讲运维平台较重要的技术之一的webssh。

一、技术选型&实现思路

1.后端逻辑,选用:Django框架

2.模拟web终端,选用:xterm

3.实现远程主机连接,建立ssh通道,python库:paramiko

4.实现web远程连接必须需要实时保持前后端通信,使用技术:websocket

二、实现

2.1.创建webssh页面

xterm.js是一个开源模拟终端,利用它我们可以创建一个比较正规好看的终端界面。

<!doctype html> <html> <head> <link rel="stylesheet" href="/static/xterm_/xterm.css" /> <link rel="stylesheet" href="/static/xterm_/bootstrap3.css" /> </head> <body> <div id="terminal"></div> </body> <script src="/static/xterm_/xterm.js"></script> <script src="/static/xterm_/jquery.js"></script> <script src="/static/xterm_/ssh.js"></script> </html> 
var window_width = $(window).width(); var window_height = $(window).height(); var term = new Terminal( { 
    cols : Math.floor(window_width/9), //列数 rows : Math.floor(window_height/18), //行数 convertEol : true, //启用时,光标将设置为下一行的开头 cursorBlink: true, //光标闪烁 rendererType: "canvas", //渲染类型 } ); $(function () { 
    var sock = new WebSocket("ws://" + window.location.host + "{% url 'webssh' %}"); // 打开webssh页面就打开web终端,并且打开websocket通道 sock.addEventListener("open",function () { 
    term.open(document.getElementById('terminal')); term.writeln('等待10s,出现命令行表示连接成功,没有出现则表示连接失败(检查参数跟网络)。');//这里连接失败是表示ssh连接失败. }); //获取从ssh通道获取的outdata sock.addEventListener("message",function (recv) { 
    term.write(recv.data); }); //输入shelldata并发送到后台 term.on("data",function (data) { 
    sock.send(data) }); window.sock=sock; }); 

2.2后台逻辑

后台是前端与服务器之间的桥梁,可以理解成中转站。具体实现思路在代码注释中有讲解。

from dwebsocket.decorators import accept_websocket @accept_websocket #用于websocket连接的修饰器 def webssh(request): global ip, port, user, passwd #定义全局变量连接信息. if request.session.get('login')==None: #判断是否登陆系统,如果没有就去登陆! return redirect('/sys/login/') if not request.is_websocket():#判断websocket连接,如果是普通的http连接就获取传送进来的登陆信息。 ip = request.POST.get('conip') port = request.POST.get('conport') user = request.POST.get('conuser') passwd = request.POST.get('conpass') print(ip,str(port),user,passwd) return render(request, 'html/webssh.html', locals()) else: #如果是websocket连接就创建ssh连接,使用paramiko模块创建 client = paramiko.SSHClient() #创建连接对象 client.set_missing_host_key_policy(paramiko.AutoAddPolicy) #设置自动添加主机名及主机密钥到本地HostKeys对象,不依赖load_system_host_key的配置。即新建立ssh连接时不需要再输入yes或no进行确认 try: #用异常抛出判定主机是否成功连接ssh client.connect(hostname=ip,port=port,username=user,password=passwd) #connetc为连接函数 print(f'主机{ip}连接成功!') mess = f'主机{ip}连接成功!' except: print(f'主机{ip}连接失败,请确认输入信息!') mess = f'主机{ip}连接失败!' sshsession = client.get_transport().open_session() #成功连接后获取ssh通道 sshsession.get_pty() #获取一个终端 sshsession.invoke_shell() #激活终端 for i in range(2): #激活终端后会有信息流,一般都是lastlogin与bath目录,并获取其数据 messa = sshsession.recv(1024) request.websocket.send(messa) print(request.websocket) def srecv(): #从ssh通道获取输出data,并发送到前端 while True: sshmess = sshsession.recv(2048) if not len(sshmess): print('退出监听发送循环') return request.websocket.send(sshmess) print('ssh回复的信息:' + sshmess.decode('utf-8')) print(len(sshmess)) for shell in request.websocket: #获取前端的shelldata并且发送到服务器执行 deshell = shell.decode('utf-8') print('deshell:'+deshell) # stdin,stdout,stderr = client.exec_command(deshell)  # request.websocket.send(stdout.read()) # request.websocket.send(stderr.read())  sshsession.send(deshell) # while True: # sshmess = sshsession.recv(2048) # request.websocket.send(sshmess)  # print('ssh回复的信息:'+sshmess.decode('utf-8')) # print(len(sshmess)) sshrecvthre = Thread(target=srecv, args=()).start() #启用线程监听ssh通道获取输出data,并发送到前端 

2.3效果
在这里插入图片描述

结束

Webssh的应用十分的广泛,并且在网络的复杂环境中很难确保它的通信安全,但是针对自己网络所自己编写的webssh往往安全性会有提升,以上只是对功能实现上进行了说明,若要对安全上进行防范,还需要对以上代码进行改造。

一个web远程连接与主机的正删改查只是一个运维系统的基础功能,下次我们来说一下webssh终端如何实现录像回放~

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/220289.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午8:49
下一篇 2026年3月17日 下午8:49


相关推荐

  • 已知负数的补码求原码

    已知负数的补码求原码正数的原码 反码 补码都是一样的 负数的原码你应该知道的 就是带符号位的二进制数 反码 符号位不变为 1 其他每位二进制数取反 1 变 0 0 变 1 补码就是在反码的基础上 符号位不变 最低位加 1 得到补码 这里有个简单的求补码的方法 从原码的最低位向最高位看去 遇到第一个 1 前 保持不变 第一个 1 前面的二进制串取反 符号位保持不变 下面是一个例子 x 这是一个负数 它的原码 反码 补码分别是 用上面的那个简单的方法就可以一步写出

    2026年3月18日
    2
  • 虚拟机ftp服务器配置实验报告,FTP服务器配置 实验报告.doc

    虚拟机ftp服务器配置实验报告,FTP服务器配置 实验报告.docFTP 服务器配置实验报告学号 姓名 专业 班级 第周课程名称 计算机网络课程设计实验课时 2 实验项目 FTP 服务器配置实验时间 11 27 实验目的掌握安装 FTP 服务器掌握对 FTP 服务器的设置掌握如何使用 Serv U 架设 FTP 服务器实验环境 WindowsServe 实验内容 算法 程序 步骤和方法 一 安装 IIS 组件 1 单击 开始 设置 控制面板 添加 删除程序

    2026年3月19日
    2
  • FQDN科普

    FQDN科普FQDN FullyQualifi 全限定域名 通过符号 访问时将由 DNS 进行解析 得到 IP 由两部分组成 1 主机名 2 域名当连接到主机 例如 使用 SSH 客户机 时 必须指定 FQDN 然后 DNS 服务器通过查看其 DNS 表将主机名解析为其 IP 地址 与主机取得联系 您将收到一个登录提示 如果只使用主机名 没有域信息 连接到服务器 则使用的应

    2026年3月18日
    3
  • fedora14虚拟机安装教程_vmware上安装ubuntu

    fedora14虚拟机安装教程_vmware上安装ubuntuSunVirtualBox虚拟机下安装Fedora12Linux软件准备:硬件:32bitCPU本地系统:WinXPSP2虚拟机版本:SunVirtualBox 3.1.4Fedora12:i386安装包操作步骤:1、安装虚拟机SunVirtualBox 3.1.4略 2、设置虚拟电脑>新建虚拟电脑,名称随意,选择操作系统Linux,选择版

    2025年11月25日
    5
  • Gradle DSL method not found: ‘google()’

    Gradle DSL method not found: ‘google()’

    2021年10月1日
    46
  • war3辅助工具_魔兽世界修改器

    war3辅助工具_魔兽世界修改器War3tools魔兽工具完成于2012年5月,工具包含:版本转换,注册表修复,一键启动游戏,以及将网上好用的改建精灵内置其中。War3tools魔兽工具还可以将自己的工具或者魔兽对战平台加入启动项目,只需在我的工具中添加即可,操作简单,功能实用。希望War3tools魔兽工具能给您的游戏带来方便。@risingsun下载地址:http://pan.baidu.com/share/li

    2026年4月16日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号