iT邦幫忙

2022 iThome 鐵人賽

DAY 29
0
Modern Web

MERN Stack + Tailwind CSS - React 小專案實踐計畫系列 第 29

【Day 29】專案部署 - Railway

  • 分享至 

  • xImage
  •  

Railway

https://ithelp.ithome.com.tw/upload/images/20221014/20152502g3v9XtoYEM.png

因為 Heroku 把免費專案取消了,所以這次來試試另一個平台 - Railway

首先先登入帳號,直接使用 GitHub 登入,然後記得同意他們的政策

https://ithelp.ithome.com.tw/upload/images/20221014/201525025DFC42GMU6.png

登入後會發現每個月都有免費的容量可以使用~很適合拿來放用來練習的專案或作品集!(希望不要很快變成付費的…)

https://ithelp.ithome.com.tw/upload/images/20221014/20152502cinTe4CkQ4.png

開始部署前…

之前我習慣將前後端會分別放在不同的 repository,所以這次放在一起的狀況下要發布的時候遇到很多沒遇過的問題 orz 試了一整天都失敗…所以在火燒眉毛之際,參考了 https://create-react-app.dev/docs/integrating-with-an-api-backend (Node)的教學,於是決定改變檔案架構跟部署方式:

/*** Before ***/
bb-log/
├─ client/
├─ server/
├─ .gitignore
├─ .prettierignore
├─ .prettierrc

/*** After ***/
bb-log/
├─ client/
├─ controllers/
├─ models/
├─ node_modules/
├─ routes/
├─ .env
├─ .gitignore
├─ .prettierignore
├─ .prettierrc
├─ index.js
├─ package.json
├─ yarn.lock

將 server/ 內的檔案移出來到 root directory

https://ithelp.ithome.com.tw/upload/images/20221014/20152502REf0n2SahE.png

開始部署!

接著來新增專案:

  • 回到首頁
  • Create a New Project

https://ithelp.ithome.com.tw/upload/images/20221014/20152502znM3LKtMzW.png

選擇從 GitHub 的 repository 部署

https://ithelp.ithome.com.tw/upload/images/20221014/20152502ULEDUnnHn1.png

依照指示設定存取 GitHub 的權限

https://ithelp.ithome.com.tw/upload/images/20221014/20152502W8S9kQD2h2.png

這邊可以選擇允許存取所有 repo 或是指定的 repo

https://ithelp.ithome.com.tw/upload/images/20221014/20152502cZ6kirrSqa.png

接著就是選擇要部署的 repository

https://ithelp.ithome.com.tw/upload/images/20221014/20152502Ehh6cAIhA1.png

部署 server

在 Deploy 前先來設定我們放在 .env 中的環境變數

https://ithelp.ithome.com.tw/upload/images/20221014/201525025fVdSWQTkb.png

點擊會跳到這個頁面

https://ithelp.ithome.com.tw/upload/images/20221014/20152502ApqVEIMncs.png

接著將環境變數一個一個放進去即可~(在修改任何內容時,應該都會觸發自動 Deploy)

https://ithelp.ithome.com.tw/upload/images/20221014/20152502mfrIRTXeMq.png

等一下下後就能看到 server 部署成功的 Success 啦~

https://ithelp.ithome.com.tw/upload/images/20221014/201525026Jyp3x4weg.png

可以點擊旁邊的「Settings」來設定這個 repository 的名稱及產生專屬的網址 Domain

https://ithelp.ithome.com.tw/upload/images/20221014/20152502ewfonJprht.png

因為這主要用來架設我們的 server,所以修改一下名稱及 Domain

https://ithelp.ithome.com.tw/upload/images/20221014/20152502JGaRKctlt9.png

https://ithelp.ithome.com.tw/upload/images/20221014/20152502OY2zBgCDfK.png

部署 client

接著來部署我們使用 React 打造的前端頁面,點右上角的叉叉符號就能看到這個畫面,然後一樣匯入 repository (bb-log)

https://ithelp.ithome.com.tw/upload/images/20221014/20152502rXICFR1UBl.png

https://ithelp.ithome.com.tw/upload/images/20221014/20152502ngIsjVsqb4.png

接著將 Root Directory 改成 /client

https://ithelp.ithome.com.tw/upload/images/20221014/20152502W6j5A6Egu4.png

然後新增環境變數(剛剛部署 server 的 Domain)

https://ithelp.ithome.com.tw/upload/images/20221014/20152502UIOJtmTqdy.png

後來在 client/api/index.js 中我使用了 React 的環境變數 → 建立 .env 檔案,環境變數必須以 REACT_APP_ 開頭

https://ithelp.ithome.com.tw/upload/images/20221014/20152502sIP0voztUK.png

結果竟然失敗 Failed 了… 原來是忘記設定 CI = false(是大寫 CI 不是 CL 呦!

https://ithelp.ithome.com.tw/upload/images/20221014/20152502cmWw4EsJZv.png

https://ithelp.ithome.com.tw/upload/images/20221014/20152502hv6BqUEzYt.png

然後產生 Domain~~~

https://ithelp.ithome.com.tw/upload/images/20221014/20152502WWvgtebxzH.png

原本以為這次成功了…結果出現了這樣的畫面「 Invalid Host header」

https://ithelp.ithome.com.tw/upload/images/20221014/201525023WFwt95dhO.png

上網查了資料,新增環境變數 DANGEROUSLY_DISABLE_HOST_CHECK = true

https://ithelp.ithome.com.tw/upload/images/20221014/20152502hFer1cFelI.png

統整一下 /client 部署的環境變數:

CI = false
DANGEROUSLY_DISABLE_HOST_CHECK = true
REACT_APP_API_BASE_URL = 專案的server網址

謝天謝地~ 終於成功完成部署啦!!!

https://ithelp.ithome.com.tw/upload/images/20221014/20152502PwBxacKNgw.png

DEMO 網址:https://bb-log.up.railway.app/

GitHub Repository:https://github.com/BeanBeam11/bb-log(請忽略後面有一堆嘗試錯誤的 commit…)

參考資料:


上一篇
【Day 28】調整專案細節
下一篇
【Day 30】總結 & 心得
系列文
MERN Stack + Tailwind CSS - React 小專案實踐計畫30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

1 則留言

0
magic0308
iT邦新手 2 級 ‧ 2022-12-11 22:00:49

剛好在找新的主機,謝謝你的分享!

我要留言

立即登入留言