原文:https://my.oschina.net/songzhu/blog/610337

一、服务器准备

服务器ip地址为:172.16.70.174

1.安装 Node.js

参考:http://my.oschina.net/songzhu/blog/608129

2.安装 PM2

PM2 是一个带有负载均衡功能的 Node 应用的进程管理器。

全局安装 PM2

$ npm install pm2 -g
$ pm2 list
[PM2] Spawning PM2 daemon
[PM2] PM2 Successfully daemonized
┌──────────┬────┬──────┬─────┬────────┬─────────┬────────┬────────┬──────────┐
│ App name │ id │ mode │ pid │ status │ restart │ uptime │ memory │ watching │
└──────────┴────┴──────┴─────┴────────┴─────────┴────────┴────────┴──────────┘
Use `pm2 show <id|name>` to get more details about an app

安装 PM2 如果出现错误,大概是网络和权限问题导致的。仔细看一下错误提示,如果是网络问题,那么多重试几次应该就可以了。

3.准备发布目录

/home/admin/publish/web/express-demo

$ cd ~
$ mkdir publish && cd publish
$ mkdir web && cd web
$ mkdir express-demo && cd express-demo
$ pwd
/home/admin/publish/web/express-demo

二、创建 PM2  启动脚本

进入 express-demo 目录,添加文件 pm2-start.json

$ touch pm2-start.json

添加以下内容:

[
{
"name" : "express-demo",
"script" : "./app.js",
"watch" : false,
"instances" : "",
"exec_mode" : "cluster_mode",
"env": {
"NODE_ENV": "production"
},
"out_file": "./logs/app.log",
"error_file": "./logs/err.log",
}
]

通过 pm2 start pm2-start.json,可启动 express-demo。

更详细的配置:http://pm2.keymetrics.io/docs/usage/application-declaration/

三、创建 Gulp 任务

Gulp 用自动化构建工具增强你的工作流程。

1.全局安装 gulp

$ npm install gulp -g
$ gulp -v
[::] CLI version 3.9.

2.作为项目的开发依赖安装 gulp

$ npm install --save-dev gulp
$ gulp -v
[::] CLI version 3.9.
[::] Local version 3.9.

3.在项目根目录创建 gulpfile.js

$ touch gulpfile.js
$ gulp
[::] Using gulpfile ~/demos/express-demo/gulpfile.js
[::] Task 'default' is not in your gulpfile
[::] Please check the documentation for proper gulpfile formatting

看到错误是因为我没还没有在 gulpfile.js里面添加内容

4.添加 gulp 部署依赖

$ npm install --save-dev gulp-util gulp-shell gulp-ssh gulp-zip through2 scp2 async progress

gulp-util

gulp-shell

gulp-ssh

gulp-zip

through2

scp2

async

progress

5.在项目根目录创建 deploy-ssh.js

$ touch deploy-ssh.js

添加以下内容:

var gulp = require('gulp');
var gutil = require('gulp-util');
var through = require('through2');
var ScpClient = require('scp2').Client;
var ssh = require('gulp-ssh');
var async = require('async');
var ProgressBar = require('progress'); const PLUGIN_NAME = 'deploy-ssh' module.exports = function (options) {
var servers = options.servers;
var dest = options.dest;
var shell = options.shell;
var logPath = options.logPath; return through.obj(function (file, enc, callback) {
if (file.isNull()) {
callback(null, file);
return;
} if (file.isStream()) {
return callback(new gutil.PluginError(PLUGIN_NAME, 'No stream support'));
} var i = ;
async.eachSeries(servers, function(server, done) {
var hostName = server.sshConfig.host;
gutil.log(PLUGIN_NAME, "start deploy:" + hostName)
var client = new ScpClient(server.sshConfig); var bar = null;
client.on("transfer", function(buffer, uploaded, total){
if(bar == null){
bar = new ProgressBar(hostName + ' uploading [:bar] :percent :elapsed s', {
complete: '=',
incomplete: ' ',
width: ,
total: total
});
}
bar.tick();
}); client.write({
destination: dest,
content: file.contents
}, function () {
ssh(server).shell(shell, {filePath: logPath + "-" + hostName + ".log", autoExit: true}).on('error', function (err) {
done(err); gutil.PluginError(PLUGIN_NAME, err)
}).on('finish', function () {
gutil.log(PLUGIN_NAME, "finish deploy:" + hostName); done(); if (++i === servers.length) {
callback(null, file);
}
}).pipe(gulp.dest('logs'));
});
}); }); };

