Skip to content

CentOS下如何安装nodejs及相关环境

您将了解

  1. CentOS下如何安装nodejs
  2. CentOS下如何安装NVM
  3. CentOS下如何安装git
  4. CentOS下如何安装pm2
  5. CentOS下如何安装nginx

适用对象

本文档介绍如何在阿里云CentOS系统的云服务器ECS实例上,安装Nodejs并部署项目。

准备工作

部署之前,请做如下准备工作:

  • 购买ECS实例
  • 您的实例运行的镜像是CentOS7.x
  • 您的实例可以连接公网
  • 本地已经安装用于连接 Linux 实例的工具,如 Xshell

安装nodejs

  1. wget命令下载Node.js安装包。

选择自己需要安装的版本https://nodejs.org/dist/选择带linux-x64.tar.xz的安装包,该安装包是编译好的文件,解压之后,在bin文件夹中就已存在node和npm,无需重复编译。

shell
wget https://nodejs.org/dist/latest-v10.x/node-v10.17.0-linux-x64.tar.xz

https://nodejs.org/dist/  访问该地址查看所有node版本

如果提示找不到wget命令,可以先安装weget,执行yum -y install wget后再安装。

  1. 解压文件。
shell
tar xvf node-v10.17.0-linux-x64.tar.xz
  1. 创建软链接,使node和npm命令全局有效。

通过创建软链接的方法,使得在任意目录下都可以直接使用node和npm命令:

shell
ln -s /root/node-v10.17.0-linux-x64/bin/node /usr/local/bin/node
ln -s /root/node-v10.17.0-linux-x64/bin/npm /usr/local/bin/npm
  1. 查看node、npm版本。
shell
node -v
npm -v
  1. 至此,Node.js环境已安装完毕。 软件默认安装在/目录或者~目录下,也就是根目录或当前用户目录,如果不清楚当前的目录可以执行pwd命令。如果需要将该软件安装到其他目录(如:/opt/node/)下,请进行如下操作:
