NGINX实现端口映射和负载均衡

  •   
  • 3544
  • Linux
  • 0
  • super_dodo
  • 2019/06/26

们在本地搭建了多个应用(尤其是docker的应用,每个docker都会可能绑定一个端口),每个应用对应不同的端口。如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
localhost:8088      //图书
localhost:8090      //电影A
localhost:8091      //电影B
localhost:8092      //电影C
 
//电影A和电影B电影C可以是相同的代码,负载均衡
 
以上项目的配置文件如下
 
server {
    listen       8088;
    server_name  localhost;
    location / {
        root   /www/book_dir;
        index  index.html index.htm index.php;
    }
    //.......
}

但我们一般访问应用的时候都是希望不加端口就访问域名,也即两个应用都通过 80 端口访问。
此时我们希望对外访问的是域名是 book.iqujing.net 和movie.iqujing.net。

Nginx 的实现原理是:用 Nginx监听 80 端口,当有 HTTP 请求到来时,将HTTP请求的 HOST 等信息与其配置文件进行匹配并转发给对应的应用。例如当用户访问 book.iqujing.net 时,Nginx 从配置文件中知道这个是图书应用的 HTTP 请求,于是将此请求转发给 8088 端口的应用处理。当用户访问 movie.iqujing.net 时,Nginx 从配置文件中知道这个是电影应用的 HTTP 请求,于是将此请求转发给对应的应用处理。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#nginx.conf 的配置项如下
 
user  nginx;
worker_processes  1;    #一般为CPU的核心数或者2倍
 
error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;
 
events {
    worker_connections  1024;
}
 
http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;
 
    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;
    keepalive_timeout  65;
    #gzip  on;
 
 
    #此部分为新增的代码--也可以新建一个文件引入如下行:
    #include /etc/nginx/proxy.conf;
 
    #Book负载均衡池
    upstream pool_book{
        server 127.0.0.1:8088;
    }
 
    #Movie负载均衡池
    upstream pool_movie{
        #ip_hash;  
        server 127.0.0.1:8090 weight=2;
        server 127.0.0.1:8091 weight=3;     //默认权重是1
        server 127.0.0.1:8092 weight=2;
    #   server 115.111.111.111:8088;        //其他服务器的地址
    #   server 115.239.211.112;             //百度服务器IP
    }
 
    #Book负载均衡池
    server {
        listen 80;
        server_name  book.iqujing.net;
        #access_log logs/book.log;
        #error_log logs/book.error;
 
        #将所有请求转发给pool_book池的应用处理
        location / {
            proxy_set_header Host $host;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass http://pool_book;
        }
    }
 
 
    #Movie负载均衡池
    server {
        listen 80;
        server_name  movie.iqujing.net;
         
        location / {
            proxy_set_header Host $host;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass http://pool_movie;
        }
    }
 
 
    #VHOST 多域名的配置加载
    include /etc/nginx/conf.d/*.conf;  
}

上面这段配置实现了:

1、当用户访问的域名是:http://book.iqujing.net时,我们自动将其请求转发给端口号为 8088 的 nginx或者docker 应用处理。

2、当用户访问的域名是:http://movie.iqujing.net时,我们自动将其请求转发对应的负载均衡(可以是本地也可以是远程的)。

3、当我们访问http://movie.iqujing.net 这个的时候会启用到负载均衡,会访问到不同的服务器资源。