教你在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 相关文章推荐
window.showModalDialog使用手册
Jan 11 Javascript
jQuery中:file选择器用法实例
Jan 04 Javascript
jQuery实现感应鼠标动画效果自动伸长的输入框实例
Feb 24 Javascript
BooStrap对导航条的改造实践小结
Sep 21 Javascript
AngularJS实现星星等级评分功能
Sep 24 Javascript
微信小程序 实例应用(记账)详解
Sep 28 Javascript
AngularJS辅助库browserTrigger用法示例
Nov 03 Javascript
详解ECharts使用心得总结
Dec 06 Javascript
几个你不知道的技巧助你写出更优雅的vue.js代码
Jun 11 Javascript
mpvue写一个CPASS小程序的示例
Sep 04 Javascript
使用react context 实现vue插槽slot功能
Jul 18 Javascript
JavaScript实现简单拖拽效果
Sep 15 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
在PHP中利用XML技术构造远程服务(上)
2006/10/09 PHP
批量修改RAR文件注释的php代码
2010/11/20 PHP
如何利用php array_multisort函数 对数据库结果进行复杂排序
2013/06/08 PHP
PHP下获取上个月、下个月、本月的日期(strtotime,date)
2014/02/02 PHP
PHP实现单例模式建立数据库连接的方法分析
2020/02/11 PHP
js页面跳转常用的几种方式
2010/11/25 Javascript
面向对象Javascript核心支持代码分享
2012/05/23 Javascript
JS自动缩小超出大小的图片
2012/10/12 Javascript
js取整数、取余数的方法
2014/05/11 Javascript
jQuery插件slider实现拖动滑块选取价格范围
2015/04/30 Javascript
JavaScript设置、获取、清除单值和多值cookie的方法
2015/11/17 Javascript
Javascript基础_标记文字的实现方法
2016/06/14 Javascript
JS基于正则表达式的替换操作(replace)用法示例
2017/04/28 Javascript
web前端开发中常见的多列布局解决方案整理(一定要看)
2017/10/15 Javascript
除Console.log()外更多的Javascript调试命令
2018/01/24 Javascript
jQuery实现左右滑动的toggle方法
2018/03/03 jQuery
全站最详细的Vuex教程
2018/04/13 Javascript
vue-cli webpack 引入swiper的操作方法
2018/09/15 Javascript
Vue组件Draggable实现拖拽功能
2018/12/01 Javascript
vue子路由跳转实现tab选项卡
2019/07/24 Javascript
微信小程序实现收货地址左滑删除
2020/11/18 Javascript
详解基于element的区间选择组件校验(交易金额)
2021/01/07 Javascript
[03:39]DOTA2英雄梦之声_第05期_幽鬼
2014/06/23 DOTA
[01:19:11]Ti4 循环赛第二日 NaVi.us vs iG
2014/07/11 DOTA
python中pow函数用法及功能说明
2020/12/04 Python
实列教程 一款基于jquery和css3的响应式二级导航菜单
2014/11/13 HTML / CSS
欧洲品牌瓷器餐具网上商店:Porzellantreff.de
2018/04/04 全球购物
意大利奢侈品牌在线精品店:Jole.it
2020/11/23 全球购物
Java程序员常见面试题
2015/07/16 面试题
英语系本科生个人求职信
2013/09/21 职场文书
办公室保洁员岗位职责
2013/12/02 职场文书
同学聚会老师邀请函
2014/01/28 职场文书
党委班子剖析材料
2014/08/21 职场文书
个人总结与自我评价
2014/09/18 职场文书
创业计划书之农家乐
2019/10/09 职场文书
100句人生哲理语录集锦:强者征服今天,懒汉坐等明天
2019/10/18 职场文书