Skip to content

shinvdu/k8-web-terminal

 
 

Repository files navigation

fork 出来了, 处理了在2023年11月, 在go1.19.2下编译失败的问题。 在k8s 1.25下, 默认会传node ip, 这样找不到pods, 把这个filter给去掉了, 现在列出所有的pods. 本来是测试web shell, 这个不伤大雅。。。

本项目使用 beego + websocket 进行开发

    _       __  __  ___ _____
    /_\  /\ /\ \/ / / _ \\_   \
   //_\\/ / \ \  / / /_)/ / /\/
/  _  \ \_/ /  \/ ___/\/ /_
\_/ \_/\___/_/\_\/   \____/

🍭 A k8 web terminal TOOL 🍭

k8 web terminal

一个k8s web终端连接工具,在前后端分离或未分离项目中心中,也可以把此项目无缝集成,开箱即用。

实现细节

前端用xterm.js库,它是模拟一个terminal在浏览器中,并没有通讯能力。需要在前端建立websocket,连到自己开发的websocket服务端。服务端会基于k8s的remotecommand包,建立与container的ssh长连接,remotecommand包只需要我们提供3个回调,其中read是来获取terminal的输入,我们要做的就是读取websocket发来的数据,然后返回给read回调;write则是用来向terminal发送数据,我们要做的就是调用websocket把数据写到前端,然后前端把数据写给xterm即可;next是用来获取terminal的实际大小的,sshd服务端需要知道终端的大小,这样决定了它一行输出多少个字符就要输出一次换行符。所以,当浏览器窗口改变影响了terminal大小的时候,前端应该把最新的terminal大小发给服务端,然后在next回调中返回其大小。

下面是真实的效果

2

1

使用方式

  • 1 在k8s集群内部署:使用"k8-deploy.yaml"编排进行部署
    [root@hub-01 ~]# kubectl apply -f k8-deploy.yaml 
    deployment "terminal-xcbgj" created
    service "terminal" created
    [root@hub-01 ~]# kubectl get po
    NAME                              READY     STATUS    RESTARTS   AGE
    terminal-xcbgj-78c7ff9ffc-kp99q   1/1       Running   0          26s
    
    
  • 2 在集群外部署: 需要有/root/.kube/config文件
    [root@k8s-01 k8]# ls /root/.kube/config 
    /root/.kube/config
    [root@k8s-01 k8]# ls
    conf  k8-web-terminal  static  views
    [root@k8s-01 k8]# ./k8-web-terminal 
    2019/07/29 10:25:06.793 [I] [asm_amd64.s:1333]  http server Running on http://:8089
    # 也可以手动指定文件路径
    ./k8-web-terminal  --kubeconfig ./config
    
    
    

感谢以下框架的开源支持

MIT License

Copyright (c) 2019 Eric

About

一个k8s web终端连接工具,在前后端分离或未分离项目中心中,也可以把此项目无缝集成,开箱即用。

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 96.2%
  • CSS 2.2%
  • Other 1.6%