教你在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 Mobile页面跳转后未加载外部JS原因分析及解决
Mar 18 Javascript
javascript 手动给表增加数据的小例子
Jul 10 Javascript
JavaScript中实现sprintf、printf函数
Jan 27 Javascript
text-align:justify实现文本两端对齐 兼容IE
Aug 19 Javascript
跟我学习javascript的this关键字
May 28 Javascript
jQuery动画效果相关方法实例分析
Dec 31 Javascript
15款最好的Bootstrap在线编辑器
Aug 03 Javascript
JavaScript中removeChild 方法开发示例代码
Aug 15 Javascript
详解AngularJS2 Http服务
Jun 26 Javascript
Javascript快速实现浏览器系统通知
Aug 26 Javascript
angular6 利用 ngContentOutlet 实现组件位置交换(重排)
Nov 02 Javascript
jQuery 实现扁平式小清新导航
Jul 07 jQuery
浅析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 mysql 判断update之后是否更新了的方法
2012/01/10 PHP
数据库中排序的对比及使用条件详解
2012/02/23 PHP
PHP随机字符串生成代码(包括大小写字母)
2013/06/24 PHP
php 实现301重定向跳转实例代码
2016/07/18 PHP
PHP类相关知识点实例总结
2016/09/28 PHP
js 点击按钮弹出另一页,选择值后,返回到当前页
2010/05/26 Javascript
js实现快速分享功能(你的文章分享工具)
2013/06/25 Javascript
Javascript 多浏览器兼容总结(实战经验)
2013/10/30 Javascript
Jquery中find与each方法用法实例
2015/02/04 Javascript
js将滚动条滚动到指定位置的简单实现方法
2016/06/25 Javascript
详解js实现线段交点的三种算法
2016/08/09 Javascript
jQuery基本选择器之标签名选择器
2016/09/03 Javascript
利用js的闭包原理做对象封装及调用方法
2017/04/07 Javascript
通过js动态创建标签,并设置属性方法
2018/02/24 Javascript
axios使用拦截器统一处理所有的http请求的方法
2018/11/02 Javascript
浅谈layer弹出层按钮颜色修改方法
2019/09/11 Javascript
vue vant Area组件使用详解
2019/12/09 Javascript
JavaScript实现简单的弹窗效果
2020/05/19 Javascript
JS判断数组是否包含某元素实现方法汇总
2020/06/24 Javascript
JS highcharts动态柱状图原理及实现
2020/10/16 Javascript
21行Python代码实现拼写检查器
2016/01/25 Python
Python字典简介以及用法详解
2016/11/15 Python
opencv中图像叠加/图像融合/按位操作的实现
2020/04/01 Python
Python selenium自动化测试模型图解
2020/04/15 Python
python能自学吗
2020/06/18 Python
CSS3 中的@keyframes介绍
2014/09/02 HTML / CSS
HTML5实现晶莹剔透的雨滴特效
2014/05/14 HTML / CSS
SISLEY希思黎官方旗舰店:享誉全球的奢华植物美容品牌
2018/04/25 全球购物
德国苹果商店:MacTrade
2020/05/18 全球购物
班组长岗位职责
2014/03/03 职场文书
财务部总监岗位职责
2014/03/12 职场文书
广告词串烧
2014/03/19 职场文书
人大调研汇报材料
2014/08/14 职场文书
查摆问题自查报告范文
2014/10/13 职场文书
房屋买卖协议样本
2014/11/16 职场文书
MySQL8.0的WITH查询详情
2021/08/30 MySQL