直接白嫖 Github Action 的 2C7G 服務器

GitHub Actions[1] 是 GitHub 的持續集成服務[2],於2018年10月推出[3]。它的功能非常強大,每一個 action 都用來執行一種操作,比如抓取代碼、運行測試、登錄遠程服務器,發佈到第三方服務等等。將這些 actions 組合起來,就是一個持續集成的過程。當然,這些 actions 都共享在 GitHub 的代碼倉庫中,我們可以直接引用。

Github Actions 提供了整套服務器環境,服務器規格為:

  • 2-core CPU
  • 7 GB RAM 內存
  • 84 GB SSD 硬盤空間

詳細系統環境信息如圖:

直接白嫖 Github Action 的 2C7G 服務器

當然,可使用的系統除了 Ubuntu 之外還可以使用 Windows Server 2019 和 macOS X Catalina 10.15。

看起來很美好,但實際上 GitHub Ac­tions 本身是不允許直接連接進行交互式操作的,也就是說你無法通過 SSH 來連接服務器。如果有辦法能夠直接連接到服務器進行交互式操作,那豈不是相當於白嫖了一臺或多臺 E5 2vCPU/7G RAM/90G SSD 配置的 VPS?

本文就來告訴你如何通過一些奇技淫巧來繞過 GitHub Actions 本身的限制,直接連接到服務器!

注意:請勿用於惡意用途,造成的一切後果比如封號、中美關係惡化、原子彈爆炸、第三次世界大戰等後果均與作者無關。

方案一

mxschmitt/action-tmate[4]

這是第一個實現 tmate[5] 連接 Ac­tions 服務器的 ac­tion ,但此方案在退出連接後不能進行到下一個步驟,所以在實際使用中沒有多少價值,只能用於 SSH 連接。不過由於其開天闢地的作用,我決定把它放到第一位。

work­flow 文件示例:

<code>name: CI
on: [push]
jobs:
  build:
    runs-on: ubuntu-latest
    steps:
    - uses: actions/checkout@v2
    - name: Setup tmate session
      uses: mxschmitt/action-tmate@v2/<code>

方案二

csexton/debugger-action[6]

此 ac­tion 作者受 mxschmitt/action-tmate[7] 啟發,同樣是通過 tmate 連接,退出連接後可持續進行下一個步驟,能更好的應用到實際項目中使用。作者可能考慮到為 GitHub 節約資源,默認加了 15 分鐘自動斷開連接,不過可以通過執行 touch /tmp/keepalive 命令去解除。

work­flow 文件示例:

<code>name: debugger-action
on: 
  watch:
    types: started
jobs:
  build:
    runs-on: ubuntu-latest
    steps:
     - uses: actions/checkout@v2
 
     - name: Setup Debug Session
       uses: csexton/debugger-action@master/<code>

Action 日誌輸出:

直接白嫖 Github Action 的 2C7G 服務器

方案三

該方案沒有使用 action 來實現,而是另闢蹊徑,直接使用 ngrok 來穿透內網,腳本如下:

<code>#!/bin/bash
 
 
if [[ -z "$NGROK_TOKEN" ]]; then
  echo "Please set 'NGROK_TOKEN'"
  exit 2
fi
 
if [[ -z "$USER_PASS" ]]; then
  echo "Please set 'USER_PASS' for user: $USER"
  exit 3
fi
 
echo "### Install ngrok ###"
 
wget -q https://bin.equinox.io/c/4VmDzA7iaHb/ngrok-stable-linux-386.zip
unzip ngrok-stable-linux-386.zip
chmod +x ./ngrok
 
echo "### Update user: $USER password ###"
echo -e "$USER_PASS\n$USER_PASS" | sudo passwd "$USER"
 
echo "### Start ngrok proxy for 22 port ###"
 
 
rm -f .ngrok.log
./ngrok authtoken "$NGROK_TOKEN"
./ngrok tcp 22 --log ".ngrok.log" &
 
sleep 10
HAS_ERRORS=$(grep "command failed" < .ngrok.log)
 
if [[ -z "$HAS_ERRORS" ]]; then
  echo ""
  echo "=========================================="
  echo "To connect: $(grep -o -E "tcp://(.+)" < .ngrok.log | sed "s/tcp:\/\//ssh $USER@/" | sed "s/:/ -p /")"
  echo "=========================================="
else
  echo "$HAS_ERRORS"
  exit 4
fi/<code>

該腳本用來為 SSH 服務建立 TCP 隧道,並打印出通過公網連接遠程服務器的命令。

首先需要在 ngrok 的官網[8] 註冊一個賬戶,並生成一個Tunnel Authtoken:https://dashboard.ngrok.com/auth。然後創建如下的 workflow:

<code>name: Debugging with SSH
on: push
jobs:
  build:
    runs-on: ubuntu-latest
    steps:
     - uses: actions/checkout@v1
 
     - name: Try Build
       run: ./not-exist-file.sh it bloke build
 
     - name: Start SSH via Ngrok
       if: ${{ failure() }}
       run: curl -sL https://gist.githubusercontent.com/retyui/7115bb6acf151351a143ec8f96a7c561/raw/7099b9db76729dc5761da72aa8525f632d8875c9/debug-github-actions.sh | bash
       env:
        # After sign up on the https://ngrok.com/
        # You can find this token here: https://dashboard.ngrok.com/get-started/setup
        NGROK_TOKEN: ${{ secrets.NGROK_TOKEN }}
 
        # This password you will use when authorizing via SSH 
        USER_PASS: ${{ secrets.USER_PASS }}
 
     - name: Don't kill instace
       if: ${{ failure() }}
       run: sleep 1h # Prevent to killing instance after failure/<code>

服務器存活時間默認是 1 小時,可自行調整。這裡面的 TOKEN 和 SSH 登錄密碼最好採用 workflow 中推薦的方式,先在 GitHub 中創建 Secret,然後在 workflow 中引用 Secret。具體步驟可參考官方文檔[9]。

Action 日誌輸出:

直接白嫖 Github Action 的 2C7G 服務器

最後再次強調:希望大家以學習研究目的來使用,切勿用作其他惡意用途,切勿濫用!

參考資料

  • SSH 連接到 GitHub Actions 虛擬服務器環境 [10]

參考資料

[1]GitHub Actions: https://github.com/features/actions

[2]持續集成服務: http://www.ruanyifeng.com/blog/2015/09/continuous-integration.html

[3]推出: https://github.blog/changelog/2018-10-16-github-actions-limited-beta/

[4]mxschmitt/action-tmate: https://p3terx.com/go/aHR0cHM6Ly9naXRodWIuY29tL214c2NobWl0dC9hY3Rpb24tdG1hdGU=

[5]tmate: https://github.com/tmate-io/tmate

[6]csexton/debugger-action: https://p3terx.com/go/aHR0cHM6Ly9naXRodWIuY29tL2NzZXh0b24vZGVidWdnZXItYWN0aW9u

[7]mxschmitt/action-tmate: https://p3terx.com/go/aHR0cHM6Ly9naXRodWIuY29tL214c2NobWl0dC9hY3Rpb24tdG1hdGU=

[8]ngrok 的官網: https://ngrok.com/

[9]官方文檔: https://docs.github.com/cn/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets

[10]SSH 連接到 GitHub Actions 虛擬服務器環境 : https://p3terx.com/archives/ssh-to-the-github-actions-virtual-server-environment.html


分享到:


相關文章: