首頁 > web前端 > js教程 > 主體

教你在heroku雲端平台上部署Node.js應用程式_node.js

WBOY
發布: 2016-05-16 16:40:46
原創
1355 人瀏覽過

雖然AWS現在也推出了自己的PaaS平台,叫Elastic Beanstalk,但heroku的優點在於它上面有很多第三方的add-on,例如MongoDB,mysql, redis, memcached, 還有各種訊息佇列、 sms和郵件、後台批次、搜尋、自動化監控等插件,從生態環境的角度來說比AWS還是強​​很多。

這也就是說,heroku上有現成的Node.js PaaS運行環境,還有很多add-on,每天會自動把資料備份到AWS S3上,你只需要用git命令把代碼push上去就行了,其他的什麼都不用管。對咱們程式猿來說,世界上還有比這更爽的事嗎?

所以,為了造福網友,俺今天就把部署的幾個小步驟總結一下。

假設你已經有了一個叫sample的node.js應用,程式碼放在/Home/Apps/sample9527下,目錄下有你的伺服器端核心js檔案server.js,現在你已經cd到了這個目錄下。

為了讓heroku辨識你的應用,需要在這個目錄下加入一個檔案Procfile,內容是一行程式碼:

web: node server.js

登入後複製

(這裡的 web: node 是告訴heroku你要部署的是一個node.js web應用,後面的server.js 就是你的伺服器端核心程式碼檔名)

好,現在部署工作可以開始了。

首先,你需要到 www.heroku.com 上註冊一個用戶,用戶名是你的郵箱地址。然後安裝 Heroku Toolbelt ,這是一個命令列工具,可以讓你直接在shell裡用命令發布程式碼,查看系統狀態,修改伺服器配置,等等。

然後在shell裡用heroku login指令登錄,輸入你的使用者名稱和密碼即可。

$ heroku login

登入後複製

第一步可以用foreman start指令檢查一下你的程式碼是否能順利在heroku上執行,如果看到輸出沒有報錯,那就說明基本上正常。

$ foreman start

登入後複製

然後就是用git同步程式碼:

$ git init

$ git add .

$ git commit -m "init"

登入後複製

建立heroku應用程式:

$ heroku create sample9527

登入後複製

如果sample9527這個app名在heroku上沒有人用,那麼你會創建成功,應用的連結就是http://sample9527.herokuapp.com/,不然就改個名字接著試,或直接用heroku create讓它幫你取一個新名字。

如果需要安裝一些資料庫之類的插件,可以看看它有什麼add-on可用,然後在命令列加入。例如加入一個MongoLab提供的MongoDB資料庫:

$ heroku addons:add mongolab

登入後複製

(大部分add-on需要你在使用者資料中填入信用卡,但是如果選用免費版本則不會被扣費,放心吧)

然後就可以同步程式碼了:

$ git push heroku master

登入後複製

同步之後,heroku會自動依照npm配置下載和安裝必要的dependencies,然後啟動你的應用程式。

現在可以到應用程式連結看是否正常,如果有錯誤,可以在命令列查看日誌:

$ heroku logs

登入後複製

根據日誌中的錯誤訊息修改程式碼後,可以再次提交程式碼:

$ git commit -a -m "update some code"

$ git push heroku master

登入後複製

或是在需要時直接用restart指令重啟服務:

$ heroku restart

登入後複製

heroku的初級玩法基本上就是這些了,夠簡單吧?自己去試試嗆。

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板