一 配置nginx反向代理

# /etc/nginx/conf.d

upstream jenkins {

        server 127.0.0.1:8080;

}

server {

    listen 80;

    server_name jenkins-pro.michael.com;

    charset utf-8;

    client_body_buffer_size 10M;

    proxy_redirect     off;

    proxy_set_header   Host             $host:$server_port;

    proxy_set_header   X-Real-IP        $remote_addr;

    proxy_set_header X-Forwarded-Host $host:$server_port;

    proxy_set_header X-Forwarded-Server $host;

    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

    proxy_set_header X-Forwarded-Proto $scheme;

    proxy_next_upstream error timeout invalid_header http_502 http_503 http_504;

    proxy_ignore_client_abort on;

    proxy_read_timeout  180;

    proxy_buffering on;

    proxy_buffer_size 8k;

    proxy_buffers 8 8M;

    gzip                on;

    gzip_min_length     1000;

    gzip_types          text/plain text/css application/json text/xml application/xml application/xml+rss text/javascript;

    location / {

       proxy_pass http://jenkins;

       proxy_redirect     default;

       proxy_set_header   Host             $host:$server_port;

       proxy_set_header   X-Real-IP        $remote_addr;

       proxy_set_header X-Forwarded-Host $host:$server_port;

       proxy_set_header X-Forwarded-Server $host;

       proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

       proxy_set_header X-Forwarded-Proto $scheme;

    }

}

二 nodojs安装

[TOC]

### 1、从官网下下载最新的nodejs,

https://nodejs.org/en/download/

![](/uploads/jenkins/images/m_5af6866a323c3c476363b47c6f623c56_r.png)

### 2 解压

```yaml

cd /opt

wget https://nodejs.org/dist/v14.16.1/node-v14.16.1-linux-x64.tar.xz

mkdir /data/node

tar xf node-v14.16.1-linux-x64.tar.xz -C /data/node

```

### 3 配置环境变量

```yaml

vim /etc/profile.d/node.sh

export PATH=/data/node/bin:$PATH

source /etc/profile.d/node.sh

```

### 4 测试版本 安装cnpm与配置淘宝镜像

- npm和 cnpm区别:

- npm(node package manager)是nodejs的包管理器,用于node插件管理(包括安装、卸载、管理依赖等) npm安装插件过程:从http://registry.npmjs.org下载对应的插件包(该网站服务器位于国外,所以经常下载缓慢或出现异常)。

- cnpm是国内的淘宝团队分享的镜像,同步频率目前为 10分钟 一次以保证尽量与官方服务同步。

- cnpm跟npm用法完全一致,只是在执行命令时将npm改为cnpm。

```yaml

npm install -g cnpm --registry=https://registry.npm.taobao.org

```

```yaml

node -v

```

```yaml

npm -v

```

```yaml

cnpm -v

```

### 5 配置jenkins

"系统管理"--"全局工具设置"---" NodeJS 安装"

三 nodejs构建报错node-sass 安装失败

### 1 安装失败后重新安装问题

之前安装失败,再安装就不去下载了,怎么办呢?那就先卸载再安装:

```yaml

npm uninstall node-sass

npm i node-sass --sass_binary_site=https://npm.taobao.org/mirrors/node-sass/

```

### 2或者cnpm安装

```yaml

npm config set sass_binary_site https://npm.taobao.org/mirrors/node-sass/

cnpm install node-sass

```

四 nodejs安装pm2

[TOC]

### 1使用npm/cnpm全局安装:

```yaml

npm install -g pm2

```

### 2 pm2命令使用(项目更目录下使用):

- $ pm2 start app.js 启动app项目

- $ pm2 list 列出由pm2管理的所有进程信息,还会显示一个进程会被启动多少次,因为没处理的异常。

- $ pm2 monit 监视每个node进程的CPU和内存的使用情况

- $ pm2 logs 显示所有进程日志

- $ pm2 stop all 停止所有进程

- $ pm2 restart all 重启所有进程

- $ pm2 reload all 0秒停机重载进程 (用于 NETWORKED 进程)

- $ pm2 stop 0 停止指定的进程

- $ pm2 restart 0 重启指定的进程

- $ pm2 startup 产生 init 脚本 保持进程活着

- $ pm2 web 运行健壮的 computer API endpoint (http://localhost:9615)

- $ pm2 delete 0 杀死指定的进程

- $ pm2 delete all 杀死全部进程

### 3 启动进程的方式详细:

- $ pm2 start app.js -i max 根据有效CPU数目启动最大进程数目

- $ pm2 start app.js -i 3 启动3个进程

- $ pm2 start app.js -x 用fork模式启动 app.js 而不是使用 cluster

- $ pm2 start app.js -x -- -a 23 用fork模式启动 app.js 并且传递参数 (-a 23)

- $ pm2 start app.js --name serverone 启动一个进程并把它命名为 serverone

- $ pm2 stop serverone 停止 serverone 进程

- $ pm2 start app.json 启动进程, 在 app.json里设置选项

- $ pm2 start app.js -i max -- -a 23 在--之后给 app.js 传递参数

- $ pm2 start app.js -i max -e err.log -o out.log 启动 并 生成一个配置文件

### 4 配置pm2启动文件:

可以通过来启动。

```yaml

pm2 start processes.json

```

在项目根目录下添加文件processes.json:

```yaml

{

"apps": [

{

"name": "mywork",

"cwd": "/srv/node-app/current",

"script": "bin/xxx",

"log_date_format": "YYYY-MM-DD HH:mm:ss",

"error_file": "/var/log/node-app/node-app.stderr.log",

"out_file": "log/node-app.stdout.log",

"pid_file": "pids/node-geo-api.pid",

"instances": 6,

"min_uptime": "200s",

"max_restarts": 10,

"max_memory_restart": "1M",

"cron_restart": "1 0 * * *",

"watch": false,

"merge_logs": true,

"exec_interpreter": "node",

"exec_mode": "fork",

"autorestart": false,

"vizion": false

}

]

}

```

### 5 processes.json说明:

- apps:json结构,apps是一个数组,每一个数组成员就是对应一个pm2中运行的应用

- name:应用程序名称

- cwd:应用程序所在的目录

- script:应用程序的脚本路径

- log_date_format:

- error_file:自定义应用程序的错误日志文件

- out_file:自定义应用程序日志文件

- pid_file:自定义应用程序的pid文件

- instances:

- min_uptime:最小运行时间,这里设置的是60s即如果应用程序在60s内退出,pm2会认为程序异常退出,此时触发重启max_restarts设置数量

- max_restarts:设置应用程序异常退出重启的次数,默认15次(从0开始计数)

- cron_restart:定时启动,解决重启能解决的问题

- watch:是否启用监控模式,默认是false。如果设置成true,当应用程序变动时,pm2会自动重载。这里也可以设置你要监控的文件。

- merge_logs:

- exec_interpreter:应用程序的脚本类型,这里使用的shell,默认是nodejs

- exec_mode:应用程序启动模式,这里设置的是cluster_mode(集群),默认是fork

- autorestart:启用/禁用应用程序崩溃或退出时自动重启

- vizion:启用/禁用vizion特性(版本控制)

五 node找不到环境变量

```yaml

ln -s /application/node-v14.2.0-linux-x64/bin/node /usr/sbin/node

ln -s /application/node-v14.2.0-linux-x64/bin/npm /usr/sbin/npm

ln -s /application/node-v14.2.0-linux-x64/bin/cnpm /usr/sbin/cnpm

```