deploy-ssh 主要用于上传发布包至服务器并登录服务器之行发布脚本。

6.在项目根目录创建 deploy-config.js

$ touch deploy-config.js

添加以下内容:

var config = {
production:{
servers:[
{
sshConfig: {
host: '172.16.70.174',
port: ,
username: 'admin',
password: 'cavin@123',
readyTimeout:
}
}]
}
}; module.exports = config;

deploy-config 主要用于配置deploy服务器信息。

7.修改 gulpfile.js

添加以下内容:

var gulp = require('gulp');
var shell = require('gulp-shell');
var ssh = require('gulp-ssh');
var deployConfig = require("./deploy-config");
var gulpSequence = require('gulp-sequence');
var zip = require('gulp-zip');
var through = require('through2');
var async = require('async');
var scpClient = require('scp2');
var gulpUtil = require('gulp-util');
var deploySSH = require('./deploy-ssh'); const PLUGIN_NAME = 'gulp-deploy ::' gulp.task('default', shell.task([
'DEBUG=express-demo:* npm start'
])); gulp.task('production', function (){
shell.task(['rm -rf dist']);
gulpSequence('copyFile', 'zipFile', 'deploy', function() {
gulpUtil.log(PLUGIN_NAME, "***** Deploy Finished!!!!");
process.exit();
});
}); gulp.task('copyFile', function() {
return gulp.src(
[
'*.json',
'*.js',
'routes/**',
'views/**',
'public/**',
'!config.js'
], { base: './'})
.pipe(gulp.dest('./dist'));
}); gulp.task('zipFile', function() {
return gulp.src(['dist/**'], { base: './' })
.pipe(zip('publish.zip'))
.pipe(gulp.dest('./dist'));
}); gulp.task('deploy', function() {
var config = deployConfig.production;
config.deployPath = '/home/admin/publish/web/express-demo/';
return gulp.src("dist/publish.zip", { base: './' })
.pipe(deploySSH({
servers: config.servers,
dest: config.deployPath + 'publish.zip',
logPath: 'deploy',
shell:[ 'cd ' + config.deployPath,
'shopt -s extglob',
'rm -rf !(logs|node_modules|config.js|publish.zip)',
'unzip -o publish.zip',
'cp -rf dist/** .',
'rm -rf dist',
"rm publish.zip",
'npm install --production',
'pm2 startOrRestart pm2-start.json'],
}));
});

主要 gulp 任务流程为:

1)拷贝文档至临时目录

2)压缩文件

3)发布(先上发布包,然后远程登录服务器之行发布脚本)

注:发布目录 '/home/admin/publish/web/express-demo/' 一定要存在,否则scp上传文件时会出错。

四、一键部署 express-demo

执行发布任务

$ gulp production 

如果没有错误,登录服务器上面可以看到:

$ pm2 list
┌──────────────┬────┬─────────┬──────┬────────┬─────────┬────────┬─────────────┬──────────┐
│ App name │ id │ mode │ pid │ status │ restart │ uptime │ memory │ watching │
├──────────────┼────┼─────────┼──────┼────────┼─────────┼────────┼─────────────┼──────────┤
│ express-demo │ │ cluster │ │ online │ │ 102s │ 30.117 MB │ disabled │
│ express-demo │ │ cluster │ │ online │ │ 102s │ 30.133 MB │ disabled │
│ express-demo │ │ cluster │ │ online │ │ 102s │ 30.109 MB │ disabled │
│ express-demo │ │ cluster │ │ online │ │ 102s │ 30.363 MB │ disabled │
└──────────────┴────┴─────────┴──────┴────────┴─────────┴────────┴─────────────┴──────────┘
Use `pm2 show <id|name>` to get more details about an app

在浏览器里面输入:http://172.16.70.174:3000/

项目代码:https://git.oschina.net/cavintang/express-demo.git

