教你在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 相关文章推荐
JavaScript中void(0)的具体含义解释
Feb 27 Javascript
jquery 仿QQ校友的DIV模拟窗口效果源码
Mar 24 Javascript
将string解析为json的几种方式小结
Nov 11 Javascript
JavaScript中的闭包(Closure)详细介绍
Dec 30 Javascript
JS+CSS实现的竖向简洁折叠菜单效果代码
Oct 22 Javascript
基于javascript实现动态显示当前系统时间
Jan 28 Javascript
jQuery中animate()的使用方法及解决$(”body“).animate({“scrollTop”:top})不被Firefox支持的问题
Apr 04 jQuery
jQuery制作全屏宽度固定高度轮播图(实例讲解)
Jul 08 jQuery
jquery如何实现点击空白处隐藏元素
Dec 05 jQuery
react脚手架如何配置less和ant按需加载的方法步骤
Nov 28 Javascript
vuex 动态注册方法 registerModule的实现
Jul 03 Javascript
学习 Vue.js 遇到的那些坑
Feb 02 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
php die()与exit()的区别实例详解
2016/12/03 PHP
短信提示使用 特效
2007/01/19 Javascript
JavaScript 输入框内容格式验证代码
2010/02/11 Javascript
javascript 判断数组是否已包含了某个元素的函数
2010/05/30 Javascript
使用jQuery.Validate进行客户端验证(初级篇) 不使用微软验证控件的理由
2010/06/28 Javascript
Node.js入门教程:在windows和Linux上安装配置Node.js图文教程
2014/08/14 Javascript
深入学习AngularJS中数据的双向绑定机制
2016/03/04 Javascript
基于js实现checkbox批量选中操作
2016/11/22 Javascript
jquery二级目录选中当前页的css样式
2016/12/08 Javascript
详解AngularJS通过ocLazyLoad实现动态(懒)加载模块和依赖
2017/03/01 Javascript
Angular中支持SCSS的方法
2017/11/18 Javascript
详解JavaScript中的函数、对象
2019/04/01 Javascript
详解ECMAScript2019/ES10新属性
2019/12/06 Javascript
vue - props 声明数组和对象操作
2020/07/30 Javascript
[43:36]Liquid vs Mineski 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
python两种遍历字典(dict)的方法比较
2014/05/29 Python
python 性能提升的几种方法
2016/07/15 Python
Python实现字符串格式化输出的方法详解
2017/09/20 Python
Python实现Event回调机制的方法
2019/02/13 Python
Python调用C语言的实现
2019/07/26 Python
python制作英语翻译小工具代码实例
2019/09/09 Python
Matplotlib自定义坐标轴刻度的实现示例
2020/06/18 Python
Python3 用什么IDE开发工具比较好
2020/11/28 Python
CSS3 animation实现简易幻灯片轮播特效
2016/09/27 HTML / CSS
中粮集团旗下食品网上购物网站:我买网
2016/09/22 全球购物
销售员自我评价怎么写
2013/09/19 职场文书
结婚典礼证婚词
2014/01/11 职场文书
公益广告宣传方案
2014/02/28 职场文书
募捐倡议书怎么写
2014/05/14 职场文书
小学生勤俭节约演讲稿
2014/08/28 职场文书
班子四风对照检查材料思想汇报
2014/09/29 职场文书
2015年党员公开承诺书范文
2015/01/22 职场文书
2015年社区综治工作总结
2015/04/21 职场文书
消防演习感想
2015/08/10 职场文书
银行求职信怎么写
2019/06/20 职场文书
python实现MD5进行文件去重的示例代码
2021/07/09 Python