shell
# 创建目录
mkdir -p /opt/node/
# 移动到目录中
mv /root/node-v10.17.0-linux-x64/* /opt/node/
# 删除之前的软链
rm -f /usr/local/bin/node
rm -f /usr/local/bin/npm
# 创建新的软链
ln -s /opt/node/bin/node /usr/local/bin/node
ln -s /opt/node/bin/npm /usr/local/bin/npm

安装NVM管理多个node版本

NVM(Node version manager)是Node.js的版本管理软件,使用户可以轻松在Node.js各个版本间进行切换。适用于长期做 node 开发的人员或有快速更新node版本、快速切换node版本这一需求的用户。 安装步骤:

  1. 直接使用git将源码克隆到本地的~/.nvm目录下,并检查最新版本。
shell
yum install git

git clone https://github.com/cnpm/nvm.git ~/.nvm && cd ~/.nvm && git checkout `git describe --abbrev=0 --tags`
  1. 激活NVM。
shell
echo ". ~/.nvm/nvm.sh" >> /etc/profile

source /etc/profile
  1. 列出Node.js的所有版本。
shell
nvm list-remote
  1. 安装多个Node.js版本。
shell
nvm install v6.9.5

nvm install v7.4.0
  1. 查看已安装Node.js版本,当前使用的版本为v6.9.5。
shell
[root@iZuf62didsxigy36d6kjtrZ .nvm]# nvm ls
-> v6.9.5
v7.4.0
  1. 切换Node.js版本至v7.4.0。
shell

[root@iZuf62didsxigy36d6kjtrZ .nvm]# nvm use v7.4.0
Now using node v7.4.0
  1. NVM的更多操作请参考帮助文档:
shell
nvm help

部署测试项目

  1. 新建项目文件example.js。
shell
cd ~
touch example.js
  1. 使用vim编辑器打开项目文件example.js。
shell
yum install vim
vim example.js

输入i,进入编辑模式,将以下项目文件内容粘贴到文件中。使用Esc按钮,退出编辑模式,输入:wq,回车,保存文件内容并退出。

项目文件内容:

js
const http = require('http')
const hostname = '0.0.0.0'
const port = 3000
const server = http.createServer((req, res) => {
  res.statusCode = 200
  res.setHeader('Content-Type', 'text/plain')
  res.end('Hello World\n')
})
server.listen(port, hostname, () => {
  console.log(`Server running at http://${hostname}:${port}/`)
})

注:项目文件内容中的3000为端口号,可以自行定义。并注意在阿里云控制台安全策略中开放对于的端口

  1. 运行项目。
shell
node ~/example.js

注:可以使用命令node ~/example.js &将项目置于后台运行。

  1. 使用命令查看项目端口是否存在。
shell
netstat -tpln
  1. 在浏览器中输入http://IP:端口号 访问项目。

安装pm2 守护node进程

  1. 安装
shell
npm install -g pm2

此时执行pm2可能会提示找不到pm2命令

  1. 通过创建软链接的方法,使得在任意目录下都可以直接使用pm2命令:
shell
ln -s /root/node-v10.17.0-linux-x64/bin/pm2 /usr/local/bin/pm2

上面的软链路径不要疑惑,pm2确实安装到了node解压目录下,想要获得npm全局的安装路径可以使用命令

shell
npm config get prefix
#使用下面的命令设置npm的全局安装路径
npm config set prefix
  1. 运行
shell
cd myapp/
pm2 start ./bin/www

完.

安装Nginx配置静态服务器

安装 yum install -y nginx 启动 systemctl start nginx 关闭防火墙 iptables -F

重启 systemctl restart nginx

yum方式安装的默认地址和配置的默认地址

sh
/etc/nginx/nginx.conf  //yum方式安装后默认配置文件的路径

/usr/share/nginx/html  //nginx网站默认存放目录

/usr/share/nginx/html/index.html //网站默认主页路径

nginx基本操作

sh
[root@localhost ~]# yum -y instal nginx  //安装nginx

[root@localhost ~]# service nginx start  //启动nginx

[root@localhost ~]# service nginx stop  //停止nginx

[root@localhost ~]# service nginx reload  //重载nginx

[root@localhost ~]# ps -ef | grep nginx  //查看进程apache/httpd

[root@localhost ~]# netstat -anpl | grep 'nginx'  //查看服务端口

[root@localhost ~]# rpm -Uvh <http://nginx.org/packages/centos/7/x86_64/RPMS/nginx-1.18.0-1.el7.ngx.x86_64.rpm>  // rpm方式升级并安装某个版本的Nginx

在Nginx服务器上安装证书

您可以将已签发的SSL证书安装到Nginx或Tengine服务器上。本文介绍如何下载SSL证书并在Nginx或Tengine服务器上安装证书。

前提条件

  • 已经通过数字证书管理服务控制台签发证书。
  • 已准备好远程登录工具(例如PuTTY、Xshell),用于登录您的Web服务器。

重要

本文以CentOS 7.x操作系统、Nginx 1.20.1服务器系统为例进行说明。由于服务器系统版本不同,您在操作过程中使用的命令可能会略有区别。

步骤一:申请免费证书-下载证书到本地

  1. 登录数字证书管理服务控制台

  2. 在左侧导航栏,单击SSL证书。

  3. 单击目标证书操作列的下载。

  4. 在证书下载面板,单击Nginx服务器操作列的下载。

    该操作会将Nginx服务器证书压缩包下载到本地,并保存在浏览器的默认下载位置。

  5. 打开浏览器的默认下载位置,解压已下载的Nginx服务器证书压缩包文件。

    解压后您将会获得以下文件:证书文件

    重要 本文中出现证书文件名称的地方,统一使用cert-file-name为例进行描述。例如,本文中用到的证书文件为cert-file-name.pem,证书私钥文件为cert-file-name.key。在实际操作过程中,您必须使用真实的证书文件名称替换示例代码中的cert-file-name。

    • PEM格式的证书文件。

    PEM格式的证书文件是采用Base64编码的文本文件,您可以根据需要将证书文件修改成其他格式。

步骤二:在Nginx服务器上安装证书

在Nginx独立服务器、Nginx虚拟主机上安装证书的具体操作不同,请根据您的实际环境,选择对应的安装步骤。

在Nginx独立服务器上安装证书

  1. 登录Nginx服务器。

  2. 执行以下命令,在Nginx安装目录(默认为/usr/local/nginx/conf)下创建一个用于存放证书的目录。

    bash
    cd /usr/local/nginx/conf  #进入Nginx默认安装目录。如果您修改过默认安装目录,请根据实际配置调整。
    mkdir cert  #创建证书目录,命名为cert。
  3. 使用远程登录工具附带的本地文件上传功能,将证书文件和私钥文件上传到Nginx服务器的证书目录(示例中为/usr/local/nginx/conf/cert)。

    重要 如果您在申请证书时将CSR生成方式设置为手动填写,请将您手动创建的证书私钥文件上传至/usr/local/nginx/conf/cert目录下。

  4. 编辑Nginx配置文件(nginx.conf),修改与证书相关的配置。

    1. 执行以下命令,打开配置文件。

    重要 nginx.conf默认保存在/usr/local/nginx/conf目录下。如果您修改过nginx.conf的位置,请将/usr/local/nginx/conf/nginx.conf替换成修改后的位置。

    sql
    vim /usr/local/nginx/conf/nginx.conf
    1. 按i键进入编辑模式。
    2. 在配置文件中定位到HTTP协议代码片段(http{}),并在HTTP协议代码里面添加以下server配置(如果server配置已存在,按照以下注释内容修改相应配置即可)。

    使用示例代码前,请注意替换以下内容:

    • yourdomain:替换成证书绑定的域名。
    • cert-file-name.pem:替换成步骤3中上传的证书文件的名称。
    • cert-file-name.key:替换成步骤3中上传的证书私钥文件的名称。
    ruby
    #以下属性中,以ssl开头的属性表示与证书配置有关。
    server {
    listen 443 ssl;
    #配置HTTPS的默认访问端口为443。
    #如果未在此处配置HTTPS的默认访问端口,可能会造成Nginx无法启动。
    #如果您使用Nginx 1.15.0及以上版本,请使用listen 443 ssl代替listen 443和ssl on。
    server_name yourdomain;
    root html;
    index index.html index.htm;
    ssl_certificate cert/cert-file-name.pem;  
    ssl_certificate_key cert/cert-file-name.key; 
    ssl_session_timeout 5m;
    ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
    #表示使用的加密套件的类型。
    ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3; #表示使用的TLS协议的类型,您需要自行评估是否配置TLSv1.1协议。
    ssl_prefer_server_ciphers on;
    location / {
       root html;  #Web网站程序存放目录。
       index index.html index.htm;
    }
    }
    1. **可选:**设置HTTP请求自动跳转HTTPS。

    如果您希望所有的HTTP访问自动跳转到HTTPS页面,则可以在需要跳转的HTTP站点下添加以下rewrite语句。

    重要 以下代码片段需要放置在nginx.conf文件中server {}代码段后面,即设置HTTP请求自动跳转HTTPS后,nginx.conf文件中会存在两个server {}代码段。

    bash
    server {
    listen 80;
    server_name yourdomain; #需要将yourdomain替换成证书绑定的域名。
    rewrite ^(.*)$ https://$host$1; #将所有HTTP请求通过rewrite指令重定向到HTTPS。
    location / {
       index index.html index.htm;
    }
    }

    警告 必须配置放行80端口和443端口,否则网站访问可能出现异常。 5. 修改完成后,按Esc键、输入:wq!并按Enter键,保存修改后的配置文件并退出编辑模式。

  5. 执行以下命令,重启Nginx服务。

    bash
    cd /usr/local/nginx/sbin  #进入Nginx服务的可执行目录。
    ./nginx -s reload  #重新载入配置文件。

    如果重启Nginx服务时收到报错,您可以使用以下方法进行排查:

    • 收到the "ssl" parameter requires ngx_http_ssl_module报错:您需要重新编译Nginx并在编译安装的时候加上--with-http_ssl_module配置。
    • 收到"/cert/3970497_demo.aliyundoc.com.pem":BIO_new_file() failed (SSL: error:02001002:system library:fopen:No such file or directory:fopen('/cert/3970497_demo.aliyundoc.com.pem','r') error:2006D080:BIO routines:BIO_new_file:no such file)报错:您需要去掉证书相对路径最前面的/。例如,您需要去掉/cert/cert-file-name.pem最前面的/,使用正确的相对路径cert/cert-file-name.pem

步骤三:验证是否安装成功

证书安装完成后,您可通过访问证书的绑定域名验证该证书是否安装成功。

bash
https://yourdomain   #需要将yourdomain替换成证书绑定的域名。

如果网页地址栏出现小锁标志,表示证书已经安装成功。

配置gzip

ruby
#开启gzip
gzip  on;  
#低于1kb的资源不压缩 
gzip_min_length 1k;
#压缩级别1-9,越大压缩率越高,同时消耗cpu资源也越多,建议设置在5左右。 
gzip_comp_level 5; 
#需要压缩哪些响应类型的资源,多个空格隔开。不建议压缩图片.
gzip_types text/plain application/javascript application/x-javascript text/javascript text/xml text/css;  
#配置禁用gzip条件,支持正则。此处表示ie6及以下不启用gzip(因为ie低版本不支持)
gzip_disable "MSIE [1-6]\.";  
#是否添加“Vary: Accept-Encoding”响应头
gzip_vary on;

强制https

ruby
server {
listen       80;
server_name  localhost;
rewrite ^(.*)$ https://$host$1 permanent;
location / {
root   html;
index  index.html index.htm;
}

最终配置

ruby
# For more information on configuration, see:
#   * Official English Documentation: http://nginx.org/en/docs/
#   * Official Russian Documentation: http://nginx.org/ru/docs/

user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

# Load dynamic modules. See /usr/share/doc/nginx/README.dynamic.
include /usr/share/nginx/modules/*.conf;

events {
    worker_connections 1024;
}

http {
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile            on;
    tcp_nopush          on;
    tcp_nodelay         on;
   #开启gzip
    gzip  on;  
   #低于1kb的资源不压缩 
    gzip_min_length 1k;
   #压缩级别1-9,越大压缩率越高,同时消耗cpu资源也越多,建议设置在5左右。 
    gzip_comp_level 5; 
   #需要压缩哪些响应类型的资源,多个空格隔开。不建议压缩图片.
    gzip_types text/plain application/javascript application/x-javascript text/javascript text/xml text/css;  
   #配置禁用gzip条件,支持正则。此处表示ie6及以下不启用gzip(因为ie低版本不支持)
    gzip_disable "MSIE [1-6]\.";  
   #是否添加“Vary: Accept-Encoding”响应头
    gzip_vary on;
    keepalive_timeout   65;
    types_hash_max_size 4096;

    include             /etc/nginx/mime.types;
    default_type        application/octet-stream;

    # Load modular configuration files from the /etc/nginx/conf.d directory.
    # See http://nginx.org/en/docs/ngx_core_module.html#include
    # for more information.
    include /etc/nginx/conf.d/*.conf;

    server {
        listen       80;
        listen       [::]:80;
        server_name  _;
        rewrite ^(.*)$ https://$host$1 permanent;
        root         /usr/share/nginx/html;

        location / {
                root /data/www/blog;
                index index.html index.htm;
        }
        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        error_page 404 /404.html;
        location = /404.html {
        }

        error_page 500 502 503 504 /50x.html;
        location = /50x.html {
        }
    }

# Settings for a TLS enabled server.
   server {
       listen       443 ssl http2;
       listen       [::]:443 ssl http2;
       server_name  _;
       root         /usr/share/nginx/html;

       ssl_certificate "cert/artiely.com.pem";
       ssl_certificate_key "cert/artiely.com.key";
       ssl_session_cache shared:SSL:1m;
       ssl_session_timeout  10m;
    #    ssl_ciphers HIGH:!aNULL:!MD5;
       ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4; #表示使用的加密套件的类型。
       ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3; #表示使用的TLS协议的类型,您需要自行评估是否配置TLSv1.1协议。
       ssl_prefer_server_ciphers on;
       # Load configuration files for the default server block.
       include /etc/nginx/default.d/*.conf;
       location / {
                   root /data/www/blog;
                   index index.html index.htm;
            }
       error_page 404 /404.html;
           location = /40x.html {
       }

       error_page 500 502 503 504 /50x.html;
           location = /50x.html {
       }
   }

}