教你在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 相关文章推荐
List Information About the Binary Files Used by an Application
Jun 18 Javascript
不间断滚动JS打包类,基本可以实现所有的滚动效果,太强了
Dec 08 Javascript
使用jQuery UI的tooltip函数修饰title属性的气泡悬浮框
Jun 24 Javascript
使用闭包对setTimeout进行简单封装避免出错
Jul 10 Javascript
原生的html元素选择器类似jquery选择器
Oct 15 Javascript
JavaScript基础函数整理汇总
Jan 30 Javascript
异步安全加载javascript文件的方法
Jul 21 Javascript
JavaScript的Backbone.js框架的一些使用建议整理
Feb 14 Javascript
原生JS实现跑马灯效果
Feb 20 Javascript
从零学习node.js之文件操作(三)
Feb 21 Javascript
详解Web使用webpack构建前端项目
Sep 23 Javascript
JavaScript 下载svg图片为png格式
Jun 21 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 email邮箱正则
2008/10/08 PHP
通过php修改xml文档内容的方法
2015/01/23 PHP
php实现过滤UBB代码的类
2015/03/12 PHP
基于jquery的兼容各种浏览器的iframe自适应高度的脚本
2010/08/13 Javascript
js unicode 编码解析关于数据转换为中文的两种方法
2014/04/21 Javascript
node.js中的fs.createWriteStream方法使用说明
2014/12/17 Javascript
jquery密码强度校验
2015/12/02 Javascript
自学实现angularjs依赖注入
2016/12/20 Javascript
jQuery Masonry瀑布流布局神器使用详解
2017/05/25 jQuery
Cpage.js给组件绑定事件的实现代码
2017/08/31 Javascript
vue 2.x 中axios 封装的get 和post方法
2018/02/28 Javascript
区别JavaScript函数声明与变量声明
2018/09/12 Javascript
vuejs router history 配置到iis的方法
2018/09/20 Javascript
vue.js的简单自动求和计算实例
2019/11/08 Javascript
JS内置对象和Math对象知识点详解
2020/04/03 Javascript
[41:12]Liquid vs Secret 2019国际邀请赛淘汰赛 败者组 BO3 第一场 8.24
2019/09/10 DOTA
Python 深入理解yield
2008/09/06 Python
Python实现的一个找零钱的小程序代码分享
2014/08/25 Python
python实现简单温度转换的方法
2015/03/13 Python
python获取本机mac地址和ip地址的方法
2015/04/29 Python
Python的装饰器模式与面向切面编程详解
2015/06/21 Python
举例讲解Python设计模式编程的代理模式与抽象工厂模式
2016/01/16 Python
详解appium+python 启动一个app步骤
2017/12/20 Python
python实现诗歌游戏(类继承)
2019/02/26 Python
Python之NumPy(axis=0 与axis=1)区分详解
2019/05/27 Python
Python内置类型性能分析过程实例
2020/01/29 Python
python GUI库图形界面开发之PyQt5菜单栏控件QMenuBar的详细使用方法与实例
2020/02/28 Python
美国现代家具网站:Design Within Reach
2018/07/19 全球购物
XML文档定义有几种形式?它们之间有何本质区别?解析XML文档有哪几种方式?
2016/01/12 面试题
转党组织关系介绍信
2014/01/08 职场文书
高中军训广播稿
2014/01/14 职场文书
工作收入证明模板
2014/10/10 职场文书
房产分割协议书范文
2014/11/21 职场文书
培训心得体会怎么写
2016/01/25 职场文书
《小蝌蚪找妈妈》教学反思
2016/02/23 职场文书
Html分层的box-shadow效果的示例代码
2021/03/30 HTML / CSS