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

  •   
  • 289
  • linux
  • 0
  • dodobook
  • 2019/06/26

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

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 请求,于是将此请求转发给对应的应用处理。

#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 这个的时候会启用到负载均衡,会访问到不同的服务器资源。