前面有一篇文章讲到过用git的hook部署应用,hook的方法有一个缺陷就是每次都要到服务器去修改一下hook对应的配置文件,这个配置文件是与当前仓库分离的,调试上会有一些麻烦,借助ruby的一个部署工具mina可以快速的在服务器部署nodejs应用。
安装mina
gem install mina
简单的配置
require 'mina/git' require 'mina/bundler'set :domain, 'your.server.com' set :user, 'flipstack' set :repository, 'flipstack'
task :deploy do deploy do # Preparations here invoke :'git:clone' invoke :'bundle:install' end end
task :restart do queue 'sudo service restart apache' end
运行
在正式的deploy之前一般需要准备一些目录,可以通过 mina setup来设置,默认情况下,它会在指定的服务器上创建下面的目录结构
. ├── releases 发布的版本 └── shared 这里可以放公用的文件,比如node_modules
运行mina deploy它会执行task deploy里指定的命令,比如上面的会进行:
1.登录到服务器
2.git clone 到scm目录
3.在tmp目录里创建一个build-xxxxx的目录,然后开始执行bundle install
4.在releases里创建一个发布版本号目录,移动build-xxxxx里的内容进去
5.软链接current到刚才的版本号目录
nodejs应用的发布示例
require 'mina/git'set :term_mode, nil # 这里一个虚拟机的ip set :domain, '192.168.56.101' # 登录到机器的用户名 set :user, 'test' # Username in the server to SSH to. # 发布的目录 set :deploy_to, '/home/test/doitnow' # 发布的git仓库地址 set :repository, 'ssh://jb51.net@192.168.56.1/Users/jb51.net/works/doitnow' # 发布的git分支 set :branch, 'master'
# 设置需要软链接的目录 # 软链接node_modules,可以防止每次npm install时花费的大量时间 set :shared_paths, ['log', 'tmp', 'node_modules']
# 这里使用forever来管理node进程,也推荐使用pm2 set :forever,"#{deploy_to}/shared/node_modules/forever/bin/forever"
# 初始化的时候创建目录,分配目录权限 task :setup do queue "mkdir -p #{deploy_to}/shared/log" queue "chmod g+rx,u+rwx #{deploy_to}/shared/log"
queue "mkdir -p #{deploy_to}/shared/node_modules" queue "chmod g+rx,u+rwx #{deploy_to}/shared/node_modules" end
desc "Deploys the current version to the server." task :deploy do deploy do invoke :'git:clone' # 链接目录 invoke :'deploy:link_shared_paths' # 安装模块 # 静态资源的编译可以放到package.json里的{scripts:{install:'xxxxx'}} queue "npm install"
to :launch do # 重启应用 queue "NODE_ENV=production #{forever} stopall" # 注意把log放到shared里去 queue "NODE_ENV=production #{forever} start -o #{deploy_to}/shared/log/output.log -e #{deploy_to}/shared/log/error.log -a app.js " end end end
来源:http://jser.me
本文向大家介绍Docker实践--部署Nodejs应用,包括了Docker实践--部署Nodejs应用的使用技巧和注意事项,需要的朋友参考一下 这个例子的目标是为了向大家展示如何在Docker的container里运行Node.js程序。我会先创建一个简单的Node.js web app,来构建一个镜像。然后基于这个Image运行一个container。从而实现快速部署。 由于网络的原因我的Nod
我们这里以项目 flask-todo-app 为例,介绍如何将其部署到生产环境,主要有以下几个步骤: 创建项目的运行环境 使用 Gunicorn 启动 flask 程序 使用 supervisor 管理服务器进程 使用 Nginx 做反向代理 创建项目的运行环境 创建 Python 虚拟环境,以便隔离不同的项目 安装项目依赖包 $ pip install virtualenvwrapper $ s
本文向大家介绍用Docker swarm快速部署Nebula Graph集群的教程,包括了用Docker swarm快速部署Nebula Graph集群的教程的使用技巧和注意事项,需要的朋友参考一下 一、前言 本文介绍如何使用 Docker Swarm 来部署 Nebula Graph 集群。 二、nebula集群搭建 2.1 环境准备 机器准备 ip 内存(Gb) cpu(核数) 192.168
注 这一章可以有时有点难打通。 坚持并完成它 ;部署是在网站开发过程的重要组成部分。 这一章放在本教程的中部,因此你的指导者可以帮助你在使网站上线中的一些小困难。 这意味着如果您花大量的时间,你仍然能独立完成这个教程。 到目前为止您的网站只是在您的计算机上可用,现在您将了解如何部署它 ! 部署是在互联网上发布你的应用程序的一系列过程,因此人们最终可以一起去看看你的应用程序。 正如你所学习的,一个网
为了使用 Electron 部署你的应用,您需要进行打包和重塑。这样做的最简单的方法是使用以下第三方打包工具之一: electron-forge electron-builder electron-packager 这些工具将覆盖发布一个Electron应用所需采取的所有步骤,例如,打包应用程序,重组可执行程序,设置图标和可配置的创建安装程序。 Application Distribution T
程序开发完毕之后,我们现在要部署Web应用程序了,但是我们如何来部署这些应用程序呢?因为Go程序编译之后是一个可执行文件,编写过C程序的读者一定知道采用daemon就可以完美的实现程序后台持续运行,但是目前Go还无法完美的实现daemon,因此,针对Go的应用程序部署,我们可以利用第三方工具来管理,第三方的工具有很多,例如Supervisord、upstart、daemontools等,这小节我介