教你在heroku云平台上部署Node.js应用


Posted in Javascript onJuly 30, 2014

虽然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的初级玩法基本上就是这些了,够简单吧?自己去试试呗。

Javascript 相关文章推荐
纯js实现的论坛常用的运行代码的效果
Jul 15 Javascript
javascript计时器详解
Feb 28 Javascript
JS实现点击按钮自动增加一个单元格的方法
Mar 09 Javascript
AngularJS基础 ng-keypress 指令简单示例
Aug 02 Javascript
vue.js单页面应用实例的简单实现
Apr 10 Javascript
javascript中mouseenter与mouseover的异同
Jun 06 Javascript
JS 组件系列之Bootstrap Table 冻结列功能IE浏览器兼容性问题解决方案
Jun 30 Javascript
Vue利用History记录上一页面的数据方法实例
Nov 02 Javascript
NestJs 静态目录配置详解
Mar 12 Javascript
通过循环优化 JavaScript 程序
Jun 24 Javascript
JavaScript使用表单元素验证表单的示例代码
Aug 20 Javascript
解决vue elementUI 使用el-select 时 change事件的触发问题
Nov 17 Vue.js
浅析Node在构建超媒体API中的作用
Jul 30 #Javascript
JS实现图片无间断滚动代码汇总
Jul 30 #Javascript
使用jquery.upload.js实现异步上传示例代码
Jul 29 #Javascript
js动态添加onclick事件可传参数与不传参数
Jul 29 #Javascript
使用focus方法让光标默认停留在INPUT框
Jul 29 #Javascript
Node.js 服务器端应用开发框架 -- Hapi.js
Jul 29 #Javascript
node.js 开发指南 ? Node.js 连接 MySQL 并进行数据库操作
Jul 29 #Javascript
You might like
使用Curl进行抓取远程内容时url中文编码问题示例探讨
2013/10/29 PHP
PHP防止图片盗用(盗链)的方法小结
2016/11/11 PHP
Yii框架参数化查询中IN查询只能查询一个的解决方法
2017/05/20 PHP
ThinkPHP like模糊查询,like多匹配查询,between查询,in查询,一般查询书写方法
2018/09/26 PHP
基于jquery实现智能表单验证操作
2016/05/09 Javascript
JS生成不重复的随机数组的简单实例
2016/07/10 Javascript
vue2.0全局组件之pdf详解
2017/06/26 Javascript
深入讲解xhr(XMLHttpRequest)/jsonp请求之abort
2017/07/26 Javascript
JS实现利用两个队列表示一个栈的方法
2017/12/13 Javascript
JS实现移动端触屏拖拽功能
2018/07/31 Javascript
JavaScript禁用右键单击优缺点分析
2019/01/20 Javascript
JS如何实现手机端输入验证码效果
2020/05/13 Javascript
vue v-on:click传递动态参数的步骤
2020/09/11 Javascript
vant-ui组件调用Dialog弹窗异步关闭操作
2020/11/04 Javascript
javascript实现随机抽奖功能
2020/12/30 Javascript
利用JS判断元素是否为数组的方法示例
2021/01/08 Javascript
[01:46]TI4西雅图DOTA2前线报道 中国选手抱团调时差
2014/07/08 DOTA
python中使用百度音乐搜索的api下载指定歌曲的lrc歌词
2014/07/18 Python
特征脸(Eigenface)理论基础之PCA主成分分析法
2018/03/13 Python
PyQt5每天必学之布局管理
2018/04/19 Python
pytorch AvgPool2d函数使用详解
2020/01/03 Python
Python 实现自动完成A4标签排版打印功能
2020/04/09 Python
python查看矩阵的行列号以及维数方式
2020/05/22 Python
python实现PolynomialFeatures多项式的方法
2021/01/06 Python
CSS3结构性伪类选择器九种写法
2012/04/18 HTML / CSS
利用HTML5绘制点线面组成的3D图形的示例
2015/05/12 HTML / CSS
Html5在手机端调用相机的方法实现
2020/05/13 HTML / CSS
Columbia美国官网:美国著名的户外服装品牌
2016/11/24 全球购物
理肤泉加拿大官网:La Roche-Posay加拿大
2018/07/06 全球购物
Oracle中delete,truncate和drop的区别
2016/05/05 面试题
医学生个人求职信范文
2013/09/24 职场文书
大专生工程监理求职信
2013/10/04 职场文书
护理专业应届毕业生推荐信
2013/11/15 职场文书
投标承诺书范本
2014/03/27 职场文书
庆祝教师节新闻稿
2015/07/17 职场文书
vue数据字典取键值项目的字典问题
2022/04/12 Vue.js