教你在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监测ActiveX控件是否已经安装过的代码
Sep 02 Javascript
JavaScript中的Array对象使用说明
Jan 17 Javascript
关于JavaScript中的关联数组分析
Apr 09 Javascript
js验证电话号码与手机支持+86的正则表达式
Jan 23 Javascript
jquery实现弹出层遮罩效果的简单实例
Mar 03 Javascript
javascript实现base64 md5 sha1 密码加密
Sep 09 Javascript
基于Bootstrap实现Material Design风格表单插件 附源码下载
Apr 18 Javascript
Vue开发中整合axios的文件整理
Apr 29 Javascript
vue 修改 data 数据问题并实时显示的方法
Aug 27 Javascript
webpack 动态批量加载文件的实现方法
Mar 19 Javascript
jquery插件懒加载的示例
Oct 24 jQuery
vue-cli3.x配置全局的scss的时候报错问题及解决
Apr 30 Vue.js
浅析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
跟我学小偷程序之成功偷取首页(第三天)
2006/10/09 PHP
用PHP将数据导入到Foxmail
2006/10/09 PHP
php中的时间显示
2007/01/18 PHP
phpword插件导出word文件时中文乱码问题处理方案
2014/08/19 PHP
PHP+MySQL修改记录的方法
2015/01/21 PHP
PHP与JavaScript针对Cookie的读写、交互操作方法详解
2017/08/07 PHP
PHP实现微信支付(jsapi支付)流程步骤详解
2018/03/15 PHP
js left,right,mid函数
2008/06/10 Javascript
仅IE6/7/8中innerHTML返回值忽略英文空格的问题
2011/04/07 Javascript
JavaScript中清空数组的三种方法分享
2011/04/07 Javascript
jQuery内置的AJAX功能和JSON的使用实例
2014/07/27 Javascript
js根据手机客户端浏览器类型,判断跳转官网/手机网站多个实例代码
2016/04/30 Javascript
快速掌握jQuery插件WebUploader文件上传
2016/11/07 Javascript
VueJs组件prop验证简单介绍
2017/09/12 Javascript
Node.js静态服务器的实现方法
2018/02/28 Javascript
node.js命令行教程图文详解
2019/05/27 Javascript
Javascript Dom元素获取和添加详解
2019/09/24 Javascript
jQuery实现简单弹幕效果
2019/11/28 jQuery
JS常见内存泄漏及解决方案解析
2020/05/30 Javascript
vue-cli或vue项目利用HBuilder打包成移动端app操作
2020/07/29 Javascript
Python的Flask框架标配模板引擎Jinja2的使用教程
2016/07/12 Python
详解Python里使用正则表达式的ASCII模式
2017/11/02 Python
Python实现的朴素贝叶斯分类器示例
2018/01/06 Python
python+opencv+caffe+摄像头做目标检测的实例代码
2018/08/03 Python
从DataFrame中提取出Series或DataFrame对象的方法
2018/11/10 Python
创建Django项目图文实例详解
2019/06/06 Python
Django中间件拦截未登录url实例详解
2019/09/03 Python
jenkins+python自动化测试持续集成教程
2020/05/12 Python
Python实现给PDF添加水印的方法
2021/01/25 Python
详解CSS3选择器的使用方法汇总
2015/11/24 HTML / CSS
澳大利亚当地社区首选的光学商店:1001 Optical
2019/08/24 全球购物
main 函数执行以前,还会执行什么代码
2013/04/17 面试题
优秀实习生主要事迹
2014/05/29 职场文书
个人自我鉴定怎么写?
2019/07/01 职场文书
Python如何快速找到多个字典中的公共键(key)
2022/04/29 Python
el-form每行显示两列底部按钮居中效果的实现
2022/08/05 HTML / CSS