nginx学习

什么是 Nginx

Nginx 是一款高性能的 HTTP 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗斯的程序设计师 Igor Sysoev 所开发,官方测试 Nginx 能够支支撑 5 万并发链接,并且 CPU、内存等资源消耗却非常低,运行非常稳定。

Nginx 的应用场景

  • HTTP 服务器:Nginx 是一个 HTTP 服务可以独立提供 HTTP 服务。可以做网页静态服务器。
  • 虚拟主机:可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。
  • 反向代理:正向代理->在客户端配置代理服务器,通过代理服务器进行互联网访问。反向代理->我们只需要将请求发送给反向代理服务器,有反向代理服务器去选择目标服务器获取数据后,再返回给客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP地址。
  • 负载均衡:当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用 Nginx 做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。
  • 动静分离 : 为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速度。降低原来单个服务器的压力。

安装后设置防火墙

firewall-cmd --zone=public --add-port=8200/tcp --permanent
systemctl restart firewalld.service

nginx配置文件

nginx.conf当中有三部分
1.全局块
在这里插入图片描述
比如worker_processes 1;这是Nginx服务器并发处理服务的关键配置,worker_processes值越大,可以支持的并发容器也越多,但是会受硬件、软件等设备的制约。

2.events块
在这里插入图片描述
events块涉及的指令主要影响Nginx服务器与用户的网络连接
比如:worker_connections 1024;支持的最大连接数

3.http块

http {
    # ...
    server{
        # ...
    }
    # ...
    server{
        # ...
    }
}

在这算是Nginx服务器配置中最频繁的部分,代理、缓存和日指定一等大多数功能和第三方模块的配置都在这里。每个 server 就是一个虚拟主机

配置实例

1.反向代理one

实现效果,打开浏览器,在浏览器地址中输入www.huangyy.com,跳转到liunx系统tomcat主页画面中
准备工作:

  • 在linux中安装tomcat,使用默认端口8080
  • 对外开放访问的端口加上8080
    具体配置:
  • 在win系统的host文件中进行域名和ip的对应关系
    在这里插入图片描述
    在这里插入图片描述
  • 在nginx进行请求转发的配置
    在这里插入图片描述
    最终测试,启动nginx。
    在这里插入图片描述

2. 反向代理two

实现效果:使用nginx反向代理,根据访问的路径跳转到不同端口的服务中,nginx监听端口为9001

  • 访问http://127.0.0.1:9001/edu/ 直接跳转到127.0.0.1:8080
  • 访问http://127.0.0.1:9001/edu/直接跳转到127.0.0.1:8081
    准备工作:
  • 准备两个tomcat服务器,一个为8080端口,一个为8081端口
  • 创建文件夹和测试页面
    具体配置:
    在这里插入图片描述
    开放对外端口号
    测试:
    在这里插入图片描述

3.负载均衡

浏览器中输入地址http://192.168.32.128/edu/a.html,负责负载均衡效果,平均8080和8081端口中
准备工作:

  • 两台服务器,8080以及8081
  • 在两台tomcat里面webapps目录中,创建名称是edu文件夹,在edu文件夹中创建页面a.html,用于测试
    在nginx中做负载均衡的配置
    在这里插入图片描述
    nginx分配服务器的策略:
  • 1.轮询(默认):每个请求按时间顺序逐一分配到服务器中,如果后端服务器down掉,则自动剔除。
  • 2.weight:weight代表权重默认为1,权重越高被分配的客户端越多(在后面加weight=)
  • 3.ip_hash:每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题(直接加ip_hash;)
  • 4.fair(第三方):庵后端服务器的响应时间来分配请求,响应时间短的优先分配(直接加fair)

4. 动静分离

通过location制定不同的后缀名实现不同的请求转发。通过expires参数设置,可以使刘兰其缓存过期时间,减少与服务器之前的请求和流量。具体Expires定义:是给一个资源设定一个过期时间,也就是说无需去服务端验证,直接通过浏览器自身确认是否过期即可,所以不会产生额外的流量。刺种方法非常适合不经常变动的资源。(如果经常更新的文件,不建议使用Epires来缓存),设置3d,表示在这3天内访问这个URL,发送一个请求,比对服务器该文件最后更新时间没有变化,则不会从服务器抓取,返回状态码304,如果有修改,则直接从服务器重新下载,返回状态码200。
准备工作:

  • 在linux系统中准备静态资源
    具体配置:
    在这里插入图片描述
    测试:
  • 输入地址http://192.168.32.128/image/
    在这里插入图片描述
  • 输入地址http://192.168.32.128/www/a.html
    在这里插入图片描述

参考:

  • nginx学习总结:
https://blog.csdn.net/tuesdayma/article/details/81359913?utm_medium=distribute.pc_relevant.none-task-blog-OPENSEARCH-2.control&depth_1-utm_source=distribute.pc_relevant.none-task-blog-OPENSEARCH-2.control
  • nginx的proxy_set_header
https://www.cnblogs.com/yyxianren/p/10831564.html

个人总结:
部署注意:
1.nginx的配置文件

user  root;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       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  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       80;
        server_name  localhost;
        client_max_body_size 500M;
        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   /usr/share/nginx/html;
            index  index.html index.htm;
        }

 
        location /dataservice/ {
            proxy_set_header Host $host;
            proxy_pass http://10.52.3.25:50200/;
            #add_header 'Access-Control-Allow-Origin' '*';
            #add_header 'Access-Control-Allow-Credentials' 'true';
            #add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS';
        }
          
        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

     }

}

location /dataservice/ 这里的dataservice需要与前端代码保持一样
在这里插入图片描述
2.nginx里的html文件夹里为dataserviceweb
在这里插入图片描述
3.访问时候,ip:端口/文件夹
例如
http://ip:端口号/dataserviceweb/#/dataManage/dataSource/source

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值