[day29][部屬] heroku託管伺服器與github的結合,超簡單的自動化部屬



heroku,免費託管伺服器

終於走到了這一步,最後的最後就是將伺服器託管道雲端了!在這過程你用過了雲端資料庫、webpack、typescript和vue等等東西,最後就是將你的成果部屬到伺服器!並利用heroku已經整合好的自動化佈署讓你每次推完就立刻更新伺服器,開始註冊吧!

https://www.heroku.com/

使用與註冊可以參考這個網站搭配 Git 在 Heroku 上部署網站的手把手教學
輸入基本資料
https://ithelp.ithome.com.tw/upload/images/20201012/20130673Tnn9doHW3I.jpg
然後會寄出ㄧ封信,前往開啟連結後輸入密碼
https://ithelp.ithome.com.tw/upload/images/20201012/20130673RIU8BdGThp.jpg
同意...你也沒辦法拒絕不是嗎?
https://ithelp.ithome.com.tw/upload/images/20201012/20130673hwmQTKhbMG.jpg

進入登入完成的畫面!

https://ithelp.ithome.com.tw/upload/images/20201012/20130673p2tqy81MZb.jpg

https://ithelp.ithome.com.tw/upload/images/20201012/201306739ZEkfVg35I.jpg

https://ithelp.ithome.com.tw/upload/images/20201012/20130673mtslqOFusB.jpg

接著利用github自動佈署

https://ithelp.ithome.com.tw/upload/images/20201012/20130673EhWrZDNHZR.jpg

https://ithelp.ithome.com.tw/upload/images/20201012/20130673rFDIFsV5GB.jpg

搜尋你建立的專案

https://ithelp.ithome.com.tw/upload/images/20201012/20130673SziNOIAi8r.jpg

這樣就算完成了!

https://ithelp.ithome.com.tw/upload/images/20201012/20130673h5en1uhvyr.jpg

接著啟用自動佈署

https://ithelp.ithome.com.tw/upload/images/20201012/201306739zVyjC9X9L.jpg

然後讓我們最後開啟VScode進行ㄧ些heroku用的設定!heroku的設定主要是在package上,當你啟用自動化部屬後專案推到github就會自動部屬到heroku!然後heroku會自動執行"npm start"這個命令腳本。但是這個專案直接執行"npm start"是會失敗的!必須先執行過weboack的編譯後才能使用,所以這邊追加給heroku專用的命令腳本"heroku-postbuild"並下"webpack -d"就可以了(webpack -d的意思是跑開發設定,細節過多不再討論範圍)

package.json

{
  "name": "ithome_30day",
  "version": "1.0.0",
  "description": "IT邦邦忙鐵人賽用git檔案",
  "main": "index.js",
  "scripts": {
    "start": "nodemon dist/index.bundle.js",
    "test": "echo \"Error: no test specified\" && exit 1",
    "webpack": "webpack -d -w",
    "heroku-postbuild": "webpack -d"
  },
  略
}

然後開啟Sourcetree進行"commit"後推上去就完成自動部屬了!

如果你跟我ㄧ樣試另開分支的話,那回到heroku點選該分支並手動部屬

https://ithelp.ithome.com.tw/upload/images/20201012/20130673YIMiOv1JP4.jpg

他會顯示部屬完成,你可以點開view直接開啟那個網頁!

然後你會發現他壞掉了...因為在"package.json"中"start"使用的指令是要用"nodemon"起動伺服器,但是"nodemon"在"package.json"內是開發中使用的套件。這樣會導致heroku不會將他引進你的環境下執行,所以這邊要進行修改

package.json

{
  "name": "ithome_30day",
  "version": "1.0.0",
  "description": "IT邦邦忙鐵人賽用git檔案",
  "main": "index.js",
  "scripts": {
    "start": "node dist/index.bundle.js",
    "test": "echo \"Error: no test specified\" && exit 1",
    "webpack": "webpack -d -w",
    "heroku-postbuild": "webpack -d"
  },
略

接著直接推到你的那個分支,heroku就會進行自動部屬了!

https://ithelp.ithome.com.tw/upload/images/20201012/20130673X0IjOHrWDt.jpg

可以點開logs看看你的伺服器運行的狀態,或是點open app前往就可以看到你的網頁了!現在伺服器就正式部屬到雲端伺服器了!

githubday29

張貼留言

0 留言