<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Container - 東東 GCP 教學 - GCP 實戰講師</title>
	<atom:link href="https://dongdonggcp.com/tag/container/feed/" rel="self" type="application/rss+xml" />
	<link>https://dongdonggcp.com</link>
	<description>助你考取證照，轉職成功</description>
	<lastBuildDate>Sun, 20 Jul 2025 08:41:05 +0000</lastBuildDate>
	<language>zh-TW</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=7.0</generator>

<image>
	<url>https://dongdonggcp.com/wp-content/uploads/2025/04/cropped-340838097_121391010914395_5443948698124160121_n-32x32.jpg</url>
	<title>Container - 東東 GCP 教學 - GCP 實戰講師</title>
	<link>https://dongdonggcp.com</link>
	<width>32</width>
	<height>32</height>
</image> 
<site xmlns="com-wordpress:feed-additions:1">243235092</site>	<item>
		<title>儲存容器映像檔的 Artifact Registry 簡介與上傳 Docker 映像檔教學</title>
		<link>https://dongdonggcp.com/2025/07/20/artifact-registry-tutorials/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=artifact-registry-tutorials</link>
					<comments>https://dongdonggcp.com/2025/07/20/artifact-registry-tutorials/#respond</comments>
		
		<dc:creator><![CDATA[admin]]></dc:creator>
		<pubDate>Sun, 20 Jul 2025 08:18:56 +0000</pubDate>
				<category><![CDATA[無伺服器]]></category>
		<category><![CDATA[Artifact Registry]]></category>
		<category><![CDATA[Container]]></category>
		<category><![CDATA[Docker]]></category>
		<category><![CDATA[Docker Image]]></category>
		<category><![CDATA[Nodejs]]></category>
		<guid isPermaLink="false">https://dongdonggcp.com/?p=11173</guid>

					<description><![CDATA[<p>Artifact Registry 是 Google Cloud 中專門的容器映像檔儲存庫，除了 Docker 映像外，還支援 Maven Artifacts（Java）、Npm Packages、Python Packages、Helm Charts 等等。</p>
<p>The post <a href="https://dongdonggcp.com/2025/07/20/artifact-registry-tutorials/">儲存容器映像檔的 Artifact Registry 簡介與上傳 Docker 映像檔教學</a> first appeared on <a href="https://dongdonggcp.com">東東 GCP 教學 - GCP 實戰講師</a>.</p>]]></description>
										<content:encoded><![CDATA[<h2 class="wp-block-heading">Artifact Registry 簡介</h2>



<p class="wp-block-paragraph"><a href="https://www.googleadservices.com/pagead/aclk?sa=L&amp;ai=DChsSEwirsLTv_8qOAxXG2kwCHfITEJUYACICCAEQABoCdG0&amp;ae=2&amp;aspm=1&amp;co=1&amp;ase=2&amp;gclid=CjwKCAjwp_LDBhBCEiwAK7FnkhBSGGOAMvfHjawzthiFks7mErP8ixTosby2sEBJ0rz1lMGqoZSP2hoCfmAQAvD_BwE&amp;ohost=www.google.com&amp;cid=CAESV-D27f6HJLfY8fRQo7vyEJc-amuEDVvDvj7wVTm5UcHc2tc7-ZWroRb6nEiYHrpBHGo0vZXo4tcWYIOvM2iBxdUY17ArpWhXU9tGYG691bXGAlbxMry-5w&amp;category=acrcp_v1_47&amp;sig=AOD64_0OiELFeAQRJRqxZXvfz8ZOPSb8VQ&amp;q&amp;nis=4&amp;adurl&amp;ved=2ahUKEwjL0a_v_8qOAxUch68BHYbNGZkQ0Qx6BAgOEAE" target="_blank" rel="noopener" title="">Artifact Registry </a>是 Google Cloud 中專門的容器映像檔儲存庫，當時在 Artifact Registry 推出之前，己經有 Container Registry，但 Container Registry 只支援 <a href="https://www.docker.com/" target="_blank" rel="noopener" title="">Docker</a> 映像檔，並且功能較為簡單，也沒有細緻的權限管理機制，所以 Google 在 2020 年推出 Artifact Registry，作為 Container Registry 的全面升級。</p>



<p class="wp-block-paragraph">Artifact Registry 除了 Docker 映像外，還支援 Maven Artifacts（Java）、Npm Packages、Python Packages、Helm Charts 等等。</p>



<h2 class="wp-block-heading">建立容器映像檔示範</h2>



<h3 class="wp-block-heading">準備 Nodejs 程式檔案</h3>



<p class="wp-block-paragraph">接著我們就開始打造一個容器映像檔，並上傳到 Artifact Registry 吧！</p>



<p class="wp-block-paragraph">首先我們一樣開啟 Cloud Shell，建立一個資料夾例如 nodejs01，然後先建立第一個檔案 server.js</p>



<pre class="wp-block-code"><code>var http = require('http');
var handleRequest = function(request, response) {
  response.writeHead(200);
  response.end("Hello World from Dongdong Nodejs!!");
}
var www = http.createServer(handleRequest);
www.listen(8080);
</code></pre>



<p class="wp-block-paragraph">然後測試程式能否運作，輸入 node server.js，可以點擊預覽網頁的按鈕，看看網頁是否秀出內容：</p>



<figure class="wp-block-image aligncenter size-large"><img fetchpriority="high" decoding="async" width="1024" height="495" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-1-程式執行和預覽-1024x495.png" alt="" class="wp-image-11174" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-1-程式執行和預覽-1024x495.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-1-程式執行和預覽-300x145.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-1-程式執行和預覽-768x371.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-1-程式執行和預覽-1536x742.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-1-程式執行和預覽.png 1884w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">執行 Nodejs 程式並預覽網頁</figcaption></figure>



<h3 class="wp-block-heading">準備 Dockerfile</h3>



<p class="wp-block-paragraph">如果確認沒問題，再按下 ctrl + C 取回游標，接著準備第二個檔案 Dockerfile 內容如下：</p>



<pre class="wp-block-code"><code>FROM node:6.9.2
EXPOSE 8080
COPY server.js .
CMD node server.js
</code></pre>



<p class="wp-block-paragraph">Dockerfile 是說明檔，告訴 Docker 要如何打包這個 Image，包含這個容器使用什麼程式語言、對外開放哪個 Port、程式的檔案在哪裡、用什麼指令來跑程式等等。</p>



<p class="wp-block-paragraph">現在我們已經準備好兩個檔案如下：</p>



<figure class="wp-block-image aligncenter size-full"><img decoding="async" width="981" height="230" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-2-確認目前準備好兩個檔案.png" alt="" class="wp-image-11175" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-2-確認目前準備好兩個檔案.png 981w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-2-確認目前準備好兩個檔案-300x70.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-2-確認目前準備好兩個檔案-768x180.png 768w" sizes="(max-width: 981px) 100vw, 981px" /><figcaption class="wp-element-caption">確認目前準備好兩個檔案</figcaption></figure>



<h3 class="wp-block-heading">建立 Artifact Registry 存放區</h3>



<p class="wp-block-paragraph">接著我們回到 Google Cloud Console，去 Artifact Registry 建立一個存放區：</p>



<figure class="wp-block-image aligncenter size-large"><img decoding="async" width="1024" height="547" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-3-建立-Artifact-Registry-存放區-1024x547.png" alt="" class="wp-image-11176" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-3-建立-Artifact-Registry-存放區-1024x547.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-3-建立-Artifact-Registry-存放區-300x160.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-3-建立-Artifact-Registry-存放區-768x410.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-3-建立-Artifact-Registry-存放區-1536x820.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-3-建立-Artifact-Registry-存放區.png 1865w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">建立 Artifact Registry 存放區</figcaption></figure>



<p class="wp-block-paragraph">我們命名「nodejs-1」，格式選擇 Docker，Region 選在 asia-east1，再按下「建立」。 完成之後就會看到它顯示在存放區的列表：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="653" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-4-設定名稱、格式和儲存位置-1024x653.png" alt="" class="wp-image-11177" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-4-設定名稱、格式和儲存位置-1024x653.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-4-設定名稱、格式和儲存位置-300x191.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-4-設定名稱、格式和儲存位置-768x490.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-4-設定名稱、格式和儲存位置-1536x980.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-4-設定名稱、格式和儲存位置.png 1682w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">設定映像檔存放區的名稱、格式和儲存位置</figcaption></figure>



<h3 class="wp-block-heading">取得憑證</h3>



<p class="wp-block-paragraph">點擊「設定操作說明」，它會開啟一個視窗，並提供一個 gcloud 指令，把它複製起來，這樣之後才能從 Cloud Shell 直接推送映像檔上去：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="389" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-5-設定-gcloud-為憑證輔助程式-1024x389.png" alt="" class="wp-image-11178" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-5-設定-gcloud-為憑證輔助程式-1024x389.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-5-設定-gcloud-為憑證輔助程式-300x114.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-5-設定-gcloud-為憑證輔助程式-768x292.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-5-設定-gcloud-為憑證輔助程式-1536x584.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-5-設定-gcloud-為憑證輔助程式.png 1896w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">設定 gcloud 為憑證輔助程式</figcaption></figure>



<p class="wp-block-paragraph">直接將指令貼到 Cloud Shell 並執行，等它完成即可，你會看到它說 gcloud credentials 註冊成功：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="503" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-6-等待指令執完成-1024x503.png" alt="" class="wp-image-11179" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-6-等待指令執完成-1024x503.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-6-等待指令執完成-300x147.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-6-等待指令執完成-768x377.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-6-等待指令執完成-1536x754.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-6-等待指令執完成.png 1788w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">等待指令執完成</figcaption></figure>



<h3 class="wp-block-heading">建立 Docker 容器映像檔</h3>



<p class="wp-block-paragraph">接下來準備 Docker image 的完整名稱，它同時也是存放在 Artifact Registry 的路徑，格式如下：</p>



<p class="wp-block-paragraph">[位置]/[project-id]/[repo_name]/[image_name]:v1</p>



<p class="wp-block-paragraph">我的映像檔名字就像這樣：</p>



<p class="wp-block-paragraph">asia-east1-docker.pkg.dev/dong-dong-gcp-2-bigquery/nodejs-1/nodejs-web:v1</p>



<p class="wp-block-paragraph">準備好之後，就執行以下指令：</p>



<p class="wp-block-paragraph">docker build -t&nbsp; [位置]/[project-id]/[repo_name]/[image_name]:v1</p>



<p class="wp-block-paragraph">我的範例指令：</p>



<p class="wp-block-paragraph">docker build -t asia-east1-docker.pkg.dev/dong-dong-gcp-2-bigquery/nodejs-1/nodejs-web:v1 .&nbsp;</p>



<p class="wp-block-paragraph">你注意指令最後有一個句點，代表要把當前資料夾 (nodejs01) 內的檔案都打包進這個映像檔。</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="425" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-7-建立容器映像檔-1024x425.png" alt="" class="wp-image-11180" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-7-建立容器映像檔-1024x425.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-7-建立容器映像檔-300x125.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-7-建立容器映像檔-768x319.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-7-建立容器映像檔-1536x638.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-7-建立容器映像檔.png 1866w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">建立容器映像檔</figcaption></figure>



<h3 class="wp-block-heading">測試 Docker Image 運作</h3>



<p class="wp-block-paragraph">我們再直接使用 Image 跑一次容器，確認應用程式正常</p>



<p class="wp-block-paragraph">docker run -d -p [port]:[port] [位置]/[project-id]/[repo_name]/[image_name]:v1</p>



<p class="wp-block-paragraph">我的範例指令：</p>



<p class="wp-block-paragraph">docker run -d -p 8080:8080 asia-east1-docker.pkg.dev/dong-dong-gcp-2-bigquery/nodejs-1/nodejs-web:v1&nbsp;&nbsp;&nbsp;&nbsp;</p>



<p class="wp-block-paragraph">參數 -d ，指的是背景執行</p>



<p class="wp-block-paragraph">參數 -p 8080:8080 ，指的是把主機的 8080 Port 所有流量轉發到 web 這個Container 的 8080 Port</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="70" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-8-確認容器已開始運作-1024x70.png" alt="" class="wp-image-11181" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-8-確認容器已開始運作-1024x70.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-8-確認容器已開始運作-300x21.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-8-確認容器已開始運作-768x53.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-8-確認容器已開始運作-1536x105.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-8-確認容器已開始運作.png 1869w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">確認容器已開始運作</figcaption></figure>



<p class="wp-block-paragraph">然後我們點擊 Cloud Shell 視窗右上角的預覽按鈕，可以看到網頁已經正常顯示：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="531" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-9-確認能看到網頁-1024x531.png" alt="" class="wp-image-11182" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-9-確認能看到網頁-1024x531.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-9-確認能看到網頁-300x156.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-9-確認能看到網頁-768x398.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-9-確認能看到網頁-1536x797.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-9-確認能看到網頁.png 1677w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">確認能看到網頁</figcaption></figure>



<h3 class="wp-block-heading">停止 Docker 應用程式</h3>



<p class="wp-block-paragraph">確認無誤的話，我們要停止 Container 運作之前，要先查詢目前正在運作 Container 的 ID：&nbsp;</p>



<p class="wp-block-paragraph">docker ps&nbsp;</p>



<p class="wp-block-paragraph">取得 ID 之後，停止指定的 Container</p>



<p class="wp-block-paragraph">docker stop [container-id]</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="233" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-10-停止容器運作-1024x233.png" alt="" class="wp-image-11183" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-10-停止容器運作-1024x233.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-10-停止容器運作-300x68.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-10-停止容器運作-768x175.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-10-停止容器運作-1536x349.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-10-停止容器運作.png 1808w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">停止容器運作</figcaption></figure>



<h2 class="wp-block-heading">推送 Docker Image 到 Artifact Registry</h2>



<p class="wp-block-paragraph">現在就可以正式 Push Docker Image 到 Artifact Registry 了，執行以下指令：</p>



<p class="wp-block-paragraph">docker push [位置]/[project-id]/[repo_name]/[image_name]:v1</p>



<p class="wp-block-paragraph">我的範例指令：</p>



<p class="wp-block-paragraph">docker&nbsp; push asia-east1-docker.pkg.dev/dong-dong-gcp-2-bigquery/nodejs-1/nodejs-web:v1 &nbsp;</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="347" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-11-映像檔推送完成-1024x347.png" alt="" class="wp-image-11184" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-11-映像檔推送完成-1024x347.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-11-映像檔推送完成-300x102.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-11-映像檔推送完成-768x261.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-11-映像檔推送完成-1536x521.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-11-映像檔推送完成.png 1851w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">映像檔推送完成</figcaption></figure>



<p class="wp-block-paragraph">我們看到映像檔已經推上去了，我們可以回到 Console 上按重新整理：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="621" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-12-在-Console-上看到映像檔出現了-1024x621.png" alt="" class="wp-image-11185" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-12-在-Console-上看到映像檔出現了-1024x621.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-12-在-Console-上看到映像檔出現了-300x182.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-12-在-Console-上看到映像檔出現了-768x466.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-3-12-在-Console-上看到映像檔出現了.png 1523w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">在 Artifact Registry 上看到映像檔出現了</figcaption></figure>



<p class="wp-block-paragraph">現在我們有一個映像檔在上面，之後就可以部署到 <a href="https://dongdonggcp.com/2025/07/20/cloud-run-tutorials/" target="_blank" rel="noopener" title="">Cloud Run</a> 或 <a href="https://dongdonggcp.com/2025/07/20/google-kubernetes-engine-tutorials/" title="">Google Kubernetes Engine</a> 囉！</p>



<p class="wp-block-paragraph">影片版教學：</p>



<figure class="wp-block-embed is-type-video is-provider-youtube wp-block-embed-youtube wp-embed-aspect-16-9 wp-has-aspect-ratio"><div class="wp-block-embed__wrapper">
<div class="ast-oembed-container " style="height: 100%;"><iframe title="[GKE 教學] 031 Artifact Registry 教學，如何在 GCP 上建立第一個 Docker 容器映像檔 Container Image？| 免費下載 GKE 簡報、完整指令和程式碼" width="1200" height="675" src="https://www.youtube.com/embed/6DHUC-MZ34U?feature=oembed" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe></div>
</div></figure><p>The post <a href="https://dongdonggcp.com/2025/07/20/artifact-registry-tutorials/">儲存容器映像檔的 Artifact Registry 簡介與上傳 Docker 映像檔教學</a> first appeared on <a href="https://dongdonggcp.com">東東 GCP 教學 - GCP 實戰講師</a>.</p>]]></content:encoded>
					
					<wfw:commentRss>https://dongdonggcp.com/2025/07/20/artifact-registry-tutorials/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">11173</post-id>	</item>
		<item>
		<title>Google Kubernetes Engine 是什麼？GKE 簡介與手把手操作教學</title>
		<link>https://dongdonggcp.com/2025/07/20/google-kubernetes-engine-tutorials/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=google-kubernetes-engine-tutorials</link>
					<comments>https://dongdonggcp.com/2025/07/20/google-kubernetes-engine-tutorials/#respond</comments>
		
		<dc:creator><![CDATA[admin]]></dc:creator>
		<pubDate>Sun, 20 Jul 2025 05:20:24 +0000</pubDate>
				<category><![CDATA[Google Kubernetes Engine]]></category>
		<category><![CDATA[CI/CD]]></category>
		<category><![CDATA[Container]]></category>
		<category><![CDATA[DevOps]]></category>
		<category><![CDATA[Docker]]></category>
		<category><![CDATA[GKE]]></category>
		<category><![CDATA[Kubernetes]]></category>
		<category><![CDATA[容器]]></category>
		<guid isPermaLink="false">https://dongdonggcp.com/?p=11119</guid>

					<description><![CDATA[<p>Google Kubernetes Eengine 是 Kubernetes 在 GCP 的雲端加值版本，可以讓你的 Kubernetes 在管理 Docker 容器應用程式的時候，更方便好用。</p>
<p>The post <a href="https://dongdonggcp.com/2025/07/20/google-kubernetes-engine-tutorials/">Google Kubernetes Engine 是什麼？GKE 簡介與手把手操作教學</a> first appeared on <a href="https://dongdonggcp.com">東東 GCP 教學 - GCP 實戰講師</a>.</p>]]></description>
										<content:encoded><![CDATA[<p class="wp-block-paragraph">Google Kubernetes Eengine 是 Kubernetes 在 GCP 的雲端加值版本，可以讓你的 Kubernetes 在管理 Docker 容器應用程式的時候，更方便好用。</p>



<p class="wp-block-paragraph">假如你本來就已經會使用容器技術，例如 Docker，可以使用虛擬機器或是 <a href="https://dongdonggcp.com/2025/07/20/cloud-run-tutorials/" target="_blank" rel="noopener" title="">Cloud Run</a> 來運作容器應用程式，但當我們的系統變得更加複雜時，我們可能需要更強大的工具來管理整個應用程式生態系統。</p>



<p class="wp-block-paragraph">這時候就需要「容器編排」技術了。編排（Orchestration）這個詞來自音樂領域，就像指揮家需要協調管弦樂團中的各種樂器，讓他們在正確的時間演奏正確的音符，最終產生和諧的音樂一樣，容器編排就是自動化協調和管理複雜系統中多個容器元件的過程。它負責決定哪些容器應該在哪裡運行、如何分配資源、確保容器間的通訊，以及根據需求自動擴展或縮減容器數量。</p>



<h2 class="wp-block-heading">Kubernetes 簡介</h2>



<h3 class="wp-block-heading">為什麼需要 <a href="https://kubernetes.io/" target="_blank" rel="noopener" title="">Kubernetes</a>？</h3>



<p class="wp-block-paragraph">想像一下，你正在經營一家大型的線上商店。最初，你可能只有一個簡單的網站容器在運行，這時 Cloud Run 就足夠了。但隨著業務成長，你的系統開始變得複雜：</p>



<ul class="wp-block-list">
<li>前端網站需要與後端 API 服務通訊</li>



<li>需要負載平衡來分配流量</li>



<li>某些服務需要定期備份和更新</li>



<li>不同的服務有不同的資源需求</li>



<li>需要監控各個環節的健康狀態</li>
</ul>



<p class="wp-block-paragraph">這時候，單純使用多個獨立的容器服務就變得難以管理。你需要手動協調各個服務之間的通訊、處理故障恢復、管理各種設定檔和機密資訊等等。這就是 Kubernetes 要解決的問題。</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="683" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-1-單個容器獨立管理因數量變多導致工作繁重-1024x683.jpg" alt="" class="wp-image-11120" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-1-單個容器獨立管理因數量變多導致工作繁重-1024x683.jpg 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-1-單個容器獨立管理因數量變多導致工作繁重-300x200.jpg 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-1-單個容器獨立管理因數量變多導致工作繁重-768x512.jpg 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-1-單個容器獨立管理因數量變多導致工作繁重.jpg 1440w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">單個容器獨立管理因數量變多導致工作繁重</figcaption></figure>



<p class="wp-block-paragraph">Kubernetes（常簡稱為 K8s）是一個開源的容器編排平台，它就像是一個聰明的指揮家，能夠協調和管理大量的容器化應用程式。</p>



<h3 class="wp-block-heading">Kubernetes 的核心價值</h3>



<p class="wp-block-paragraph">它的核心價值在於：</p>



<p class="wp-block-paragraph">自動化部署和擴充：<br>根據負載自動增加或減少容器執行個體的數量。</p>



<p class="wp-block-paragraph">服務發現 (Service Discovery) 和負載平衡：<br>服務發現機制讓服務能夠輕鬆找到彼此，並自動分配流量到健康的容器。</p>



<p class="wp-block-paragraph">自我修復能力：<br>當某個容器發生故障，會自動重啟新的容器，確保系統的高可用性。</p>



<p class="wp-block-paragraph">設定和機密資訊管理：<br>提供了統一的方式來管理應用程式的設定資訊和敏感資料。</p>



<p class="wp-block-paragraph">滾動更新 (Rolling Update)：<br>能夠逐步替換舊版本的容器，確保服務不中斷。</p>



<h3 class="wp-block-heading">從單一容器到容器叢集</h3>



<p class="wp-block-paragraph">如果說 Cloud Run 讓我們能夠輕鬆運行單一的容器化應用程式，那麼 Kubernetes 就是讓我們能夠管理整個容器化應用程式生態系統的平台。它將多個容器組織成一個協調運作的叢集 (Cluster) ，每個容器都有自己的角色和責任，但它們共同協作來提供完整的服務。</p>



<p class="wp-block-paragraph">就像管理一個小型團隊發展到管理一個大型組織。在小團隊中，每個人可能身兼多職，溝通簡單直接。但在大型組織中，你需要明確的分工、標準化的流程、有效的溝通機制，以及能夠快速適應變化的管理體系。</p>



<h2 class="wp-block-heading">Google Kubernetes Engine (GKE) 簡介</h2>



<p class="wp-block-paragraph">雖然 Kubernetes 非常強大，但設置和維護一個 Kubernetes 叢集本身就是一項複雜的任務。你需要處理主節點的高可用性、網路配置、安全性設定、監控和日誌收集等等。</p>



<p class="wp-block-paragraph">你可以在地端，或使用 Compute Engine 的虛擬機器來架設 Kubernetes，但是整個過程非常繁瑣，架設完成還要處理各個節點之前的通訊，極為複雜且耗時，當你花了好幾搭建好環境，你都還沒處理到應用程式的部分。</p>



<p class="wp-block-paragraph">這就是為什麼 Google 推出了 <a href="https://cloud.google.com/kubernetes-engine?hl=zh-TW" target="_blank" rel="noopener" title="">Google Kubernetes Engine</a>。</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="782" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-2-8-自建-Kubernetes-和使用-GKE-的比較-1024x782.png" alt="" class="wp-image-11121" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-2-8-自建-Kubernetes-和使用-GKE-的比較-1024x782.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-2-8-自建-Kubernetes-和使用-GKE-的比較-300x229.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-2-8-自建-Kubernetes-和使用-GKE-的比較-768x587.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-2-8-自建-Kubernetes-和使用-GKE-的比較.png 1169w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">在自建 Kubernetes 和直接使用 GKE 的建置過程差異</figcaption></figure>



<p class="wp-block-paragraph">GKE 是 Google Cloud 提供的代管式 Kubernetes 服務。它讓你能夠善用 Kubernetes 的所有強大功能，同時 Google 會負責處理底層的基礎建設管理工作。代表你可以專注於開發和部署應用程式，而不需要擔心 Kubernetes Cluster 本身的維護。</p>



<h3 class="wp-block-heading">Kubernetes 的幾個核心物件</h3>



<p class="wp-block-paragraph">在開始使用 GKE 之前，先來了解 Kubernetes 的幾個核心物件：</p>



<h3 class="wp-block-heading">Node：工作節點而非虛擬機器</h3>



<p class="wp-block-paragraph">Node 是指叢集中的工作節點。為什麼不直接叫「虛擬機器」？因為 Node 是一個更抽象的概念：它可以是實體機器或虛擬機器。Kubernetes 把這些不同類型的運算資源統一稱為 Node，強調的是它們的「工作節點」角色，能夠運作容器，至於它們到底是怎樣的機器，其實並不重要。</p>



<h3 class="wp-block-heading">Pod：容器的最小單位</h3>



<p class="wp-block-paragraph">Pod 是 Kubernetes 中部署和管理的最小單位。一個 Pod 通常包含一個容器，但也可以包含多個緊密相關的容器。這些容器共享網路和儲存資源，就像室友共享一個公寓一樣。Pod 的生命週期很短暫，隨時可能被創建或銷毀。</p>



<h3 class="wp-block-heading">Deployment：管理應用程式的生命週期</h3>



<p class="wp-block-paragraph">Deployment 負責管理你的應用程式如何部署和更新。它告訴 Kubernetes：「我想要運行 3 個網站的副本」，然後 Deployment 會確保始終有 3 個健康的 Pod 在運行。如果某個 Pod 掛掉了，Deployment 會自動建立新的來替代。當你要更新應用程式時，Deployment 也會協調整個更新過程。</p>



<h3 class="wp-block-heading">Service：穩定的網路端點</h3>



<p class="wp-block-paragraph">由於 Pod 會頻繁地建立和銷毀，它們的 IP 地址也會不斷變化。Service 就像是一個穩定的門牌號碼，為一組 Pod 提供固定的網路端點。無論後面的 Pod 如何變化，其他服務都可以通過 Service 找到它們，不需要你手動調整網路連結。</p>



<h3 class="wp-block-heading">Ingress：對外開放的大門</h3>



<p class="wp-block-paragraph">Ingress 是叢集的對外入口，負責將外部的 HTTP/HTTPS 流量路由到叢集內的 Service。它就像是一個智慧的接待人員，根據 URL 路徑或網域將流量導向正確的服務。比如，當用戶訪問 api.example.com 時，Ingress 會將請求轉發給 API 服務；訪問 app.example.com 時，則轉發給前端應用程式。</p>



<p class="wp-block-paragraph">整體的運作架構示意如下圖：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="829" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-3-Kubernetes-核心物件-1024x829.png" alt="" class="wp-image-11122" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-3-Kubernetes-核心物件-1024x829.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-3-Kubernetes-核心物件-300x243.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-3-Kubernetes-核心物件-768x621.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-3-Kubernetes-核心物件.png 1142w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">Kubernetes 核心物件架構</figcaption></figure>



<p class="wp-block-paragraph">這些元件形成了一個完整的體系：Node 提供運算資源，Pod 在 Node 上運行你的應用程式，Deployment 管理 Pod 的生命週期，Service 為 Pod 提供穩定的網路訪問方式，而 Ingress 則負責將外部流量導入到正確的 Service。</p>



<p class="wp-block-paragraph">就像一個運作良好的公司：Node 是辦公大樓，Pod 是員工工作的辦公室，Deployment 是人事部門負責人員配置，Service 是內部電話系統，而 Ingress 是前台接待處。</p>



<h2 class="wp-block-heading">建立你的第一個 GKE Cluster</h2>



<p class="wp-block-paragraph">了解了 Kubernetes 的核心概念後，現在讓我們實際建立一個 GKE Cluster。GKE 提供了兩種主要的叢集模式，讓我們先來了解它們的差異。</p>



<h3 class="wp-block-heading">Standard 模式 vs Autopilot 模式</h3>



<p class="wp-block-paragraph">GKE 提供兩種不同的 Cluster 運作模式，各有其適用場景：</p>



<p class="wp-block-paragraph">Standard 模式（標準模式）</p>



<p class="wp-block-paragraph">Standard 模式讓你擁有完整的控制權，就像擁有一輛可以自己調整引擎、變速箱的汽車。你需要自己管理節點（Node）的配置、擴展策略、安全性設定等等。這種模式適合有經驗的團隊，需要精細控制叢集行為，或是有特殊的硬體需求。</p>



<p class="wp-block-paragraph">要注意的是，當你建立完 Cluster，它會幫你建立好節點，其實你還沒部署應用程式，代表這些節點資源已經開始隨著時間計費，這樣會浪費你的預算，你就可以選擇 Autopilot 模式。</p>



<p class="wp-block-paragraph">Autopilot 模式（自動駕駛模式）</p>



<p class="wp-block-paragraph">Autopilot 模式就像使用自動駕駛汽車，Google 會自動處理大部分的基礎設施管理工作。它會自動配置節點、處理安全性更新、優化資源使用，並且只針對你實際使用的 Pod 資源收費，所以讓你還沒部署 Pod 的時候，還沒建立任何 Node，就不會針對 Node 收取費用。</p>



<p class="wp-block-paragraph">這種模式特別適合想要專注於應用程式開發，而不想花時間管理基礎設施的團隊。對於初學者和大多數應用場景，我們推薦使用 Autopilot 模式，因為它大幅簡化了叢集管理的複雜度。</p>



<h3 class="wp-block-heading">使用 GCP Console 來建立 GKE Autopilot Cluster</h3>



<p class="wp-block-paragraph">讓我們透過 Google Cloud Console 來建立第一個 Autopilot Cluster，點擊「叢集」，再點「建立」：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="532" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-4-建立第一個-GKE-Cluster-1024x532.png" alt="" class="wp-image-11123" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-4-建立第一個-GKE-Cluster-1024x532.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-4-建立第一個-GKE-Cluster-300x156.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-4-建立第一個-GKE-Cluster-768x399.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-4-建立第一個-GKE-Cluster.png 1234w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">建立第一個 GKE Cluster</figcaption></figure>



<p class="wp-block-paragraph">名稱我們保持預設，區域一樣選擇 asia-east1，然後在級別的部分選擇「標準級」，然後再點「下一個區段：機群註冊」：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="364" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-5-Cluster-命名、設定位置和級別-1024x364.png" alt="" class="wp-image-11124" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-5-Cluster-命名、設定位置和級別-1024x364.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-5-Cluster-命名、設定位置和級別-300x107.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-5-Cluster-命名、設定位置和級別-768x273.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-5-Cluster-命名、設定位置和級別-1536x546.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-5-Cluster-命名、設定位置和級別.png 1884w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">Cluster 命名、設定位置和級別</figcaption></figure>



<p class="wp-block-paragraph">GKE 有個最新功能叫做 GKE Fleet Management，可以將不同 Google Cloud 專案中的GKE Cluster 地群組在一起，而且不只 GKE Cluster，也包含地端環境、其他雲端平台的 Cluster 都可以納入管理，這樣就能一次管理所有應用程式，簡化維運工作。</p>



<p class="wp-block-paragraph">在這裡我們只有一個 Cluster，所以可略過這個功能，再點「下一個區段：網路連線」：</p>



<figure class="wp-block-image aligncenter size-full"><img loading="lazy" decoding="async" width="815" height="478" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-6-機群註冊可略過.png" alt="" class="wp-image-11125" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-6-機群註冊可略過.png 815w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-6-機群註冊可略過-300x176.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-6-機群註冊可略過-768x450.png 768w" sizes="(max-width: 815px) 100vw, 815px" /><figcaption class="wp-element-caption">機群註冊</figcaption></figure>



<p class="wp-block-paragraph">在這裡保持預設即可，其中可以注意的是，最右邊有 Pod 和 Service 的 IP 範圍，代表 Kubernetes 會分配 IP 位址給它們使用，而在 GKE 環境下，就是會把 Subnet 的次要 IP 範圍自動分配給它們，我們不用額外設定。再點「下一個區段：進階設定」：<br></p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="354" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-7-Cluster-網路-1024x354.png" alt="" class="wp-image-11126" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-7-Cluster-網路-1024x354.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-7-Cluster-網路-300x104.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-7-Cluster-網路-768x266.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-7-Cluster-網路-1536x531.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-7-Cluster-網路.png 1905w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">GKE Cluster 網路設定</figcaption></figure>



<p class="wp-block-paragraph">在「目前發布版本」的下拉式選單中，我們選擇「一般（建議）」，然後再按下「建立」：&nbsp;<br></p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="481" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-8-選擇版本類型並建立-Cluster--1024x481.png" alt="" class="wp-image-11127" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-8-選擇版本類型並建立-Cluster--1024x481.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-8-選擇版本類型並建立-Cluster--300x141.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-8-選擇版本類型並建立-Cluster--768x361.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-8-選擇版本類型並建立-Cluster--1536x722.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-8-選擇版本類型並建立-Cluster-.png 1868w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">選擇版本類型並建立 Cluster</figcaption></figure>



<p class="wp-block-paragraph">接下來就等待&nbsp; Cluster 建立完成，在這裡大概需要等待 5～10 分鐘左右：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="500" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-9-等待-Cluster-建立完成-1024x500.png" alt="" class="wp-image-11128" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-9-等待-Cluster-建立完成-1024x500.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-9-等待-Cluster-建立完成-300x146.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-9-等待-Cluster-建立完成-768x375.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-9-等待-Cluster-建立完成.png 1092w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">等待 GKE Cluster 建立完成</figcaption></figure>



<p class="wp-block-paragraph">這裡順便補充一下，大部分熟悉 Kubernertes 的工程師都偏好使用指令來建立和管理 GKE Cluster，我們也開啟 Cloud Shell 來建立第二個 Cluster 看看吧！</p>



<h3 class="wp-block-heading">使用 gcloud 指令建立 Autopilot Cluster</h3>



<p class="wp-block-paragraph">gcloud container clusters create-auto autopilot-cluster-2&nbsp; &#8211;region=asia-east1 &nbsp; &nbsp; &#8211;release-channel=regular</p>



<p class="wp-block-paragraph">執行完後，你會看到它在建立過程的相關訊息，包含 Cluster 名稱、版本、Cluster IP、機器類型、節點數量等等：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="317" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-10-使用指令建立-GKE-Cluster-完成-1024x317.png" alt="" class="wp-image-11129" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-10-使用指令建立-GKE-Cluster-完成-1024x317.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-10-使用指令建立-GKE-Cluster-完成-300x93.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-10-使用指令建立-GKE-Cluster-完成-768x238.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-10-使用指令建立-GKE-Cluster-完成-1536x475.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-10-使用指令建立-GKE-Cluster-完成.png 1882w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">使用指令建立 GKE Cluster 完成</figcaption></figure>



<h3 class="wp-block-heading">使用 gcloud 和 kubectl 指令操作 GKE Cluster </h3>



<p class="wp-block-paragraph">我們回到建立好的 autopilot-cluster-1，我們可以用指令來查看它的相關資訊 (autopilot-cluster-2 如果沒用到可以先刪除)：</p>



<p class="wp-block-paragraph">取得 Cluster 憑證以便使用 kubectl 工具</p>



<p class="wp-block-paragraph">gcloud container clusters get-credentials autopilot-cluster-1&nbsp; &#8211;region=asia-east1</p>



<p class="wp-block-paragraph">這個指令的作用就像是取得鑰匙，告訴 kubectl 叢集在哪裡，並且提供身分驗證資訊，來證明你有權限管理這個 Cluster 的憑證，然後把連線的設定儲存在本機電腦的 ~/.kube/config 檔案。</p>



<p class="wp-block-paragraph">檢查叢集狀態</p>



<p class="wp-block-paragraph">kubectl cluster-info</p>



<p class="wp-block-paragraph">查看節點資訊</p>



<p class="wp-block-paragraph">kubectl get nodes</p>



<p class="wp-block-paragraph">檢查系統 Pod 狀態</p>



<p class="wp-block-paragraph">kubectl get pods &#8211;all-namespaces</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="481" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-11-使用指令查看-Cluster-相關資訊-1024x481.png" alt="" class="wp-image-11130" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-11-使用指令查看-Cluster-相關資訊-1024x481.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-11-使用指令查看-Cluster-相關資訊-300x141.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-11-使用指令查看-Cluster-相關資訊-768x361.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-11-使用指令查看-Cluster-相關資訊-1536x722.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-11-使用指令查看-Cluster-相關資訊.png 1870w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">使用 kubectl 指令查看 GKE Cluster 相關資訊</figcaption></figure>



<p class="wp-block-paragraph">到這裡你可能會覺得奇怪，為什麼指令分成 gcloud 和 kubectl？</p>



<p class="wp-block-paragraph">gcloud 是 Google Cloud 的管理工具，負責管理 Google Cloud 上的資源，包含建立或刪除 GKE 叢集、管理帳單、權限、API 啟用。</p>



<p class="wp-block-paragraph">而 kubectl 是 Kubernetes 用來管理 Cluster 內部的應用程式。能夠部署應用程式到 Cluster、查看 Pod、Service 的狀態、管理設定檔和執行日常維護工作。</p>



<p class="wp-block-paragraph">而且每次下達 kubectl 指令，並不會用參數指定要操作的 Cluster，當你專案內有多個 Cluster 的時候，它不會知道你要對誰操作，所以才必須要 get-credentials 這個指令，才能操作到正確的 Cluster，當然你也可以再執行一次 get-credentials，切換到另外一個 Cluster，再去執行管理動作。&nbsp;</p>



<h2 class="wp-block-heading">部署應用程式到 GKE Cluster</h2>



<h3 class="wp-block-heading">使用 GKE Deployment 物件部署容器映像檔到 Pod </h3>



<p class="wp-block-paragraph">Cluster 建立完成，現在來部署應用程式到 Cluser，我們點擊「佈署」（雖然我覺得是「部署」）：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="498" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-12-部署應用程式-1024x498.png" alt="" class="wp-image-11131" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-12-部署應用程式-1024x498.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-12-部署應用程式-300x146.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-12-部署應用程式-768x373.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-12-部署應用程式.png 1152w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">部署應用程式到 GKE</figcaption></figure>



<p class="wp-block-paragraph">這裡設定的部署作業就像上面提到的 deployment 物件，我們可以在這裡指定跟上個單元相同的容器映像檔，再按「下一步：公開（選用）」：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="562" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-13-設定部署的目的-Cluster-和容器-1024x562.png" alt="" class="wp-image-11132" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-13-設定部署的目的-Cluster-和容器-1024x562.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-13-設定部署的目的-Cluster-和容器-300x165.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-13-設定部署的目的-Cluster-和容器-768x421.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-13-設定部署的目的-Cluster-和容器-1536x842.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-13-設定部署的目的-Cluster-和容器.png 1909w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">設定部署的目的 Cluster 和容器</figcaption></figure>



<h3 class="wp-block-heading">部署 GKE Service 物件 （Network Load Balancer）</h3>



<p class="wp-block-paragraph">做到這裡可以讓 Pod 部署完成，但是要注意這個設定還不會讓 Pod 直接對外，你必須在勾選「以新 Service 的形式公開 Deployment」 。</p>



<p class="wp-block-paragraph">在這裡要注意，我們當初在建立容器映像檔的時候，我們讓容器本身對外開放 Port 8080，上面的 80 是指負載平衡器對外的 Port，但是當流量進來之後，要指定 8080 才能存取到容器上的網頁喔。&nbsp;</p>



<p class="wp-block-paragraph">在服務類型保持預設的「負載平衡器」，它就會直接在 Google Cloud 上建立負載平衡器。 然後我們再按下建立。</p>



<figure class="wp-block-image aligncenter size-full"><img loading="lazy" decoding="async" width="726" height="812" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-14-設定-Service.png" alt="" class="wp-image-11133" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-14-設定-Service.png 726w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-14-設定-Service-268x300.png 268w" sizes="(max-width: 726px) 100vw, 726px" /><figcaption class="wp-element-caption">設定 Service</figcaption></figure>



<p class="wp-block-paragraph">接下來再等待幾分鐘會看到這個 Deployment 已經部署完成了，視窗可以再往下滑：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="681" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-15-看到-Deployment-部署完成-1024x681.png" alt="" class="wp-image-11134" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-15-看到-Deployment-部署完成-1024x681.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-15-看到-Deployment-部署完成-300x200.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-15-看到-Deployment-部署完成-768x511.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-15-看到-Deployment-部署完成.png 1360w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">看到 Deployment 部署完成</figcaption></figure>



<p class="wp-block-paragraph">我們往下看到各種物件產生，包含一個 Deployment 物件，和三個 Pod 物件，都是在正常運作的狀態：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="533" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-16-往下看到各種物件產生-1024x533.png" alt="" class="wp-image-11135" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-16-往下看到各種物件產生-1024x533.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-16-往下看到各種物件產生-300x156.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-16-往下看到各種物件產生-768x400.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-16-往下看到各種物件產生.png 1159w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">往下看到各種物件產生</figcaption></figure>



<p class="wp-block-paragraph">你可以再打開 Cloud Shell，下達各種相關的查詢指令 (記得要先 get-credentials) 喔！&nbsp;</p>



<p class="wp-block-paragraph">查看目前部署的 Deployment</p>



<p class="wp-block-paragraph">kubectl get deployments</p>



<p class="wp-block-paragraph">查看目前部署的 Pod</p>



<p class="wp-block-paragraph">kubectl get pods</p>



<p class="wp-block-paragraph">查看目前部署的 Service&nbsp;</p>



<p class="wp-block-paragraph">kubectl get services</p>



<p class="wp-block-paragraph">你會看到它有產生一個外部 IP，是對外開放存取的。</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="350" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-17-輸入各項查詢指令-1024x350.png" alt="" class="wp-image-11136" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-17-輸入各項查詢指令-1024x350.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-17-輸入各項查詢指令-300x103.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-17-輸入各項查詢指令-768x263.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-17-輸入各項查詢指令-1536x525.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-17-輸入各項查詢指令.png 1866w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">輸入 kubectl 各項查詢指令</figcaption></figure>



<p class="wp-block-paragraph">你可以打開瀏覽器輸入 https://[IP位址]，或是直接在 Web Console 上面點擊會看到網頁秀出來，不過在這裡要稍微等待一下，因為我們現在使用的是 Autopilot 模式，是連 Node 都還沒建立的情況，所以現在要先等它建立 Node，再部署 Deployment、Pod 和 Service。</p>



<p class="wp-block-paragraph">過幾分鐘之後，我們看到它部署完成，也看到網頁出現了！</p>



<figure class="wp-block-image aligncenter size-full"><img loading="lazy" decoding="async" width="610" height="299" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-18-點擊服務連結看到網頁出現.png" alt="" class="wp-image-11137" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-18-點擊服務連結看到網頁出現.png 610w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-18-點擊服務連結看到網頁出現-300x147.png 300w" sizes="(max-width: 610px) 100vw, 610px" /><figcaption class="wp-element-caption">點擊服務連結看到網頁出現</figcaption></figure>



<p class="wp-block-paragraph">另外我們也可以在負載平衡器頁面看到一個負載平衡器：</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="300" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-19-也可以在負載平衡器頁面看到一個-TCP-負載平衡器-1024x300.png" alt="" class="wp-image-11138" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-19-也可以在負載平衡器頁面看到一個-TCP-負載平衡器-1024x300.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-19-也可以在負載平衡器頁面看到一個-TCP-負載平衡器-300x88.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-19-也可以在負載平衡器頁面看到一個-TCP-負載平衡器-768x225.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-19-也可以在負載平衡器頁面看到一個-TCP-負載平衡器-1536x450.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-19-也可以在負載平衡器頁面看到一個-TCP-負載平衡器-2048x600.png 2048w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">也可以在負載平衡器頁面看到一個 TCP 負載平衡器</figcaption></figure>



<p class="wp-block-paragraph">要注意它是 TCP 負載平衡器，它工作在網路的第 4 層（傳輸層），只能根據 IP 位址和 Port 來分配流量。無法根據 URL 路徑進行導向 (例如 /api 或 /admin)，也無法根據網域名稱進行路由。</p>



<p class="wp-block-paragraph">如果我們想要更聰明的流量路由功能，就需要使用 Application Load Balancer (ALB)。ALB 工作在第 7 層（應用層），能夠處理 HTTP/HTTPS 通訊協定的內容，提供更豐富的路由功能。</p>



<p class="wp-block-paragraph">但目前在 Google Cloud 的 Console 上沒有辦法直接建立 ALB，必須要使用指令和設定檔的方式，來建立 Ingress 物件。</p>



<h3 class="wp-block-heading">部署 GKE Ingress 物件 (Application Load Balancer)</h3>



<p class="wp-block-paragraph">不過！現在要先刪除原有的 deployment-1-service (Load Balancer)，以免後續物件在建立時，會有衝突喔！</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="487" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-20-刪除-deployment-1-service-Load-Balancer--1024x487.png" alt="" class="wp-image-11139" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-20-刪除-deployment-1-service-Load-Balancer--1024x487.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-20-刪除-deployment-1-service-Load-Balancer--300x143.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-20-刪除-deployment-1-service-Load-Balancer--768x365.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-20-刪除-deployment-1-service-Load-Balancer--1536x731.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-20-刪除-deployment-1-service-Load-Balancer--2048x974.png 2048w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">刪除&nbsp; deployment-1-service (Load Balancer)</figcaption></figure>



<p class="wp-block-paragraph">刪除之後，我們再建立 2 個物件：</p>



<p class="wp-block-paragraph">第一個物件：ClusterIP 類型的 Service</p>



<p class="wp-block-paragraph">ClusterIP Service 是 Kubernetes 中最基本的 Service 類型，它只在 Cluster 內部提供一個穩定的 IP 位址和 DNS 名稱。雖然 ClusterIP Service 無法從 Cluster 外部直接訪問，但它為 Cluster 內部的通訊提供了完美的抽象層。</p>



<p class="wp-block-paragraph">你可以把 ClusterIP Service 想像成公司內部的分機號碼系統。員工可以通過分機號碼找到彼此，但外部的人無法直接撥打分機號碼。</p>



<p class="wp-block-paragraph">我們現在 Cloud Shell 的環境準備好一個設定檔 cluster-ip-service.yaml，內容如下：</p>



<pre class="wp-block-code"><code>apiVersion: v1
kind: Service
metadata:
  name: deployment-1-service
  labels:
    app: deployment-1
spec:
  type: ClusterIP 
  selector:
    app: deployment-1
    app.kubernetes.io/managed-by: cloud-console
  ports:
  - port: 80
    targetPort: 8080
    protocol: TCP
</code></pre>



<p class="wp-block-paragraph">接著來執行這個指令：</p>



<p class="wp-block-paragraph">kubectl apply -f cluster-ip-service.yaml</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="131" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-21-執行部署-ClusterIP-Service-物件-1024x131.png" alt="" class="wp-image-11141" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-21-執行部署-ClusterIP-Service-物件-1024x131.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-21-執行部署-ClusterIP-Service-物件-300x39.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-21-執行部署-ClusterIP-Service-物件-768x99.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-21-執行部署-ClusterIP-Service-物件-1536x197.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-21-執行部署-ClusterIP-Service-物件-2048x263.png 2048w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">執行部署 ClusterIP Service 物件</figcaption></figure>



<p class="wp-block-paragraph">這裡說明一下指令和參數：</p>



<p class="wp-block-paragraph">kubectl apply&nbsp;</p>



<p class="wp-block-paragraph">這是 Kubernetes 的宣告式管理指令。它的意思是：「讓 Cluster 的實際狀態符合這個檔案中描述的期望狀態」。如果資源不存在，它會建立；如果已存在但設定有任何不同，它會更新。</p>



<p class="wp-block-paragraph">-f 參數</p>



<p class="wp-block-paragraph">代表 &#8220;file&#8221;，告訴 kubectl 從檔案中讀取設定。你也可以使用 -f 指定多個檔案，或是指定包含多個 YAML 檔的目錄。</p>



<p class="wp-block-paragraph">YAML（YAML Ain&#8217;t Markup Language）</p>



<p class="wp-block-paragraph">這是是一種人類易讀的資料序列化格式。在 Kubernetes 中，我們使用 YAML 檔來描述我們想要的資源狀態。</p>



<p class="wp-block-paragraph">在 Kubernetes 的術語中，這些 YAML 檔被稱為 Manifest（資訊清單）。Manifest 是一份宣告式的文件，描述了 Kubernetes 資源的期望狀態。它不是告訴 Kubernetes「如何做」，而是告訴它「我想要什麼結果」，有點像在許願的感覺，而且它會使命必達的實現你的願望。</p>



<p class="wp-block-paragraph">PS. 我以前不懂 Manifest 到底是什麼，但自從看了國外的吸引力法則或顯化法則，才知道 Manifest 就是顯化的意思，把你想要的現實呈現出來。</p>



<p class="wp-block-paragraph">第二個物件：Ingress</p>



<p class="wp-block-paragraph">Ingress 是真正負責處理外部流量並提供 ALB 功能的物件，它就像是建築物的智慧接待處，能夠根據 URL 路徑決定要導向哪個服務，也能根據網域名進行路由，把流量帶向目的服務。（感覺跟 Load Balancer 一模一樣）</p>



<p class="wp-block-paragraph">設定檔 ingress-1.yaml 的內容如下：</p>



<pre class="wp-block-code"><code>apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: ingress-1
  namespace: default
  annotations:
    kubernetes.io/ingress.class: "gce"
spec:
  rules:
  - http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: deployment-1-service
            port:
              number: 80
</code></pre>



<p class="wp-block-paragraph">接著來執行這個指令：</p>



<p class="wp-block-paragraph">kubectl apply -f ingress-1.yaml</p>



<p class="wp-block-paragraph">你會看到它有一個警告訊息「 Warning: annotation &#8220;kubernetes.io/ingress.class&#8221; is deprecated, please use &#8216;spec.ingressClassName&#8217; instead」，是因為 Kubernetes 本身推薦使用新的 spec.ingressClassName，但 GKE 的官方文件卻說要用舊的註解方式。</p>



<p class="wp-block-paragraph">在這裡以 GKE 的官方文件為主，不用理會該訊息。</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="168" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-22-執行部署-Ingress-物件-1024x168.png" alt="" class="wp-image-11143" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-22-執行部署-Ingress-物件-1024x168.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-22-執行部署-Ingress-物件-300x49.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-22-執行部署-Ingress-物件-768x126.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-22-執行部署-Ingress-物件-1536x253.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-22-執行部署-Ingress-物件-2048x337.png 2048w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">執行部署 GKE Ingress 物件</figcaption></figure>



<p class="wp-block-paragraph">接下來需要等待至少 5~10 分鐘的時間，如果設定正確，就能夠在 Ingress 的地方看到一個前端的 IP，點擊之後就能看到網頁。</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="513" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-23-Ingress-建立完成並看到網頁正常顯示-1024x513.png" alt="" class="wp-image-11144" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-23-Ingress-建立完成並看到網頁正常顯示-1024x513.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-23-Ingress-建立完成並看到網頁正常顯示-300x150.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-23-Ingress-建立完成並看到網頁正常顯示-768x385.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-23-Ingress-建立完成並看到網頁正常顯示-1536x769.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-23-Ingress-建立完成並看到網頁正常顯示-2048x1026.png 2048w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">Ingress 建立完成並看到網頁正常顯示</figcaption></figure>



<p class="wp-block-paragraph">也能在負載平衡頁面看到 ALB，代表它能夠處理 HTTP/HTTPS 通訊協定的內容，提供更豐富的路由功能。</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="418" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-24-也能在負載平衡頁面看到-ALB-1024x418.png" alt="" class="wp-image-11145" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-24-也能在負載平衡頁面看到-ALB-1024x418.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-24-也能在負載平衡頁面看到-ALB-300x122.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-24-也能在負載平衡頁面看到-ALB-768x313.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-24-也能在負載平衡頁面看到-ALB-1536x626.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-24-也能在負載平衡頁面看到-ALB.png 1864w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">也能在負載平衡頁面看到 ALB</figcaption></figure>



<p class="wp-block-paragraph">恭喜你也把 GKE 的基本服務建立完成了，接下來還是要記得刪除相關服務喔！</p>



<h2 class="wp-block-heading">逐步刪除 GKE 物件</h2>



<h3 class="wp-block-heading">下 kubectl 指令刪除 GKE 物件</h3>



<p class="wp-block-paragraph">你可以按照以下的順序刪除：</p>



<p class="wp-block-paragraph">查詢 Ingress 名稱</p>



<p class="wp-block-paragraph">kubectl get ingress</p>



<p class="wp-block-paragraph">刪除 Ingress (執行後要等 3~5 分鐘刪除完畢)</p>



<p class="wp-block-paragraph">kubectl delete ingress-1&nbsp;</p>



<p class="wp-block-paragraph">查詢 Service 名稱</p>



<p class="wp-block-paragraph">kubectl get service</p>



<p class="wp-block-paragraph">刪除 Service&nbsp; (名稱為 kubernetes 的 Service 不用刪除)</p>



<p class="wp-block-paragraph">kubectl delete service deployment-1-service</p>



<p class="wp-block-paragraph">查詢 Deployment 名稱</p>



<p class="wp-block-paragraph">kubectl get deployment</p>



<p class="wp-block-paragraph">刪除 Deployment</p>



<p class="wp-block-paragraph">kubectl delete deployment deployment-1</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="437" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-25-刪除-GKE-Cluster-上各個物件-1024x437.png" alt="" class="wp-image-11148" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-25-刪除-GKE-Cluster-上各個物件-1024x437.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-25-刪除-GKE-Cluster-上各個物件-300x128.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-25-刪除-GKE-Cluster-上各個物件-768x328.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-25-刪除-GKE-Cluster-上各個物件-1536x656.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-25-刪除-GKE-Cluster-上各個物件.png 1934w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">刪除 GKE Cluster 上各個物件</figcaption></figure>



<h3 class="wp-block-heading">直接刪除整個 GKE Cluster</h3>



<p class="wp-block-paragraph">再用這個指令刪除整個 Cluster，其實你也可以跳過前面刪除物件的步驟，直接刪除 Cluster：</p>



<p class="wp-block-paragraph">gcloud container clusters delete autopilot-cluster-1 &#8211;region asia-east1</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="230" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-26-使用-gcloud-指令刪除-GKE-Cluster--1024x230.png" alt="" class="wp-image-11146" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-26-使用-gcloud-指令刪除-GKE-Cluster--1024x230.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-26-使用-gcloud-指令刪除-GKE-Cluster--300x68.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-26-使用-gcloud-指令刪除-GKE-Cluster--768x173.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-26-使用-gcloud-指令刪除-GKE-Cluster--1536x346.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-26-使用-gcloud-指令刪除-GKE-Cluster--2048x461.png 2048w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">使用 gcloud 指令刪除 GKE Cluster</figcaption></figure>



<p class="wp-block-paragraph">或是更簡單的方法，直接在 Web Console 上刪除整個 Cluster， Cluster 裡所有物件也都會跟著被刪除掉。</p>



<figure class="wp-block-image aligncenter size-large"><img loading="lazy" decoding="async" width="1024" height="572" src="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-27-在-Web-Console-上刪除-GKE-Cluster-1-1024x572.png" alt="" class="wp-image-11149" srcset="https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-27-在-Web-Console-上刪除-GKE-Cluster-1-1024x572.png 1024w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-27-在-Web-Console-上刪除-GKE-Cluster-1-300x167.png 300w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-27-在-Web-Console-上刪除-GKE-Cluster-1-768x429.png 768w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-27-在-Web-Console-上刪除-GKE-Cluster-1-1536x857.png 1536w, https://dongdonggcp.com/wp-content/uploads/2025/07/9-5-27-在-Web-Console-上刪除-GKE-Cluster-1-2048x1143.png 2048w" sizes="(max-width: 1024px) 100vw, 1024px" /><figcaption class="wp-element-caption">在 Web Console 上刪除 GKE Cluster</figcaption></figure>



<p class="wp-block-paragraph">最後要跟各位提醒，Kubernetes 本身是一個博大精深的領域，本文礙於篇幅只能介紹到這裡，如果需要深入鑽研，建議各位再去尋找專門的書籍或文件來看。而且 Kubernetes 本身不斷在更新，GKE 也持續更新，所以現在看到可以運作的樣子，也許過不久後又會改變，所以還請大家持續追蹤 GCP 官方文件喔！</p>



<p class="wp-block-paragraph">影片版教學如下：</p>



<figure class="wp-block-embed is-type-video is-provider-youtube wp-block-embed-youtube wp-embed-aspect-4-3 wp-has-aspect-ratio"><div class="wp-block-embed__wrapper">
<div class="ast-oembed-container " style="height: 100%;"><iframe title="[GKE 教學] 030 斷片也能學會，滑鼠點五下，建好 GKE ｜ Cluster、應用程式和負載平衡全部完成！！| 免費下載 GKE 簡報" width="1200" height="900" src="https://www.youtube.com/embed/VCXlIBm7qlo?feature=oembed" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe></div>
</div></figure>



<p class="wp-block-paragraph"></p><p>The post <a href="https://dongdonggcp.com/2025/07/20/google-kubernetes-engine-tutorials/">Google Kubernetes Engine 是什麼？GKE 簡介與手把手操作教學</a> first appeared on <a href="https://dongdonggcp.com">東東 GCP 教學 - GCP 實戰講師</a>.</p>]]></content:encoded>
					
					<wfw:commentRss>https://dongdonggcp.com/2025/07/20/google-kubernetes-engine-tutorials/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">11119</post-id>	</item>
	</channel>
</rss>
