们在本地搭建了多个应用(尤其是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 这个的时候会启用到负载均衡,会访问到不同的服务器资源。