一款可以通过 Web 访问的 Linux 终端神器,已开源!

rtty 由客户端和服务端组成。客户端采用纯C实现,服务端采用 GO 语言实现,前端界面采用 vue 实现。使用 rtty 可以在任何地方通过 Web 访问您的设备的终端,通过 设备ID 来区分您的不同的设备。rtty 非常适合远程维护 Linux设备。

特性

  • 客户端 C 语言实现,非常小,适合嵌入式 Linux
  • 不支持 SSL:rtty(32K) + libev(56K)
  • 支持 SSL:+ libmbedtls(88K) + libmbedcrypto(241K) + * libmbedx509(48k)
  • 远程批量执行命令
  • 支持SSL: openssl、mbedtls、CyaSSl(wolfssl)
  • SSL 双向认证(mTLS)
  • 非常方便的上传和下载文件
  • 根据 设备ID 访问不同的设备
  • 支持 HTTP 代理 访问您的设备的 Web
  • 基于 Xterm.js 的全功能终端
  • 部署简单,使用方便

演示

02d6d99dd3454b7632aedcecc7c1f484.jpg

35926612cea520d67890a3482e38533c.jpg

aa4630efc6c4ab3e8cfb6ee50f76f10d.jpg

部署服务端

安装依赖

sudo apt install -y libev-dev libssl-dev      # Ubuntu, Debian  
sudo pacman -S --noconfirm libev openssl      # ArchLinux  
sudo yum install -y libev-devel openssl-devel # Centos

克隆 rtty 代码

git clone --recursive https://github.com/zhaojh329/rtty.git

编译

cd rtty && mkdir build && cd build  
cmake .. && make install

将下面的参数替换为您自己的参数

sudo rtty -I 'My-device-ID' -h 'your-server' -p 5912 -a -v -d 'My Device Description'

生成一个 token

$ rttys token  
Please set a password:******  
Your token is: 34762d07637276694b938d23f10d7164

使用 token

$rttys -t 34762d07637276694b938d23f10d7164

通过浏览器访问

使用 Web 浏览器访问您的服务器:http://your-server-host:5913,然后点击连接按钮。
或者直接连接设备,无需 Web 登录(需要在服务端配置设备白名单)

http://your-server-host:5913/connect/devid1
http://your-server-host:5913/connect/devid2

从本地传输文件到远程设备

rtty -R

从远程设备传输文件到本地

rtty -S test.txt

开源地址:

https://github.com/zhaojh329/rtty

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容