Google Cloud 建立與設定 VM 執行個體 for CentOS 7
data:image/s3,"s3://crabby-images/b714e/b714e3a7ec69f7395da62913d5ace2606b6ab383" alt="Google Cloud Platform"
使用 Google Cloud Platform 雲端服務的 Compute Engine 建立 CentOS 7 的 VM 執行個體,並說明 VM 如何預約靜態外部 IP、如何使用 PieTTY 與 VM 建立 SSH 連結、如何使用 WinSCP 與 VM 建立 SCP 來安全的傳輸檔案,以及透過第三方供應商 SendGrid 的電子郵件服務來讓 Postfix 寄發電子郵件。
GCP (Google Cloud Platform,Google 雲端平台) 是一項使用 Google 核心基礎架構、資料分析和機器學習技術的雲端運算服務。
啟用免費試用
搜尋並點擊 Google Cloud。
data:image/s3,"s3://crabby-images/d3424/d3424983d471ea82cfd30f5efe4c093a345739bd" alt=""
點擊「免費試用」。
data:image/s3,"s3://crabby-images/7f7c8/7f7c8c3b10b1dc151a833d7edbc8d8d27bcf406d" alt=""
選擇國家和勾選服務條款。
data:image/s3,"s3://crabby-images/6aede/6aedee61f869c9828161e69937979a7930e08db8" alt=""
填寫個人資料。
data:image/s3,"s3://crabby-images/4f115/4f1153549eac6d50bf85443b28dc353073197863" alt=""
填寫付款方式與信用卡資料。
data:image/s3,"s3://crabby-images/2b7b7/2b7b7667a7d1875e1ff9447a9a5e35cf35388b97" alt=""
啟用免費試用完成,Google Cloud 首頁。
data:image/s3,"s3://crabby-images/cbcd1/cbcd1f4d74b0646d63227201ff4a7e1b470e7f17" alt=""
VM 執行個體
Google Cloud 的 Compute Engine,提供可彈性擴充高效能的 VM (Virtual Machine,虛擬機器)。
啟用 VM
點擊「VM 執行個體」。
data:image/s3,"s3://crabby-images/2575b/2575b4b5a0dd90446d735c9c2bae2a419feb4f71" alt=""
必須「啟用計費功能」,才能使用 Compute Engine 來建立 VM。
data:image/s3,"s3://crabby-images/f0eff/f0eff994814d96d47aedf3cc213cfbc9f43fbb32" alt=""
Compute Engine 啟用中。
data:image/s3,"s3://crabby-images/31a4f/31a4f5f94ed056bf862dce9c6e153bac08dc658d" alt=""
建立 VM
建立 VM。
data:image/s3,"s3://crabby-images/09d71/09d71f251ca88796733b764c3745f17b45ddf781" alt=""
VM 配置,映像檔選擇要安裝的作業系統 CeneOS 7。
(720 小時 / 30 天 = 24 小時,就是都免費)
data:image/s3,"s3://crabby-images/50ecf/50ecf9116ad266e794866c66af9183a051fd071c" alt=""
建立 VM 完成。
data:image/s3,"s3://crabby-images/aac99/aac995d137d132d678d1429e07f43c40356222d1" alt=""
預約靜態外部 IP
每當建立一個新的 VM 執行個體時,都會自動配發一個臨時外部 IP,但當您重啟 VM 時,這個臨時外部 IP 就會被回收,因此我們必須透過「預約靜態外部 IP」來保留一個固定 IP。
進入 VM 詳細資料。
data:image/s3,"s3://crabby-images/af6c3/af6c3958b3a917d6b3c9a687bb88d6e356a8fb78" alt=""
編輯 VM。
data:image/s3,"s3://crabby-images/364fd/364fd50184602c6e8f824de6b29e0652d5339fe1" alt=""
編輯 VM 網路介面。
data:image/s3,"s3://crabby-images/a2724/a2724941754518b465800ebe280a9e3bd69908b5" alt=""
編輯 VM 網路介面外部 IP。
data:image/s3,"s3://crabby-images/14300/14300659cfc47634e0f50da5da7ba8787622f3fb" alt=""
建立 VM 的外部 IP 位址。
data:image/s3,"s3://crabby-images/92294/922946211a52d431f4535c99f685bcbb5fa9d7c6" alt=""
VM 預約新的靜態外部 IP 位址。
data:image/s3,"s3://crabby-images/9ed3b/9ed3bbaa7b078f3968eef3dad95f9e89f55ce30e" alt=""
VM 預約新的靜態外部 IP 位址完成。
data:image/s3,"s3://crabby-images/815df/815df96213ae70a6f60ad7df498bad321c2d8295" alt=""
編輯 VM 完成儲存。
data:image/s3,"s3://crabby-images/5fc85/5fc852000f9b1bb7b41a5875b5583da8cccdd97b" alt=""
VM 預約新的靜態外部 IP 設定完成。
data:image/s3,"s3://crabby-images/f2d7c/f2d7c6370160a96592cdf1e9b4cff350843d7a53" alt=""
SSH 連結 VM
使用 SSH (Secure Shell,安全外殼協定) 連結 VM 最常用的兩種方式。
在瀏覽器視窗開啟
Google Cloud 預設提供「在瀏覽器視窗中開啟」與 VM 的 SSH 連結。
data:image/s3,"s3://crabby-images/dcc72/dcc72739c6e09a7f437d2cd8b2082b3235434482" alt=""
連結 VM 中...
data:image/s3,"s3://crabby-images/d1533/d1533d7b9e55bb2fc56458378c47946674dc44fe" alt=""
已連結至 VM。
data:image/s3,"s3://crabby-images/ea38d/ea38d1204a7cbfbe36bfe3fe0c71306582f54764" alt=""
PieTTY
在 Windows 可以使用 PieTTY 或 PuTTY 軟體,連結 Google Cloud VM 執行個體。
至 PieTTY project 下載並執行軟體後,點擊「PuTTY 模式」。
data:image/s3,"s3://crabby-images/3037b/3037beb37783cd460319d407bce52dfe8825e633" alt=""
data:image/s3,"s3://crabby-images/662f5/662f5e00544ce43e67fa1e2f59667b19cec85a73" alt=""
輸入 Google Cloud VM 的外部 IP。
data:image/s3,"s3://crabby-images/ef30c/ef30c55080d1c97c5dcb442c39d71bde64d76ebd" alt=""
設定在新建立 SSH 金鑰製作好儲存的 Private Key,並開啟。
data:image/s3,"s3://crabby-images/4824a/4824a5b6dfa79522c2812a0dbc65cdf68b923d6c" alt=""
data:image/s3,"s3://crabby-images/dd004/dd00400a659daac244a0346cff5ca23fccf2026d" alt=""
成功連結 VM,輸入使用者名稱 (就是在新建立 SSH 金鑰時自訂的)。
data:image/s3,"s3://crabby-images/15037/15037078b31108a3bd6780565a5cb9827e0fb703" alt=""
儲存設定,這樣下次就不用再重新設定一次。
data:image/s3,"s3://crabby-images/61d99/61d999f6f888cf98eb4a7db4aff067d8a928a8af" alt=""
data:image/s3,"s3://crabby-images/1610e/1610edceab6d3b996db3cbf73e0da71985a17b22" alt=""
使用 root 帳戶
執行這個指令即可切換至 root 帳戶 (無須密碼):
sudo su
使用 WinSCP 傳輸檔案
Windows 可透過 WinSCP 軟體使用 SCP (Secure Copy,安全複製),來與 Google Cloud VM 傳輸檔案。
至 WinSCP 下載安裝並執行軟體後,點擊「Advanced」進入進階設定。
data:image/s3,"s3://crabby-images/d7390/d7390bd9b86590cec3fa39cf2ed6dc125e6efbe2" alt=""
設定在新建立 SSH 金鑰製作好儲存的 Private Key。
data:image/s3,"s3://crabby-images/4d8b8/4d8b86db9d64d8daae0482dbc27a44e4debbe372" alt=""
- File protocol:SCP。
- Host name:輸入 Google Cloud VM 的外部 IP。
- User name:使用者名稱 (就是在新建立 SSH 金鑰時自訂的)。
點擊「Login」登入。
data:image/s3,"s3://crabby-images/fa77f/fa77f32de2227fcd709f30eed50d2d61d5426988" alt=""
data:image/s3,"s3://crabby-images/4cad8/4cad8ca38632cecb92861ad10e7b2bd1a418d7ef" alt=""
data:image/s3,"s3://crabby-images/29663/296637898f2fb81689de4df294a23d5739daa7a7" alt=""
成功連結 Google Cloud VM。
data:image/s3,"s3://crabby-images/97822/97822ab1b5503e4b38843a7887b91e49a51dacc0" alt=""
一般帳戶登入切換至 root
修改 SCP Shell 設定為 sudo su -
,在連結後會自動切換自 root 帳戶。
data:image/s3,"s3://crabby-images/2ff1b/2ff1b71603e08f148311eefd0b2af437cc63672b" alt=""
SSH 金鑰
新建立
於 Windows 建立新的 SSH 金鑰,必須透過第三方工具 PuTTY Key Generator。至 PuTTY 依 OS (Operating System,作業系統)位元下載 puttygen.exe。
執行 puttygen.exe,點擊 Generate 來產生 public/private key。
data:image/s3,"s3://crabby-images/7991b/7991b34b6ba18aab3e8ba616130125bd0ae45bc9" alt=""
data:image/s3,"s3://crabby-images/1092b/1092b5d30167629a6fc9071dae2bf9e480a5b8fb" alt=""
- 產生 public/private key 完成,可自訂「Key comment」(也就是到時登入系統的使用者名稱),這裡我設定 jacky 這個使用者 (修改同時可看到上方的「Public key ...」也會跟著修改)。
- 點擊「Save public key」和「Save private key」,儲存產生的 public/private key (PieTTY 連結 VM 和 WinSCP 與 VM 傳輸檔案要使用)。
- 複製上方的 SSH「Public key ...」(下面的加入 VM 要使用)。
data:image/s3,"s3://crabby-images/e004f/e004f64445d16cad6d115ab3f568d85126ea0d00" alt=""
data:image/s3,"s3://crabby-images/d500c/d500c7008d7748b757e8c39e5e82a092f74bd1f4" alt=""
加入 VM
將 puttygen.exe 產生的 SSH「Public key ...」加入 VM。
進入 VM 詳細資料。
data:image/s3,"s3://crabby-images/5d36d/5d36d821ec2d6c340c2daaad67a394dd1e83d550" alt=""
編輯 VM 的 SSH 金鑰。
data:image/s3,"s3://crabby-images/72a91/72a916f7e42e6ee2f79e5756686856aaef9bf07f" alt=""
貼上 puttygen.exe 產生的 SSH「Public key ...」並儲存。
data:image/s3,"s3://crabby-images/ac450/ac4508978d576bd9cf3b69205f4ce4d53713bc20" alt=""
SSH 金鑰加入 VM 完成。
data:image/s3,"s3://crabby-images/3b955/3b955b4dc642fe11e84dae97e1df6cb5d89f4de3" alt=""
CentOS 7 設置
語系
查看目前系統語系。(Google Cloud VM 安裝的 CentOS 7 語系預設為 en_US)
locale
LANG=en_US.UTF-8 LC_CTYPE="en_US.UTF-8" LC_NUMERIC="en_US.UTF-8" LC_TIME="en_US.UTF-8" LC_COLLATE="en_US.UTF-8" LC_MONETARY="en_US.UTF-8" LC_MESSAGES="en_US.UTF-8" LC_PAPER="en_US.UTF-8" LC_NAME="en_US.UTF-8" LC_ADDRESS="en_US.UTF-8" LC_TELEPHONE="en_US.UTF-8" LC_MEASUREMENT="en_US.UTF-8" LC_IDENTIFICATION="en_US.UTF-8" LC_ALL=
將語系設定為中文台灣。
localectl set-locale LANG=zh_TW.utf8
重新登入後再查看目前系統語系,已設為中文台灣。
locale
LANG=zh_TW.utf8 LC_CTYPE="zh_TW.utf8" LC_NUMERIC="zh_TW.utf8" LC_TIME="zh_TW.utf8" LC_COLLATE="zh_TW.utf8" LC_MONETARY="zh_TW.utf8" LC_MESSAGES="zh_TW.utf8" LC_PAPER="zh_TW.utf8" LC_NAME="zh_TW.utf8" LC_ADDRESS="zh_TW.utf8" LC_TELEPHONE="zh_TW.utf8" LC_MEASUREMENT="zh_TW.utf8" LC_IDENTIFICATION="zh_TW.utf8" LC_ALL=
時區
查看目前系統時區。(Google Cloud VM 安裝的 CentOS 時區預設為 UTC)
timedatectl
Local time: 六 2019-04-27 13:11:53 UTC
Universal time: 六 2019-04-27 13:11:53 UTC
RTC time: 六 2019-04-27 13:11:53
Time zone: UTC (UTC, +0000)
NTP enabled: yes
NTP synchronized: yes
RTC in local TZ: no
DST active: n/a
將時區設定為亞洲/台北。
timedatectl set-timezone Asia/Taipei
重新登入後再查看目前系統時區,已設為亞洲/台北。
timedatectl
Local time: 六 2019-04-27 21:19:19 CST
Universal time: 六 2019-04-27 13:19:19 UTC
RTC time: 六 2019-04-27 13:19:19
Time zone: Asia/Taipei (CST, +0800)
NTP enabled: yes
NTP synchronized: yes
RTC in local TZ: no
DST active: n/a
使用 SendGrid 傳送電子郵件
雖然 Google Cloud VM 安裝的 CentOS 7 預設就包含 Postfix 電子郵件伺服器 (Mail Server),但 Google Cloud 的 Compute Engine 不允許 SMTP 通訊埠 25 與 SMTPS 通訊埠 465、587 傳出連線,也就是 SMTP 與 SMTPS 的通訊埠會遭到封鎖,因為這些通訊埠容易被大量濫用。
雖然可以自訂 Postfix 的其它通訊埠,但建議使用擁有信任的第三方供應商 (如 SendGrid),可減輕 Google Cloud 的 Compute Engine 與我們維持良好 IP 記錄的壓力。
訂閱 SendGrid
前往 Google Cloud Platform Marketplace 或至 Marketplace 來訂閱 SendGrid Email。
data:image/s3,"s3://crabby-images/7f71e/7f71e1266dd2133b19ae32a0ad0f63db3a45d295" alt=""
data:image/s3,"s3://crabby-images/7ef63/7ef637a990f19da07e8986062a8c493a293f8703" alt=""
選擇 SendGrid Email 的 Free 方案。
data:image/s3,"s3://crabby-images/5c7e0/5c7e03af83a2129d802be22ef41ddb5decc2d78f" alt=""
前往註冊「SendGrid」。
data:image/s3,"s3://crabby-images/0f739/0f739541865a5a0326ba0b12f1921d28df0dac4b" alt=""
填寫註冊資訊
data:image/s3,"s3://crabby-images/efbb8/efbb895615d83928465b4791f1abdd2c20fbf1df" alt=""
允許 SendGrid 存取 Google 帳戶。
data:image/s3,"s3://crabby-images/978e1/978e1969e936a35d91ce36edfafc6c6da44379fb" alt=""
註冊完成。
data:image/s3,"s3://crabby-images/d9b2c/d9b2cbe96555713790504fee0f9024401d078c7a" alt=""
Google Cloud SendGrid Email 訂閱完成。
data:image/s3,"s3://crabby-images/29b22/29b229092ec9b59e3089d4bc40bcd3473e854a90" alt=""
申請 SendGrid API Key
點擊「在 SendGrid 網站上管理 API 金鑰」來申請 API Key。
data:image/s3,"s3://crabby-images/06e94/06e946daaa7aaa76a0da81b3935bf844b53b4640" alt=""
認證 Email (預設為剛才允許存取 Google 的帳戶 Email)。
data:image/s3,"s3://crabby-images/7e1ab/7e1abc6549f9537c6eec129c23b10e2551249808" alt=""
認證 Email 確認信。
data:image/s3,"s3://crabby-images/93e6b/93e6b8db2d9968381337f569d06291ce60b3121d" alt=""
產生 API Key。
data:image/s3,"s3://crabby-images/f1dfd/f1dfd51c6a505f28624e24050ae90909be427c0e" alt=""
選擇 API Key 的權限 (自己使用的,選取 Full Access 即可)。
data:image/s3,"s3://crabby-images/18a55/18a555a0351a9bd7f0a9de6145388f3626276289" alt=""
產生的 API Key。
data:image/s3,"s3://crabby-images/424e5/424e52042506772da731b3cca7c001ada93454c4" alt=""
Postfix
安裝相關套件。
yum install postfix cyrus-sasl-plain cyrus-sasl-md5 -y
修改 Postfix 設定檔,在結尾處加入這些設定。
vim /etc/postfix/main.cf
# ... 以上省略 ... # 新增 SendGrid SMTP 服務與使用的通訊埠 (Compute Engine 不允許使用通訊埠 25 和 587,因此請務必使用通訊埠 2525) relayhost = [smtp.sendgrid.net]:2525 # 強制執行安全資料傳輸層 (SSL)/傳輸層安全標準 (TLS) 支援,並設定 STMP 驗證 smtp_tls_security_level = encrypt smtp_sasl_auth_enable = yes smtp_sasl_password_maps = hash:/etc/postfix/sasl_passwd header_size_limit = 4096000 smtp_sasl_security_options = noanonymous
使用 SendGrid 帳戶產生的 API Key 來產生 SASL 密碼對應 (將紅字改為您的 API Key 即可)。
vim /etc/postfix/sasl_passwd
[smtp.sendgrid.net]:2525 apikey:SG.xxxxxxxxxxxxxxxxxxxxxx.xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
產生 .db 檔。
postmap /etc/postfix/sasl_passwd
為確保安全性,刪除內含 API Key 的檔案 (該檔案已產生 .db 檔,因此也不需要了)。
rm /etc/postfix/sasl_passwd
設定 .db 檔案權限,並確認其它檔案都已刪除。
chmod 600 /etc/postfix/sasl_passwd.db
ls -al /etc/postfix/sasl_passwd*
-rw-------. 1 root root 12288 5月 2 23:24 /etc/postfix/sasl_passwd.db
重新載入 Postfix 設定:
postfix reload
SELinux 設定
SELinux (Security Enhanced Linux,安全增强式 Linux),預設不允許透過網頁伺服器傳送電子郵件:
getsebool -a | grep httpd_can_sendmail
httpd_can_sendmail --> off
設定 SELinux 允許網頁伺服器傳送電子郵件:
setsebool -P httpd_can_sendmail=1
確認設定:
getsebool -a | grep httpd_can_sendmail
httpd_can_sendmail --> on
寄發 Email 測試
安裝寄發 Email 套件。
yum install mailx -y
寄發 Email。
echo 'message' | mail -s subject a.b@gmail.com
查看系統 Email 記錄檔,在 status=sent
顯示成功的回應 250 ok
,代表已寄發 Email 成功。
tail -n 5 /var/log/maillog
May 2 23:52:41 centos7-lemp postfix/smtp[3890]: 304161012FE4: to=<a.b@gmail.com>, relay=smtp.sendgrid.net[167.89.123.58]:2525, delay=13141, delays=13140/0.04/0.36/0.06, dsn=2.0.0, status=sent (250 Ok: queued as eBBmgQliRvi0OTtWBfYm2Q) May 2 23:52:41 centos7-lemp postfix/qmgr[3432]: 304161012FE4: removed May 3 00:02:41 centos7-lemp postfix/qmgr[3432]: 49F701012FE5: from=<root@centos7-lemp.localdomain>, size=466, nrcpt=1 (queue active) May 3 00:02:41 centos7-lemp postfix/smtp[4094]: 49F701012FE5: to=<a.b@gmail.com>, relay=smtp.sendgrid.net[169.47.148.162]:2525, delay=13230, delays=13230/0.05/0.26/0.08, dsn=2.0.0, status=sent (250 Ok: queued as iaLpsQy0T7iWxSGWHPdc8g) May 3 00:02:41 centos7-lemp postfix/qmgr[3432]: 49F701012FE5: removed
data:image/s3,"s3://crabby-images/96fb9/96fb900f8072af0831794f4b29bdc1e1d1c54198" alt="創用 CC 授權條款"
本著作係採用創用 CC 姓名標示-相同方式分享 3.0 台灣 授權條款授權.