Nginx 是一款高性能的 http 服务器 / 反向代理服务器及电子邮件(IMAP / POP3)代理服务器。由俄罗斯的程序设计师 伊戈尔.西索夫 (Igor Sysoev) 所开发,官方测试 nginx 能支持 5 万并发链接,并且CPU、内存等资源消耗非常低,运行非常稳定。
nginx应用场景:
这里使用Docker 安装 nginx
- 拉取Nginx 镜像
docker pull nginx
- 创建容器设置端口映射、目录映射
mkdir ~/nginx cd ~/nginx mkdir conf cd conf vim nginx.confuser nginx; worker_processes 1; 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;keepalive_timeout 65;include /etc/nginx/conf.d/*.conf; }
-创建且进入这个文件 ~/nginx/conf.d/80.conf
server {listen 80; server_name localhost; location / { root /usr/share/nginx/html;index index.html index.htm; }error_page 500 502 503 504 /50x.html; location = /50x.html {root html;} }
- 创建Docker 容器
docker run -id --name=c_nginx \ -p 80:80 \ -p 81:81 \ -p 82:82 \ -v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf \ -v $PWD/conf.d:/etc/nginx/conf.d \ -v $PWD/logs:/var/log/nginx \ -v $PWD/html:/usr/share/nginx/html \ nginx
- 参数说明: -p 80:80:将容器的 80端⼝映射到宿主机的 80 端⼝。 -v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf:将主机当前⽬录下的 /conf/nginx.conf 挂载到容器的 :/etc/nginx/nginx.conf。配置⽬录 -v $PWD/logs:/var/log/nginx:将主机当前⽬录下的 logs ⽬录挂载到容器 的/var/log/nginx。⽇志⽬录
2.1 端⼝绑定
(1)上传静态⽹站:
将/资料/静态⻚⾯/index⽬录上传⾄ /usr/local/nginx/index下
将/资料/静态⻚⾯/regist⽬录上传⾄ /usr/local/nginx/regist下
(2)修改Nginx 的配置⽂件:~/nginx/config.d/port.conf
server {
listen 81; # 监听的端⼝
server_name localhost; # 域名或ip
location / { # 访问路径配置
root /usr/share/nginx/index;# 根⽬录
index index.html index.htm; # 默认⾸⻚
}
error_page 500 502 503 504 /50x.html; # 错误⻚⾯
location = /50x.html {
root html;
}
}
server {
listen 82; # 监听的端⼝
server_name localhost; # 域名或ip
location / { # 访问路径配置
root /usr/share/nginx/regist;# 根⽬录
index regist.html; # 默认⾸⻚
}
error_page 500 502 503 504 /50x.html; # 错误⻚⾯
location = /50x.html {
root html;
}
}
(3)访问测试:
地址栏输⼊http://ip/:81 可以看到⾸⻚⾯
地址栏输⼊http://ip/:82 可以看到注册⻚⾯
2.2 域名与IP绑定
⼀个域名对应⼀个 ip 地址,⼀个 ip 地址可以被多个域名绑定。
本地测试可以修改 hosts ⽂件(C:\Windows\System32\drivers\etc)
可以配置域名和 ip 的映射关系,如果 hosts ⽂件中配置了域名和 ip 的对应关系,不需要⾛dns 服务
器。
192.168.177.129 www.abc.com
192.168.177.129 regist.abc.com
做好域名指向后,修改nginx配置⽂件 domain.conf
server {
listen 80;
server_name www.abc.com;
location / {
root /usr/share/nginx/cart;
index cart.html;
}
}
server {
listen 80;
server_name regist.abc.com;
location / {
root /usr/share/nginx/search;
index search.html;
}
}
什么是正向代理??
比如我们平时上网,用的联通,电信,移动这三大运营商,如果我们用的是移动的网,我们不能直接去访问移动的服务器,而是有这么个中间代理服务器,我们客户端的请求先到了中间代理服务器,然后中间代理服务器把请求发送到移动的服务器。 注意: 这里代理的是你的客户端,只是对你客户端的请求通过代理服务器转送了一下到真正的目的服务器
什么是反向代理??
比如说我们大学可能有很多个学院,每个学院都有自己的官网,我们此时作为一个客户端,而这些每个学院的官网可以看成是不同的服务器,现在存在一个中间代理服务器,就是说,当我们每次不管输入哪个学院的网址,首先会经过中间代理服务器,然后由中间代理服务器在根据你域名具体的不同,然后反向代理到你具体要访问的那个学院的服务器那里去。注意:这里代理的是你的目的服务器,这里反向代理是对具体的服务器进行了选择
配置反向代理:
- 先在docker配置tomcat 服务
- 配置反向代理
~/nginx/config.d/proxy.conf
upstream tomcat-kkb{server 192.168.220.12:8080;}server {listen 80; server_name www.kkb.com; location / { proxy_pass http://tomcat-kkb;index index.html index.htm; }}
- 先用docker 创建三个tomcat 服务
- 配置置负载均衡
修改 Nginx配置⽂件:lb.conf
upstream tomcat-huike {server 192.168.220.12:8080;server 192.168.220.12:8081 weight=2;server 192.168.220.12:8082;}server {listen 80; server_name www.huike.com; location / { proxy_pass http://tomcat-huike;index index.html index.htm; }error_page 500 502 503 504 /50x.html; location = /50x.html {root html;}}
weight 代表这台服务器出现的次数是其他服务器的两倍
原文链接:http://www.taodudu.cc/news/show-4882521.html