鍾永豐《菊花如何夜行軍》:若美濃的現代化過程是一部大河小說,卷首詩應該就是〈縣道一八四〉

鍾永豐《菊花如何夜行軍》:若美濃的現代化過程是一部大河小說,卷首詩應該就是〈縣道一八四〉
美濃菸田的一處。Photo Credit: lienyuan lee CC by 3.0

我們想讓你知道的是

循著鍾永豐的散文,我們彷彿聆聽一曲又一曲農村變遷民謠。一位農村出身的青年,走向反抗者、創作者、政治工作,仍掛心鄉土,這是一本引領讀者反思土地、自我與全球化的散文集。

牛終於聽我使喚的時候,補了一年高中聯考還是慘敗的永榮哥只剩下五專可念。他騎自轉車載我到縣道一八四上的客運巴士站,我背著他的行李。三、四個他那個年次上下的高中生,背著「省立雄中」、「省鳳高中」的明星高中書包,直挺挺地站在站牌下,彼此並不交談。另外兩、三個沒背書包的,也只跟永榮哥對看一眼,便把臉別開。

奇怪,在河裡捉迷藏、在稻田裡打棒球的時候,這些人不是與永榮哥共陣的嗎?怎麼換上校服,站到巴士站下,就都變成一臉冷漠?

「阿豐,牛交給你了。」永榮哥打好車單,頭犁犁地接過行李。

我心底彆扭,送不出話。

寬寬的縣道一八四路肩,芒草已疏疏稀稀地抽出花穗,一群我們叫作「嗶嗶噹」的小鳥,從尚未收割的稻田升空,乘著波浪型的弧線,朝河邊的竹林叢飛去。縣道一八四也換了另一副臉;畢竟它不是做來放牛的。現在它是長又直的溜滑梯,永榮哥坐上客運巴士,就要滑到很遠很遠的地方。

永榮哥放假回來,我們仍一同放牛、割草。但他不再講牛經了,說來說去都是他在城裡帶領外省眷村子弟跟閩南學生打群架的自豪事蹟。

「永榮哥,外省人是誰?」我不想讓他失望,隨便問問。

「外省人跟我們一樣,是客家人的一種,只是他們講國語。」

真好!他們不用擔心忘了講國語被罰;我們班上每天都有人脖子上掛狗牌。

「那你講方言他們罰你錢嗎?」

「哈,我現在國語講得比他們還標準,還有人問我是哪一省人?」

「那你怎麼說?」

「我說我是廣東省人。」永榮哥非常得意。

我掉了興趣;不懂眷村跟我們庄頭的共通處,也討厭打架。唯一引我興趣的,是他說校慶參加吃西瓜比賽,得了冠軍。這我有信心;我在學校吃營養午餐,從沒慢過任何人。

第一個暑假之後,永榮哥回來的頻率漸稀,庄裡跟他同年次的後生也一樣;外面的都市化與工業化如火如荼,他們之中的大部分我再也沒見過。他們為人憶起或談論的方式因人而異;離鄉後在考試戰場上過關斬將的,傳頌為模範,敗考後混跡江湖的,也被用以教示後代。都逃不掉。

「阿進伯的兒子考上研究所了,真好樣勢!」

「阿乾叔的女兒考過高考了,有橫桌好坐了。」

「橫桌」即辦公桌,是脫離農業的最高象徵。每當庄裡有人考上第一志願學校,大概就知道晚餐時大人準要唸這些「好樣勢」給我們這些後生小人聽,讓滿桌飯菜立即變得沒鹹沒甜。

「阿豐,再讀毋識書,你就當人腳猴了!」母親的廚藝是族中最厲害的,可一旦她開口教勉,滿桌菜餚頓然失味。

在社會上被人踩在腳底的,稱「人腳猴」。家族中有幾位「讀得識書」的同輩人,一路第一名,最後都如願進了公家。看到他們,耳邊就會響起母親的話。我反倒關心跟永榮哥一樣,「讀毋識書」的人;我的遊耍功夫畢竟是他們傳授給我的。照布袋戲裡的武林規矩,他們便是我師父了。

庄裡的人很少聊到他們,偶而談到也都帶著酸度很高的口水,或預報壞天氣般的口吻。他們的消息若在一、兩天之內傳開,那動力一定來自於巨大的不幸。

阿宏的消息與身體就是這樣沿著縣道一八四送回來的。

永榮哥出庄念專校前兩年,菸苗剛種完的一個週六下午,他喚我去找阿宏。我在坡面上的中藥店門口找到阿宏。他閒著,用橡皮筋打蒼蠅,旁邊有兩批人馬正在玩橡皮筋。我想,憑阿宏的武功,這些人一定是不敢讓他下場。

「阿宏哥,我堂哥要尋你單劈。」我故作莊重地傳令,立刻就引起了不小的騷動,正如我意。

「在哪兒?」阿宏目珠晶亮,像貓在夜裡。

「土地公後面的菸樓。」

「隨到!」阿宏的答話冷又短,真不愧是高手。

