在实际的应用中,你的nodejs项目可能需要部署到多台服务器上,nginx为我们提供了服务器解决方案,它可以将请求转发到不同的服务器上。

我们先巩固下几个概念:
什么是分布式?什么是集群?什么是负载均衡?

  1. 什么是分布式?
    分布式是指将不同的业务分布在不同的地方。
  2. 什么是集群?
    集群指的是将几台服务器集中在一起,实现同一业务。
  3. 什么是负载均衡?
    负载均衡是由多台服务器以对称的方式组成一个服务器集合,每台服务器都具有等价的地位,都可以单独对外供应效力而无须其他服务器的辅助。经过某种负载分管技术,将外部发送来的央求均匀分配到对称结构中的某一台服务器上。

下面来开始使用nginx:

  1. 安装nginx,进入下载页面http://nginx.org/en/download.html: windows系统直接下载稳定版解压


nginx部署分布式项目 nginx分布式集群_nginx部署分布式项目


  1. Linux系统需要以下几个:

安装PCRE库,wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz 安装zlib库,wget http://zlib.net/zlib-1.2.11.tar.gz 安装openssl,wget https://www.openssl.org/source/openssl-1.1.1a.tar.gz 安装nginx,wget http://nginx.org/download/nginx-1.14.2.tar.gz

  1. 配置nginx,在nginx的安装目录下找到nginx.conf(windows和linux配置基本相同),假设有两台服务器,一台8核,一台16核,怎么配置了?

首先在http节点下配置两台服务器的ip和权重

upstream server1 {
    server xxx.xxx.xxx.xxx:3000 weight=1;
    }
	upstream server2{
    server xxx.xxx.xxx.xxx:3001 weight=2;
    }

然后添加两个server

server {
        listen       3000;
        server_name  xxx.xxx.xxx.xxx;//IP地址

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location /api {
           
		  proxy_pass   http://server1;
		  proxy_set_header Host $host:3000;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

        }
	
		
    }
	  server {
        listen       3001;
        server_name  xxx.xxx.xxx.xxx;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

       
		location /api {
		proxy_pass   http://server2;
          proxy_set_header Host $host:3001;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
			
        }
		
    }
  1. location匹配规则

Location语法语法:location [=||*|^~] /uri/ { … }

= 表示精确匹配

^~ 表示uri以某个常规字符串开头,理解为匹配url路径即可。
nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格)。

~ 表示区分大小写的正则匹配

~* 表示不区分大小写的正则匹配

!和!* 分别为区分大小写不匹配及不区分大小写不匹配的正则

/ 通用匹配,任何请求都会匹配到。

多个location配置的情况下匹配顺序为:
首先匹配=,其次匹配^~, 其次是按文件中顺序的正则匹配,最后是交给 / 通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。

nginx文档地址:http://nginx.org/en/docs/