NGINX实现端口映射和负载均衡
- 3226
- Linux
- 0
- super_dodo
- 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 这个的时候会启用到负载均衡,会访问到不同的服务器资源。
相关阅读
- 通过Google API客户端访问Google Play帐户报告PHP库
- PHP执行文件的压缩和解压缩方法
- 消息中间件MQ与RabbitMQ面试题
- 如何搭建一个拖垮公司的技术架构?
- Yii2中ElasticSearch的使用示例
热门文章
- 通过Google API客户端访问Google Play帐户报告PHP库
- PHP执行文件的压缩和解压缩方法
- 消息中间件MQ与RabbitMQ面试题
- 如何搭建一个拖垮公司的技术架构?
- Yii2中ElasticSearch的使用示例
最新文章
- 通过Google API客户端访问Google Play帐户报告PHP库
- PHP执行文件的压缩和解压缩方法
- 消息中间件MQ与RabbitMQ面试题
- 如何搭建一个拖垮公司的技术架构?
- Yii2中ElasticSearch的使用示例