教你在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 计算两个整数的百分比值
Dec 26 Javascript
jquery ready()的几种实现方法小结
Jun 18 Javascript
javascript数组去重的六种方法汇总
Aug 16 Javascript
js实现适用于素材网站的黑色多级菜单导航条效果
Aug 24 Javascript
js如何打印object对象
Oct 16 Javascript
基于JavaScript实现右键菜单和拖拽功能
Nov 28 Javascript
JS闭包与延迟求值用法示例
Dec 22 Javascript
vue-cli项目中使用公用的提示弹层tips或加载loading组件实例详解
May 28 Javascript
vue框架搭建之axios使用教程
Jul 11 Javascript
微信小程序左滑删除功能开发案例详解
Nov 12 Javascript
js+canvas绘制图形验证码
Sep 21 Javascript
ant design pro中可控的筛选和排序实例
Nov 17 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 中的批处理的实现
2007/06/14 PHP
php遍历数组的方法分享
2012/03/22 PHP
php图片的裁剪与缩放生成符合需求的缩略图
2013/01/11 PHP
php实现三级级联下拉框
2016/04/17 PHP
laravel Validator ajax返回错误信息的方法
2019/09/29 PHP
使用jquery给input和textarea设定ie中的focus
2008/05/29 Javascript
js判断变量是否空值的代码
2008/10/26 Javascript
document.compatMode介绍
2009/05/21 Javascript
js 编程笔记 无名函数
2011/06/28 Javascript
JavaScript 类型的包装对象(Typed Wrappers)
2011/10/27 Javascript
实例讲解js验证表单项是否为空的方法
2016/01/09 Javascript
在Linux系统中搭建Node.js开发环境的简单步骤讲解
2016/01/26 Javascript
SelecT下拉框选中和取值的解决方法
2016/11/22 Javascript
JavaScript运动框架 多物体任意值运动(三)
2017/05/17 Javascript
Vue自定义属性实例分析
2019/02/23 Javascript
jQuery中each和js中forEach的区别分析
2019/02/27 jQuery
浅谈Vue页面级缓存解决方案feb-alive(上)
2019/04/14 Javascript
layui加载表格,绑定新增,编辑删除,查看按钮事件的例子
2019/09/06 Javascript
python网络编程学习笔记(二):socket建立网络客户端
2014/06/09 Python
python fabric实现远程部署
2017/01/05 Python
使用 Python 实现文件递归遍历的三种方式
2018/07/18 Python
在python中pandas读文件,有中文字符的方法
2018/12/12 Python
Python Datetime模块和Calendar模块用法实例分析
2019/04/15 Python
Python -m参数原理及使用方法解析
2020/08/21 Python
python实现MySQL指定表增量同步数据到clickhouse的脚本
2021/02/26 Python
意大利高端时尚买手店:Stefania Mode
2018/03/01 全球购物
会计实习生自我鉴定
2013/12/12 职场文书
最新大学职业规划书范文
2013/12/30 职场文书
企业总经理职责
2014/02/02 职场文书
幼儿园秋游感想
2014/03/12 职场文书
班组长竞聘书
2014/03/31 职场文书
《鸟岛》教学反思
2014/04/26 职场文书
环境科学专业教师求职信
2014/07/12 职场文书
办公室文员工作自我鉴定
2014/09/19 职场文书
党的群众路线教育实践活动个人对照检查材料(四风)
2014/11/05 职场文书
学校远程教育工作总结
2015/08/11 职场文书