gulp自动化部署:gulp发布express项目(二)的更多相关文章

  1. Linux、Debian、Jenkins、GIT、Nginx、码云安装,自动化部署前后端分离项目

    1.安装Jenkins i:下载Jenkins安装包(war文件):https://jenkins.io/download/ ii:这里采用Tomcat的war包方式安装,讲下载好的安装包放到Tomc ...

  2. jenkins之自动化部署github上maven项目

    部署流程:将代码从github上拉取下来,使用maven打包,将打包后的jar通过ssh发送到服务器上,然后构建docker镜像,运行容器. 1.安装插件 如果是第一次使用jenkins,需要检查并确 ...

  3. 从零实现Linux一键自动化部署.netCore+Vue+Nginx项目到Docker中

    环境搭建 1.安装Linux,这里我用的阿里云服务器,CentOS7版本 2.进入Linux,安装Docker,执行以下命令 sudo yum update #更新一下yum包 sudo yum in ...

  4. Team Services 自动化部署项目

    一.创建Team Services账号 直接使用vs的账号即可,TS上集成了Git.把项目导入到Git中. 使用前提:有自己的服务器,把项目自动化部署到服务器上. 二.创建一个新的定义 三.选择种类( ...

  5. Linux(四)—— 项目部署与ansible自动化部署

    目录 项目部署与ansible自动化部署 一.项目部署 二.ansible自动化部署(python自动化运维) 1.安装ansible 2.ansible例子 3.ansible自动化部署nginx ...

  6. 自动化部署--Jenkins

    自动化部署--Jenkins--简介安装(一) https://www.jianshu.com/p/b9ce206139f1 自动化部署--Jenkins--Maven构建(二)  https://w ...

  7. 使用GitHub Actions实现自动化部署

    前言 大家在工作中想必都是通过自动化部署来进行前端项目的部署的,也就是我们在开发完某个需求时,我们只需要将代码推送到某个分支,然后就能自动完成部署,我们一般不用关心项目是如何build以及如何depl ...

  8. 利用Gulp优化部署Web项目[长文慎入]

    Gulp Gulp是一款项目自动化的构建工具,与Grunt一样可以通过创建任务(Task)来帮助我们自动完成一些工作流的内容.当然,今天我们的内容并不是讨论这二者的区别,仅仅是介绍介绍如何利用Gulp ...

  9. Gulp 自动化的项目构建工具

    在很多场合都会听到前端工和 node 程师推荐 Grunt 来实现项目的自动化,自动化可以自动完成 javascript/coffee/sass/less 等文件的的测试.检查.合并.压缩.格式化.部 ...

随机推荐

  1. Linux CentOS6.5上搭建环境遇到的问题

    1.卸载CentOS自带的JDK 查看centos上 安装的jdk:rpm -qa|grep jdk 出现如下: java-1.7.0-openjdk-1.7.0.45-2.4.3.3.el6.x86 ...

  2. Elastic Search 5.4.3 java api 入门

    首先介绍一点,es的版本从之前的2.x跳跃到5.x,很多插件要保持一致,不然会产生很多版本不兼容的问题. 首先看一个demo先熟悉一下, 具体代码在git服务器上: https://github.co ...

  3. Barcode.js功能强大的条码生成jQuery插件

    本文转载自http://www.uedsc.com/barcode-js.html Barcode.js是一个基于jQuery库的插件,用于绘制条形码或者二维码,能够生成基于DIV+CSS或者Canv ...

  4. 命令行连接mysql服务器时 报Can't connect to local MySQL server through socket 'xxx.sock'错误

    本来之前用的好好的mysql服务器,突然就报Can't connect to local MySQL server through socket 'xxx.sock'错误了 遇到该问题思路首先是:检查 ...

  5. 解析pdb文件得到未导出变量地址(转)

    程序要用到dbghelp.dll中的一些函数 http://msdn.microsoft.com/en-us/library/ms679291%28VS.85%29.aspx 要自己下载系统对应的符号 ...

  6. opencv3——ANN算法的使用

    最近刚转用opencv3,使用ANN算法时遇到了一些问题,记录下来. 训练神经网络的代码如下: //创建ANN Ptr<ANN_MLP> bp = ANN_MLP::create(); 设 ...

  7. JS 运行、复制、另存为 代码。

    //运行代码 function runEx(cod1) { cod = document.getElementById(cod1) var code = cod.value; if (code != ...

  8. 【linux系列】centos7配置桥接模式静态IP

    一.设置桥接模式 VMware->Edit->Virtual Network Edit 二.查看物理机的ip地址 三.根据物理机的ip地址,设置linux虚拟机的ip地址 四.网络重启 五 ...

  9. jQuery队列(一)

    jQuery的队列依赖缓存机制事件,它同时是animate的基础. 它不像事件机制.缓存机制.回调机制一样有自己的命名空间,由于比较简单,所以直接挂在到$和jQuery对象上. 它提供的基础方法有: ...

  10. Excel中countif函数的使用方法

    1.countif函数的含义 在指定区域中按指定条件对单元格进行计数(单条件计数) 建议和countifs函数结合起来学习,可以观看小编的经验Excel中countifs函数的使用方法. END 2. ...