GoTTY:把你的 Linux 終端放到瀏覽器裡面

GoTTY 是一個簡單的基於 Go 語言的命令行工具,它可以將你的終端(TTY)作為 web 程序共享。它會將命令行工具轉換為 web 程序。

它使用 Chrome OS 的終端模擬器(hterm)來在 Web 瀏覽器上執行基於 JavaScript 的終端。重要的是,GoTTY 運行了一個 Web 套接字伺服器,它基本上是將 TTY 的輸出傳輸給客戶端,並從客戶端接收輸入(即允許客戶端的輸入),並將其轉發給 TTY。

它的架構(hterm + web socket 的想法)靈感來自 Wetty 項目,它使終端能夠通過 HTTP 和 HTTPS 使用。

先決條件

你需要在 Linux 中安裝 GoLang (Go 編程語言) 環境來運行 GoTTY。

如何在 Linux 中安裝 GoTTY

如果你已經有一個可以工作的 Go 語言環境,運行下面的 go get 命令來安裝它:

# go get github.com/yudai/gotty

上面的命令會在你的 GOBIN環境變數中安裝 GOTTY 的二進位,嘗試檢查下是否如此:

# $GOPATH/bin/

如何在 Linux 中使用 GoTTY

要運行它,你可以使用 GOBIN 環境變數並用命令補全:

# $GOBIN/gotty

另外,要不帶完整命令路徑運行 GoTTY 或其他 Go 程序,使用 export 命令將 GOBIN 變數添加到 ~/.profile 文件中的 PATH 環境變數中。

export PATH="$PATH:$GOBIN"

保存文件並關閉。接著運行 source 來使更改生效:

# source ~/.profile

運行 GoTTY 命令的常規語法是:

Usage: gotty [options] <Linux command here> [<arguments...>]

現在用 GoTTY 運行任意命令,如 df 來從 Web 瀏覽器中查看系統分區空間及使用率。

# gotty df -h

GoTTY 默認會在 8080 啟動一個 Web 伺服器。在瀏覽器中打開 URL:127.0.0.1:8080/,你會看到運行的命令彷彿運行在終端中一樣:

如何在 Linux 中自定義 GoTTY

你可以在 ~/.gotty 配置文件中修改默認選項以及終端,如果該文件存在,它會在每次啟動時載入這個文件。

這是由 getty 命令讀取的主要自定義文件,因此,按如下方式創建:

# touch ~/.gotty

並為配置選項設置你自己的有效值(在此處查找所有配置選項)以自定義 GoTTY,例如:

// Listen at port 9000 by defaultport = "9000"// Enable TSL/SSL by defaultenable_tls = true// hterm preferences// Smaller font and a little bit bluer background colorpreferences {font_size = 5,background_color = "rgb(16, 16, 32)"}

你可以使用命令行中的 --html 選項設置你自己的 index.html 文件:

# gotty --index /path/to/index.html uptime

如何在 GoTTY 中使用安全功能

由於 GoTTY 默認不提供可靠的安全保障,你需要手動使用下面說明的某些安全功能。

允許客戶端在終端中運行命令

請注意,默認情況下,GoTTY 不允許客戶端輸入到TTY中,它只支持窗口縮放。

但是,你可以使用 -w 或 --permit-write 選項來允許客戶端寫入 TTY,但是並不推薦這麼做因為會有安全威脅。

以下命令會使用 vi 命令行編輯器在 Web 瀏覽器中打開文件 fossmint.txt 進行編輯:

gotty -w vi fossmint.txt

以下是從 Web 瀏覽器看到的 vi 界面(像平常一樣使用 vi 命令):

使用基本(用戶名和密碼)驗證運行 GoTTY

嘗試激活基本身份驗證機制,這樣客戶端將需要輸入指定的用戶名和密碼才能連接到 GoTTY 伺服器。

以下命令使用 -c 選項限制客戶端訪問,以向用戶詢問指定的憑據(用戶名:test 密碼:@67890):

gotty -w -p "9000" -c "test@67890" glances

Gotty 生成隨機 URL

限制訪問伺服器的另一種方法是使用 -r 選項。GoTTY 會生成一個隨機 URL,這樣只有知道該 URL 的用戶才可以訪問該伺服器。

還可以使用 -title-format "GoTTY – {{ .Command }} ({{ .Hostname }})" 選項來定義瀏覽器標題。glances 用於顯示系統監控統計信息:

gotty -r --title-format "GoTTY - {{ .Command }} ({{ .Hostname }})" glances

以下是從瀏覽器中看到的上面的命令的結果:

帶有 SSL/TLS 使用 GoTTY

因為默認情況下伺服器和客戶端之間的所有連接都不加密,當你通過 GoTTY 發送秘密信息(如用戶憑據或任何其他信息)時,你需要使用 -t 或 --tls 選項才能在會話中啟用 TLS/SSL:

默認情況下,GoTTY 會讀取證書文件 ~/.gotty.crt 和密鑰文件 ~/.gotty.key,因此,首先使用下面的 openssl 命令創建一個自簽名的證書以及密鑰( 回答問題以生成證書和密鑰文件):

openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout ~/.gotty.key -out ~/.gotty.crt

按如下所示,通過啟用 SSL/TLS,以安全方式使用 GoTTY:

gotty -tr --title-format "GoTTY - {{ .Command }} ({{ .Hostname }})" glances

與多個客戶端分享你的終端

你可以使用終端復用程序來與多個客戶端共享一個進程,以下命令會啟動一個名為 gotty 的新 tmux 會話來運行 glances(確保你安裝了 tmux):

gotty tmux new -A -s gotty glances

要讀取不同的配置文件,像下面那樣使用 –config "/path/to/file" 選項:

gotty -tr --config "~/gotty_new_config" --title-format "GoTTY - {{ .Command }} ({{ .Hostname }})" glances

要顯示 GoTTY 版本,運行命令:

gotty -v

訪問 GoTTY GitHub 倉庫以查找更多使用示例:github.com/yudai/gotty

就這樣了!你有嘗試過了嗎?如何知道 GoTTY 的?通過下面的反饋欄與我們分享你的想法

作者簡介:Aaron Kili 是 Linux 和 F.O.S.S 愛好者,即將成為 Linux SysAdmin 和網路開發人員,目前是 TecMint 的內容創作者,他喜歡在電腦上工作,並堅信分享知識。

via: GoTTY - Share Your Linux Terminal (TTY) as a Web Application

譯者:geekpi 校對:wxy

本文由 LCTT 原創編譯,Linux中國 榮譽推出

推薦閱讀:

有哪些命令行的軟體堪稱神器?
Linux之父Linus(林納斯) 剛去美國時為什麼要去不太知名的全美達公司?
Linux下什麼下載工具比較好?
為什麼要切換到 Linux 系統?我該怎麼做?
你覺得最實用的linux腳本哪些?

TAG:Linux | Shell编程开发 | 软件 |