Nginx相关知识

Nginx相关知识

一、Nginx介绍

1.1.什么是Nginx?

​ Nginx是一款轻量级的Web 服务器反向代理服务器及电子邮件(IMAP/POP3)代理服务器,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。

特点:反向代理 负载均衡 动静分离

1.2.什么是反向代理?

代理服务可简单的分为正向代理和反向代理:

  • 正向代理: 用于代理内部网络对internet的连接请求(如VPN/NAT),客户端指定代理服务器,并将本来要直接发送给目标Web服务器的HTTP请求先发送到代理服务器上, 然后由代理服务器去访问Web服务器, 并将Web服务器的Response回传给客户端。

    所谓的正向代理就是代理服务器**替代访问方【用户】**去访问目标服务器【服务器】
    请添加图片描述

  • 反向代理: 与正向代理相反, 反向代理是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器

所谓的反向代理就是代替服务器接受用户的请求(nginx代替tomcat接受请求),从目标服务器中取得用户的需求资源,然后发送给用户

请添加图片描述

1.3.什么是负载均衡?

  • 负载均衡:数据流量分摊到多个服务器上执行,减轻每台服务器的压力,多台服务器共同完成工作任务,从而提高了数据的吞吐量。

    简单来讲负载均衡就是把请求平均分给多台tomcat。

请添加图片描述

1.4.什么是动静分离?

  • 动静分离:将静态的资源放到反向代理服务器,节省用户的访问时间

    简单来讲动静分离就是把项目中的静态资源交给nginx去处理*

Web服务器分2类:

  • web应用服务器,如:
    • tomcat
    • resin
    • jetty
  • web服务器,如:
    • Apache 服务器
    • Nginx
    • IIS

区分:web服务器不能解析jsp等页面,只能处理js、css、html等静态资源。
并发:web服务器的并发能力远高于web应用服务器。


二、安装Nginx

2.1.下载Nginx

官方网站:http://nginx.org/

2.2.安装nginx

  • 安装nginx的依赖库,也就是C语言环境
yum -y install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel
  • 解压安装包
 cd /usr/upload
 tar -zxvf nginx-1.10.0.tar.gz

设置安装目录

cd /usr/upload/nginx-1.10.0
./configure --prefix=/usr/local/nginx

注意:./configure配置nginx安装到/usr/java/nginx目录下。

编译并安装

make && make install

2.3.目录结构

conf:配置文件
logs:日志
sbin:启动脚本
html:静态页面

注:以上目录是刚安装时的,运行后会产生很多的临时目录,不用在意。

2.4.Nginx的启动及关闭

  • 启动
#在nginx目录下有一个sbin目录,sbin目录下有一个nginx可执行程序
cd /usr/local/nginx/sbin
./nginx

请添加图片描述

  • 测试:

请添加图片描述

  • 关闭
./nginx -s stop
  • 动态加载配置文件
#可以不关闭nginx的情况下更新配置文件
./nginx -s reload
  • 配置文件介绍
#user  nobody;
#工作进程
worker_processes  1;

events {
    #连接池连接数
    worker_connections  1024;
}
#请求方式
http {
    #媒体类型
    include       mime.types;
    #默认媒体类型 二进制
    default_type  application/octet-stream;
    #上传文件
    sendfile        on;
    #超时时间
    keepalive_timeout  65;

    #gzip  on;
    #服务器配置
	server {
        #监听端口
        listen       80;
        #监听域名
        server_name  localhost;
        #请求头信息
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Forwarded-Server $host;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        #请求映射规则,/代表所有请求路径
        location / {
             #请求转发地址
             #root html;
			 proxy_pass http://manage.powershop.com:8080;
             #欢迎页
             #index  index.html index.htm;
             #转发连接超时时间
			proxy_connect_timeout 600;
             #转发读取超时时间
			proxy_read_timeout 600;
        }
    }
}

2.5.Nginx代理tomcat

2.5.1.在linux中安装两台tomcat

1、解压两个tomcat到/usr/java,分别命名为tomcat-8080,tomcat-8090

请添加图片描述

2、修改tomcat的配置文件,将端口进行修改:

请添加图片描述

3、分别启动tomcat-8080,tomcat-8090

/url/local/tomcat-8080/apache-tomcat-9.0.68/bin
chomd 777 catalinna.sh
chmod 777 catalina.sh
./catalina.sh run
/url/local/tomcat-8090/apache-tomcat-9.0.68/bin
chomd 777 catalinna.sh
chmod 777 catalina.sh
./catalina.sh run

请添加图片描述
请添加图片描述

2.5.2.反向代理

修改nginx/conf/nginx.conf文件:

 server{
        listen 80;
        server_name localhost;
        #location代表映射规则,/代表任意url
        location / {
            proxy_pass http://127.0.0.1:8080; #代理通道只写ip和port,因为url会拼接到ip和port
        }

    }
2.5.3.负载均衡

1、在http节点上添加一个upstream

2、修改location /下的反向代理

upstream myTomcats{
        server 127.0.0.1:8080;
        server 127.0.0.1:8090;
    }
    server{
        listen 80;
        server_name localhost;

        location / {
            proxy_pass http://myTomcats;
        }
    }
2.5.4.六种负载均衡策略
负载均衡策略说明
轮询默认
weight权重方式
ip_hash根据客户端ip分配
least_conn根据tomcat连接数分配
fair根据tomcat相应时间分配
url_hash依据URL分配
2.5.5.Tomcat集群的session共享
  • 问题:如何防止session丢失?

请添加图片描述

方法一:保证一个ip地址永远的访问一台tomcat服务器,就不存在session共享问题了(只支持linux)

 即:upstream中添加 ip_hash;如果tomcat1挂了,仍然会访问tomcat2

方法二:session的共享

一种使用tomcat广播机制完成session的共享,多台tomcat时,复制session非常耗费资源(只支持windows,不推荐的方式)
一种使用redis服务器的方式完成session的共享,redis和session都是k、v,都能设置过期时间(推荐的方式)

2.6动静分离

2.6.1.创建静态资源

在虚拟机中新建images文件夹,并上传图片

请添加图片描述

2.6.2配置nginx的nginx.conf
server{
        listen 80;
        server_name localhost;

        location ~* \.(gif|jpg|png|jpeg)$ {
            root /usr/upload/images; #root:转发到目录里
        }
    }
2.6.3.测试

http://192.168.19.133/111.jpg

请添加图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值