教你在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 相关文章推荐
URL编码转换,escape() encodeURI() encodeURIComponent()
Dec 27 Javascript
java script编程起步(第三课)
Jan 10 Javascript
juqery 学习之三 选择器 简单 内容
Nov 25 Javascript
浅析document.createDocumentFragment()与js效率
Jul 08 Javascript
JSON.parse()和JSON.stringify()使用介绍
Jun 20 Javascript
window.open()实现post传递参数
Mar 12 Javascript
JS实现点击上移下移LI行数据的方法
Aug 05 Javascript
JavaScript文档碎片操作实例分析
Dec 12 Javascript
vue项目tween方法实现返回顶部的示例代码
Mar 02 Javascript
angular4 获取wifi列表中文显示乱码问题的解决
Oct 20 Javascript
jQuery实现上下滚动公告栏详细代码
Nov 21 jQuery
js Proxy的原理详解
May 25 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记录搜索引擎蜘蛛访问网站足迹的方法
2015/04/15 PHP
thinkPHP自定义类实现方法详解
2016/11/30 PHP
两种WEB下的模态对话框 (asp.net或js的分别实现)
2009/12/02 Javascript
基于jQuery实现的当离开页面时出现提示的实现代码
2011/06/27 Javascript
浅析jQuery中常用的元素查找方法总结
2013/07/04 Javascript
javascript中createElement的两种创建方式
2015/05/14 Javascript
AngularJS的内置过滤器详解
2015/05/14 Javascript
解决node.js安装包失败的几种方法
2016/09/02 Javascript
利用JS实现点击按钮后图片自动切换的简单方法
2016/10/24 Javascript
整理一下常见的IE错误
2016/11/18 Javascript
jQuery 禁止表单用户名、密码自动填充功能
2017/10/30 jQuery
了解JavaScript中的选择器
2019/05/24 Javascript
Vue.js仿Select下拉框效果
2020/02/18 Javascript
JS 设计模式之:工厂模式定义与实现方法浅析
2020/05/06 Javascript
Vue是怎么渲染template内的标签内容的
2020/06/05 Javascript
python下如何让web元素的生成更简单的分析
2008/07/17 Python
在Python程序中实现分布式进程的教程
2015/04/28 Python
详解Django通用视图中的函数包装
2015/07/21 Python
Python实现TCP/IP协议下的端口转发及重定向示例
2016/06/14 Python
利用python爬取软考试题之ip自动代理
2017/03/28 Python
python之Character string(实例讲解)
2017/09/25 Python
python pandas.DataFrame选取、修改数据最好用.loc,.iloc,.ix实现
2018/06/11 Python
python如何创建TCP服务端和客户端
2018/08/26 Python
Pycharm 文件更改目录后,执行路径未更新的解决方法
2019/07/19 Python
keras实现多GPU或指定GPU的使用介绍
2020/06/17 Python
使用OpenCV去除面积较小的连通域
2020/07/05 Python
PyCharm中关于安装第三方包的三个建议
2020/09/17 Python
Python xmltodict模块安装及代码实例
2020/10/05 Python
Coltorti Boutique官网:来自意大利的设计师品牌买手店
2018/11/09 全球购物
Carolina Lemke Berlin澳大利亚官网:时尚太阳镜品牌
2019/09/17 全球购物
Java的类与C++的类有什么不同
2014/01/18 面试题
师范生实习个人的自我评价
2013/09/28 职场文书
高中军训感言200字
2014/02/23 职场文书
出生公证书样本
2014/04/04 职场文书
党支部遵守党的政治纪律情况对照检查材料
2014/09/26 职场文书
Mac电脑OS系统下安装Nginx的详细教程
2022/04/14 Servers