教你在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 相关文章推荐
jquery 图片上传按比例预览插件集合
May 28 Javascript
javascript jq 弹出层实例
Aug 25 Javascript
在jQuery中使用$而避免跟其它库产生冲突的方法
Aug 13 Javascript
jquery SweetAlert插件实现响应式提示框
Aug 18 Javascript
JavaScript运动框架 解决速度正负取整问题(一)
May 17 Javascript
seajs模块压缩问题与解决方法实例分析
Oct 10 Javascript
electron demo项目npm install安装失败的解决方法
Feb 06 Javascript
Vue 重置组件到初始状态的方法示例
Oct 10 Javascript
小程序分页实践之编写可复用分页组件
Jul 18 Javascript
JavaScript进制转换实现方法解析
Jan 18 Javascript
vue的hash值原理也是table切换实例代码
Dec 14 Vue.js
vue实现锚点定位功能
Jun 29 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
探讨如何把session存入数据库
2013/06/07 PHP
使用php实现快钱支付功能(涉及到接口)
2013/07/01 PHP
ThinkPHP3.1数据CURD操作快速入门
2014/06/19 PHP
php监测数据是否成功插入到Mysql数据库的方法
2016/11/25 PHP
详解php实现页面静态化原理
2017/06/21 PHP
json-lib出现There is a cycle in the hierarchy解决办法
2010/02/24 Javascript
JQuery跳出each循环的方法
2015/04/16 Javascript
javascript中new关键字详解
2015/12/14 Javascript
AngularJs bootstrap搭载前台框架——准备工作
2016/09/01 Javascript
connection reset by peer问题总结及解决方案
2016/10/21 Javascript
Bootstrap文件上传组件之bootstrap fileinput
2016/11/25 Javascript
使用JQ完成表格隔行换色的简单实例
2017/08/25 Javascript
JS简单添加元素新节点的方法示例
2018/02/10 Javascript
微信小程序实现刷脸登录
2018/05/25 Javascript
nodejs 十六进制字符串型数据与btye型数据相互转换
2018/07/30 NodeJs
Python线程的两种编程方式
2015/04/14 Python
在Django的模型中执行原始SQL查询的方法
2015/07/21 Python
为Python的Tornado框架配置使用Jinja2模板引擎的方法
2016/06/30 Python
Python实现利用最大公约数求三个正整数的最小公倍数示例
2017/09/30 Python
Python面向对象类编写细节分析【类,方法,继承,超类,接口等】
2019/01/05 Python
对python实现模板生成脚本的方法详解
2019/01/30 Python
Python OpenCV中的resize()函数的使用
2019/06/20 Python
python发送多人邮件没有展示收件人问题的解决方法
2019/06/21 Python
Python Lambda函数使用总结详解
2019/12/11 Python
Windows上安装tensorflow  详细教程(图文详解)
2020/02/04 Python
关于python3.9安装wordcloud出错的问题及解决办法
2020/11/02 Python
前后端结合实现amazeUI分页效果
2020/08/21 HTML / CSS
网站域名和主机:Domain.com
2019/04/01 全球购物
Abbacino官网:包、钱包和女士配饰
2019/04/15 全球购物
新加坡一家在线男士皮具品牌:Faire Leather Co.
2019/12/01 全球购物
C#中有没有静态构造函数,如果有是做什么用的?
2016/06/04 面试题
求职推荐信范文
2013/12/01 职场文书
歌颂祖国的演讲稿
2014/05/04 职场文书
python中requests库+xpath+lxml简单使用
2021/04/29 Python
vue实现无缝轮播效果(跑马灯)
2021/05/14 Vue.js
深入浅出讲解Java8函数式编程
2022/01/18 Java/Android