我趕緊回家通報。永榮哥叫我把牛牽到芒果樹下釘樁綁住,免得大人發現牛沒人照料。一般的比賽規矩是在牆角下劃一個十五公分見方的正方形框,並在一公尺外劃條直線,平行於牆面。雙方把議定的橡皮筋置於框內,然後站在線外朝框內的橡皮筋輪流發射。只要把一條橡皮筋打出框外,就贏了。準度不好的人要不是無用地打出一大堆,便是射進橡皮筋堆裡,變成賭注。

比賽人數通常是三至五人,每人五十條橡皮筋算是很大的賭注了。那天永榮哥把整季的戰利品一千多條橡皮筋全帶上;十條橡皮筋一塊錢,以本庄孩子的口袋衡量,算是富豪了。在電視布袋戲的年代裡我們沒有刀劍又不會神功,因此我很果斷地認為,永榮哥跟他進行的是一場真正的武林決鬥;永榮哥代表白道,阿宏代表西域魔道。

「阿宏,三百條好嗎?」

「赫,三百條!」圍觀的人群抖了一下,立即肅靜。

「嗯!」又是冷短的回答。

永榮哥從牆邊向外跨了四大步,然後欺身用碎瓦片在水泥地上劃條直線。哇,兩公尺半,這可是神射手的距離!

「這樣好嗎?」

「嗯!」

六百條橡皮筋堆起來足足有一個掌幅高。他們還加上一個新的規定,沒打到橡皮筋的就算輸了。這更拉緊了氣氛。

雙方猜拳,永榮哥先打。

他彎身,右膝跪地,橡皮筋拉長,吸氣,瞄準,閉氣,射出。

真準!永榮哥把面頂的兩條打了出來,照規定必須擺回去,而且不能觸及其他橡皮筋。阿宏走上前,右腳踩線緣,左腳向後跨半步,簡單瞄了一下就出手。

「阿母喲!」幾個跟我同年的小孩發出驚嘆。

阿宏射中擺回去的兩條橡皮筋,那兩條橡皮筋彈起來撞牆,一條彈入框內,另一條跳了出來。阿宏贏了第一盤。


猜你喜歡


挖掘雲端開放架構優勢!Amazon EKS高可用性叢集快速部署容器

挖掘雲端開放架構優勢!Amazon EKS高可用性叢集快速部署容器

我們想讓你知道的是

企業如何在 Amazon EKS(Elastic Kubernetes Services)上使用 GitLab 創建自動化部署,減輕人力負擔,提升專案服務運作效率?

所謂現代化智慧 IT,所有工程師最希望的境界,莫過於只要輕鬆點幾下設定,系統就會自動跑起來,管理者再也不用隨時待命在機台旁邊,從此工作悠哉又快樂!儘管這樣情境還沒到來,但隨著敏捷式開發的流行,除了 DevOps 人員,有越來越多開發者將 CI/CD 概念融入到工作流程當中,例如從 build code、執行 unit test、到部署應用程式。

透過 AWS 增加雲端技能 在組織發揮影響力

上述種種反覆步驟自動化執行,也就能提昇服務品質、主動通知開發人員以減輕人力負擔,讓專案服務能持續運作。

其中,GitLab 是執行 CI/CD 常用的工具之一,也是開發者使用程式碼儲存庫的地方。為了讓 GitLab Runner 在雲端快速實踐 CI/CD,《AWS 開發者系列》透過影片分享,如何在 Amazon EKS(Elastic Kubernetes Services)上使用 GitLab 創建自動化部署。

以下節錄工作坊影音內容,幫助開發者快速理解如何運用 Amazon EKS 的高可用性且安全的叢集,將修補、部署節點、更新等關鍵任務,全部做到自動化設定。同時影片也會示範 Amazon EKS 搭配 GitLab 如何展開自動部署,幫助工程團隊實踐 CI/CD 價值。

Amazon EKS 對容器管理輕鬆簡單、維運省時省力

容器化服務越來越興盛,當容器(Container)越來越多,在複雜的微服務(Microservice)系統環境之下,運維團隊的管理成本可能相對會增加不少,為了有效調度容器部署, 導入Kubernetes 無疑是近年企業熱門的話題之一。

建構 Kubernetes Cluster 流主要可區分兩大塊,一是安排容器調度的Control Plane、另一則是容器運行時需要用到的 Worker Node。

Control Plane 裡面涵蓋有儲存狀態的 ETCD、CoController manager 、Scheduler 的調度管理、甚至是操作時進行互動的 APIServer,若是自己創建 的 Kubernetes Cluster ,需要自己安裝這些元件,後續仍需要對 Control Plane 進行相關管理、維護、升級工作。為了減少上述 Components 的繁複維護,在透過 AWS EKS 代管的 Kubernete Control Plane 部可以獲得以下三大好處。

Amazon EKS 一鍵式部署,展現三大優勢

第一,Amazon EKS代管的 Control Plane實踐了跨AZ的高可用部署,使用者不需要擔心單一節點故障的風險。

第二,Amazon EKS 支持至少四個 Kubernetes版本,持續跟進每季 CNCF 的發佈,同時 EKS 也完全符合上游 CNCF 規範。

