2024年11月15日 星期五

github actions使用進化,使用runner來佈版吧

我就覺得奇怪,最早喬納斯推薦我這套,我就在質疑,一開始跑jenkins是跑在server端,這樣才能對機器進行操作,github跑在遠端是要怎麼進行佈版啦。

一開始也沒什麼概念,於是我突發奇想,使用ssh連線,使用sftp上傳檔案,或是使用nodejs腳本

一直到最近遇到windows open ssh不穩的問題,如果短時間遇到一個帳號同時登入,ssh就會掛掉的狀況,我只好另求出路

原本想說要使用drone來作為cicd工具,看到要透過docker啟動兩個服務,一個是server一個是runner,我對這個也沒有很了解所以看過就算了,但server我有點不太想亂裝東西,所以還是放後面吧

在多方查找之下才發現,actions有各式各樣的套件可以與不同的服務進行部署,azure, aws之類的,我想想會不會有iis的pipeline可以使用,結果是有的,但使用上好像會失敗,有興趣的大大可以自己玩一下

再來我逛到保哥的網誌,裡面有用到一個可以上傳跟下載的套件(actions/upload-artifact,actions/download-artifact),接著再看到這篇提問,裡面幾個關鍵字,needs: build,run-on: self_hosted,needs我看得懂,就是可以把任務串連起來(沒串連之前測試都是併發)那self_hosted難道是可以跑在本機上?接著我就開始研究這些關鍵字

原來有github有個服務叫github runner,可以在伺服器跑起來,這樣run-on: self_hosted就可以在之後step寫要做的動作了,這招妙啊!原來runner就是監聽器的服務啊~(drone也有)

要在伺服器把github runner跑起來,可以參考這篇教學,可以選擇伺服器的作業系統進行安裝與啟用,基本上從第一行執行到最後一行就可以完成了

這邊記錄下我遇到的兩個問題

第一行下載zip包,遇到ssltls安全問題,可以把網址複製到chrome上直接下載

最後一個./run.cmd,這行跑起來沒問題,服務也持續啟動,但問題是到時腳本跑在機器上會在github-runner資料夾下面創run.cmd資料夾,到時會有檔名衝突問題,所以當啟動完就要把檔名改掉,這超不合理的啊,我也不知對什麼會這樣,可能是我設定哪裡出問題了。

圖中我把run.cmd改成run_service.cmd了,另外成功的跑了一些程序


接著就可以開始撰寫腳本了

name: 81-dev

on:
push:
branches:
- "dev"

env:
PROJECT_NAME: "81 dev"
PROJECT_FOLDER: "81c"
TELEGRAM_TOKEN: "tg_token"
TELEGRAM_CHAT_ID: "chat_id"

jobs:
build:
runs-on: ubuntu-latest # runs-on字段指定运行所需要的虚拟机环境。注意:这个是必填字段
steps:
- uses: actions/checkout@v3
- name: Setup Node 14
uses: actions/setup-node@v3.5.1
with:
node-version: "14"
cache: "npm"

- name: Install yarn
run: |
npm i -g yarn

- name: build
run: |
yarn
yarn build

- name: Upload a Build Artifact
uses: actions/upload-artifact@v4
with:
name: application
path: dist/**/*
deploy:
needs: build
runs-on: self-hosted

steps:
- name: remove old files
run: |
Remove-Item -Path D:\wwwroot\${{ env.PROJECT_FOLDER }}\static\* -Recurse -Force
Remove-Item -Path D:\wwwroot\${{ env.PROJECT_FOLDER }}\index.html -Force

- name: Download new binaries over the top of the app
uses: actions/download-artifact@v4
with:
name: application
path: D:\wwwroot\${{ env.PROJECT_FOLDER }}

notify:
needs: deploy
runs-on: ubuntu-latest
steps:
- name: telegram notify
run: |
curl -d '{"method": "sendMessage", "chat_id": "${{ env.TELEGRAM_CHAT_ID }}", "text": "${{ env.PROJECT_NAME }} deployed."}' -H "Content-Type: application/json" -X POST https://api.telegram.org/bot${{ env.TELEGRAM_TOKEN }}/



小結
這專案打包下來2.6mb,這樣扣除build跟上傳時間,僅算下載及佈版,時間都落在30秒內,算是非常快速跟滿意。
最終還是有個小問題,如果是在organization創建的runner那這self_hosted都會指向同一台,沒辦法多台或命名嗎?這之後再來研究吧


補充

上線問claude他這樣回答我

self-hosted runner 可以自訂命名和設定群組:

  1. 在 GitHub Actions 工作流程中指定特定的 runner:
  1. 設定 runner 時的命名和標籤:
# 基本設定命令格式 ./config.cmd --url https://github.com/{YOUR_USERNAME}/{YOUR_REPO} --token {YOUR_TOKEN} --name "MY-IIS-RUNNER" --labels prod-iis,windows,vue # 例如: ./config.cmd --url https://github.com/your-name/your-repo --token abcd1234 --name "PROD-IIS-01" --labels prod-iis,windows,vue

參數說明:

  • --name: runner 的名稱
  • --labels: runner 的標籤,可以設定多個,用逗號分隔
  • --work: 指定工作目錄 (預設是 _work)
  • --group: 指定 runner 群組
  1. 如果要修改現有的 runner:
# 1. 先移除現有的 runner 設定 ./config.cmd remove # 2. 重新設定 ./config.cmd --url https://github.com/{YOUR_USERNAME}/{YOUR_REPO} --token {YOUR_TOKEN} --name "NEW-NAME" --labels new-label-1,new-label-2
  1. 設定多環境範例:
# 正式環境 runner ./config.cmd --name "PROD-IIS-01" --labels prod-iis,windows,vue # 測試環境 runner ./config.cmd --name "TEST-IIS-01" --labels test-iis,windows,vue # 開發環境 runner ./config.cmd --name "DEV-IIS-01" --labels dev-iis,windows,vue

然後在工作流程中可以這樣使用:

jobs: deploy-prod: runs-on: [self-hosted, prod-iis] if: github.ref == 'refs/heads/main' # ... deploy-test: runs-on: [self-hosted, test-iis] if: github.ref == 'refs/heads/develop' # ... deploy-dev: runs-on: [self-hosted, dev-iis] if: github.ref == 'refs/heads/feature/*' # ...

有機會再來試吧


2024年11月6日 星期三

業界鬼故事第一彈

不知不覺已經四個月沒發文了,看標題就知道這次不是HD係列,只是小編走在路上不小心聽到的。

原本相安無事日子過得也是好不自在,偏偏小編最近家中換車,需要一大筆資金,剛好小編工作沒有勞健保,所以只能付全額,想起來就覺得可怕。所以只好出來多打一份工作。

正愁沒有案源,小編想到了一直以來的按摩師朋友,向來他還滿欣賞自己能力,最近又剛創業(!?),應該會有系統開發需求,所以馬上預約了一堂課,準備來個反推銷。

這過程就不贅述,絕對沒有各位想聽的抓龍筋故事,想當然耳反推銷是失敗收場,不然哪來的鬼故事。

這朋友我姑且稱他為老K

老K:「我們店已經有找到人來開發系統了。」

我:「那也不錯啊,開發得如何?」

老K:「別說了,開發到現在四個月,我測一次錯一次,我要的功能也沒幾個,有個客人連三次使用都出錯,我到現在還是紙本作業」

我:「那幹嘛不換人(選我選我!)」

老K:「對方是老闆好朋友啊」

我:「那也只能祝你好運」

老K:「我跟你講有多扯,先講個最扯的,這個月初他把資料清空了,我問他有沒有備份,他說有的,然後他反問我有沒有紙本備份,我說都有系統了我用紙本幹嘛,他反倒怪我為什麼不用紙本備份!」

我:「......聲先奪人,高明!你老闆跟他真的是好朋友嗎?」

老K:「我們按摩師賣多少課,抽成這很正常吧,假設五成,1800課按摩師賺900,1400按摩師賺700,這應該很合理吧,上次開會老闆把我叫去罵,說你這樣系統會很難計算。我雖然不是學程式的,但不就是除以2而已嗎?這有很難嗎?」

我:「......他們真的是好朋友,我第一次聽到老闆幫工程師罵客人的!」

老K:「還有我們創建客戶理論上就照創建日期排列,他也是這樣告訴我的,結果我實際去看,我後來創建的排在中間,我說能不能照順序排,他竟然回答我不能,這要另外寫,要開發時間,正常不是要可以選擇用什麼排列嗎」

我:「我已經不知到要從哪裡吐槽了」

老K:「還有一個很扯,我們通常都使用掃QRCode扣課,必須在他的app介面才能掃,然後只能正著掃,橫著掃跟倒著掃都掃不出東西,如果用一般掃條碼的app掃會掃出客戶電話號碼」

因為大部分我的回答都是...所以就省略

老K:「還有他有一份excel可以計算薪水,只有客戶用qrcode掃課才能真的扣課,按摩師薪水才會計算上去,如果在後台手動扣課,excel不會更新,這樣數據肯定是錯的吧」

老K:「我們要去辦信用卡機,他還跟老闆打包票說他辦過絕對沒問題,最後來來回回送件了好幾次終於辦下來,結果一個客人刷卡完,我進後台看怎麼沒入帳,過一週後還是沒入帳,我就打給業務員,業務員開後台確認是有入帳的,最後確認到問題是他幫我申請的是線上刷卡的帳戶,不能在線下使用。那證明他根本就沒辦過嘛,好在他沒有把金流跟系統做整合」

老K:「他寫完的東西自己都沒在測試的,都直接交給我們,我也沒有特別刁難他,但真的是用一次錯一次」

老K:「而且你跟他講問題,他永遠不會正面回答你,例如上週他問我使用狀況,我列了五點給他,他只回我我再看看,你倒是告訴我你什麼時間點會修好什麼東西啊==」

我也只能一路聽他抱怨,我甚至有點可憐他想幫他重新寫一個,他過程一直問我這些功能如果是我要開發多久,我回答一週吧,真的是沒有很複雜的功能,只能說對方是我聽過的奇耙之一,這故事也再次證明了,寫程式很強真的沒什麼用,後台要夠硬才是硬道理!

最後大家如果同情老K可以到他店裡消費,按摩技術真的不錯,人在台中,有興趣可以留言給我