教你在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 相关文章推荐
关于viewport,Ext.panel和Ext.form.panel的关系
May 07 Javascript
javascript基础知识大集锦(一) 推荐收藏
Jan 13 Javascript
JavaScript 的继承
Oct 01 Javascript
跨域请求之jQuery的ajax jsonp的使用解惑
Oct 09 Javascript
MooBox 基于Mootools的对话框插件
Jan 20 Javascript
不到30行JS代码实现Excel表格的方法
Nov 15 Javascript
WEB前端设计师常用工具集锦
Dec 09 Javascript
js实现键盘控制DIV移动的方法
Jan 10 Javascript
js获取对象、数组的实际长度,元素实际个数的实现代码
Jun 08 Javascript
connection reset by peer问题总结及解决方案
Oct 21 Javascript
几种响应式文字详解
May 19 Javascript
JavaScript实现队列结构过程
Dec 06 Javascript
浅析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
介绍几个array库的新函数 php
2006/12/29 PHP
PHP 无限分类三种方式 非函数的递归调用!
2011/08/26 PHP
php实现过滤表单提交中html标签的方法
2014/10/17 PHP
PHP如何通过AJAX方式实现登录功能
2015/11/23 PHP
PHP7安装Redis扩展教程【Linux与Windows平台】
2016/09/30 PHP
详解php中 === 的使用
2016/10/24 PHP
PHP自定义函数获取汉字首字母的方法
2016/12/01 PHP
PHP批斗大会之缺失的异常详解
2019/07/09 PHP
JavaScript实际应用:innerHTMl和确认提示的使用
2006/06/22 Javascript
JS Jquery 遍历,筛选页面元素 自动完成(实现代码)
2013/07/08 Javascript
我用的一些Node.js开发工具、开发包、框架等总结
2014/09/25 Javascript
在Google 地图上实现做的标记相连接
2015/01/05 Javascript
js实现文本框中输入文字页面中div层同步获取文本框内容的方法
2015/03/03 Javascript
跟我学习javascript的浮点数精度
2015/11/16 Javascript
ES6中字符串string常用的新增方法小结
2017/11/07 Javascript
echarts学习笔记之图表自适应问题详解
2017/11/22 Javascript
浅谈VUE监听窗口变化事件的问题
2018/02/24 Javascript
vue路由事件beforeRouteLeave及组件内定时器的清除方法
2018/09/29 Javascript
[04:37]DOTA2英雄梦之声Vol20发条
2014/06/20 DOTA
Python 3.x 连接数据库示例(pymysql 方式)
2017/01/19 Python
Python 通过pip安装Django详细介绍
2017/04/28 Python
Python pip替换为阿里源的方法步骤
2019/07/02 Python
python 实现识别图片上的数字
2019/07/30 Python
Pandas 缺失数据处理的实现
2019/11/04 Python
真正了解CSS3背景下的@font face规则
2017/05/04 HTML / CSS
计算机开发个人求职信范文
2013/09/26 职场文书
护理毕业生自我鉴定
2014/02/11 职场文书
大学新生军训自我鉴定
2014/03/18 职场文书
师德师风个人反思
2014/04/28 职场文书
公司离职证明标准范本
2014/10/05 职场文书
幼儿园感谢信
2015/01/21 职场文书
中学后勤工作总结2015
2015/07/22 职场文书
二十年同学聚会感言
2015/07/30 职场文书
治理商业贿赂工作总结
2015/08/10 职场文书
Python实现抖音热搜定时爬取功能
2022/03/16 Python
nginx实现多geoserver服务的负载均衡
2022/05/15 Servers