第三,部署 Amazon EKS 之後,可直接使用 AWS 平台上現成的服務工具,在安全性管理、網路設定方面,可以做到無縫整合。

最後 AWS 台灣解決方案架構師也提到,若想在容器環境進行 CI/CD 及應用程式的管理,可以進一步透過 IaC 整合部署 Amazon EKS 叢集,透過使用 Console、把 EKS 變成 Cloudformation 的模板、使用 AWS 所開發出來的 eksctl.io、或指令是採用 AWS CDK 可以讓開發者用自身熟悉的語言,在 AWS 平台整合 CI/CD 工具進行維運及部署 EKS。

打造第一個在 AWS 上的應用程式

了解 Amazon EKS 整合 GitLab ,獲得三面向價值

對開發者而言,想把 Amazon EKS 整合到 CI/CD 工具之一的 GitLab 平台上,可以看到那些實際的優勢?

在 DevOps 開發者示範工作坊當中,GitLab 資深解決方案架構師指出,GitLab 使用到 Kubernetes 技術,主要有三種搭配方法,包含 GitLab Server、GitLab Runner、以及創建 Deployment Environment。

本次示範教學會主要聚焦在 GitLab Runner 如何採取 Auto-scaled 方式進行 Build、Test、Package Apps;以及在 Deployment Environment 運用 Kubernetes 技術,做到 Auto Deploy、Review App。

正因為 Amazon EKS 能夠在 DevOps 過程提供所需要的彈性計算資源,幫助開發者在 GitLab 平台上面獲得以下三個層次的優勢:

  • 在 GitLab 內建的部署工作流程當中,自動生成整套 CI/CD 最佳實踐腳本。
  • Review App 過程,從 Merge Request 中可直接訪問應用程式 /App 的 UI 介面,並且根據 Git branch 名稱、專案名稱,自動生成 Review App 的 URL,以及在 Merge 前的最後防線進行 Approval 檢查。
  • 加速 CI/CD 流水線,GitLab Runner 運行時候還可藉由 Amazon EKS Cluster 進行 Auto-scaled 的支援。

Amazon EKS 整合 GitLab ,需要兩大流程

影片最後,GitLab 資深解決方案架構師示範如何把 Amazon EKS 整合至 GitLab 執行 Auto Deploy,主要可分為兩大區塊流程,第一部分聚焦在 Amazon EKS cluster 的設置,第二部分則執行 Auto Deploy 設置。

第一塊可拆分為四個階段,首先教學怎麼創建 EC2 節點的 EKS cluster,第二階段示範把 EKS Cluster 連接到開發者的 GitLab Instance、Group 或 Project,下一步則使用 Cluster Management Project Template 創建一個 Cluster Management Project,以及最後一階段透過 Cluster Management Project 自帶的 Helm Chart,安裝在 Cluster 所需要的內建 App。

第二塊執行 Auto Deploy 設置,針對需要部署的 App 創建一個 GitLab Project,接著再把 gitlab-ci.yml 添加到 Project,並從 Web IDE 選擇及導入 Auto Deploy 的 CI 模版,讓 GitLab 自動生成最佳實踐的整套流水線。

幫助開發者更了解 Amazon EKS 整合 GitLab 的 QA 系列

Q:使用 Amazon EKS 之後,如何更有效率或優化資源去配置 Worker Node 的機器數量,以及如何有效空管開發維運的成本?

A:Kubernetes 除了本身有 HPA(Horizontal Pod Autoscaling)可根據使用程度自動調整資源流量,另外也能延伸使用 AWS Auto Scaling 方案,針對可擴展資源去設定自動擴展管理。另外在成本管控,雖然 Amazon EKS 會收取額外管理費用,但可透過 AWS 平台的 Calculato r計算每個 EKS 的價格,你會發現自動化部署及管理的費用,相對工程師人力的成本更加便宜。

Q:越來越多客戶考慮把現有 Application 變成容器部署,大多是爲了加快部署的效率,那麼變成容器模式之後,對 CI/CD 的工作流程有什麽影響嗎?

A:運用容器技術最直接的效果,可以讓應用程式的環境更一致化,例如 testing 環節、stage production,讓容器避開一些差異問題。至於 CD 部分要 delivery 一些 usage 不太一樣的時候,容器會幫忙做配置,所以 CI/CD 對容器的效益是相輔相成的。

Q: 客戶在開發流程漸漸會把 Infrastructure 變成代碼或文檔,是不是可以把程式碼跟現有的應用程式的 CI/CD 流水線整合在一起,達到一套完整的 CI/CD 部署流程?

A:觀察目前市場作法,主要分成兩個階段去做整體部署。如果規模比較小的團隊,會把 Infrastructure 代碼跟 App 代碼分開,在管理上會比較靈活;如果企業規模比較大,會有另外一個 Infrastructure 團隊來控制部署事情,這種情况之下,APP 的項目會生成一個 APP package,主要做到 delivery 這個階段爲止。而 Infrastructure 的項目會指定把需要版本的文檔,部署到他們的 Kubernetes Cluster。

填寫表單 找到適合的快速上雲服務與工具!


猜你喜歡