Nginx

文章目录

  • 1.Nginx介绍
    • 1.1.什么是Nginx
    • 1.2.反向代理
    • 1.3.负载均衡
    • 1.4.动静分离
    • 1.5.Web服务器
  • 2.安装Nginx
    • 2.1.下载Nginx
    • 2.2.安装nginx
    • 2.3.目录结构
  • 3.Nginx的启动及关闭
    • 3.1.启动
    • 3.2.关闭
    • 3.3.动态加载配置文件
    • 3.4.配置文件介绍
  • 4.Nginx代理tomcat
    • 4.1.在linux中安装两台tomcat
    • 4.2.代理一台tomcat(反向代理)
    • 4.3.代理多台tomcat(负载均衡)
    • 4.4.负载均衡策略
      • 4.4.1.六种负载均衡策略
      • 4.4.2.权重
    • 4.5.Tomcat集群的session共享
  • 5.动静分离
    • 5.1.创建静态资源
    • 5.2.配置nginx的nginx.conf
    • 5.3.测试

1.Nginx介绍

1.1.什么是Nginx

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

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

1.2.反向代理

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

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

    所谓的正向代理就是代理服务器**替代访问方【用户】**去访问目标服务器【服务器】
    Nginx_第1张图片

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

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

Nginx_第2张图片

1.3.负载均衡

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

1.4.动静分离

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

1.5.Web服务器

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

区分:web服务器不能解析jsp等页面,只能处理js、css、html等静态资源。

并发:web服务器的并发能力远高于web应用服务器。

2.安装Nginx

2.1.下载Nginx

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

2.2.安装nginx

  • 安装nginx的依赖库
yum -y install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel
  • 解压安装包
tar -zxvf nginx-1.10.0.tar.gz
  • 配置nginx安装包
cd nginx-1.10.0

./configure --prefix=/usr/local/nginx

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

  • 编译并安装
make && make install

2.3.目录结构

├── client_body_temp         # 临时目录
├── conf                     # Nginx所有配置文件的目录
│   ├── nginx.conf                 # Nginx主配置文件
├── fastcgi_temp             # fastcgi临时数据目录
├── html                     # Nginx默认站点目录
│   ├── 50x.html                   # 错误页面优雅替代显示文件,例如当出现502错误时会调用此页面
│   └── index.html                 # 默认的首页文件
├── logs                     # Nginx日志目录
│   ├── access.log			      # 访问日志文件
│   ├── error.log			      # 错误日志文件
│   └── nginx.pid			      # pid文件,Nginx进程启动后,会把所有进程的ID号写到此文件
├── proxy_temp               # 临时目录
├── sbin                     # Nginx命令目录
│   └── nginx			          # Nginx的启动命令
├── scgi_temp                # 临时目录
└── uwsgi_temp               # 临时目录

3.Nginx的启动及关闭

3.1.启动

#在nginx目录下有一个sbin目录,sbin目录下有一个nginx可执行程序
./nginx

在这里插入图片描述

测试:
Nginx_第4张图片

3.2.关闭

./nginx -s stop

3.3.动态加载配置文件

#可以不关闭nginx的情况下更新配置文件
./nginx -s reload

3.4.配置文件介绍

完整配置:

#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;
        }
    }
}

4.Nginx代理tomcat

4.1.在linux中安装两台tomcat

1、解压两个tomcat到/usr/java,分别命名为tomcat1,tomcat2

2、修改tomcat的配置文件,将端口进行修改:
Nginx_第5张图片
3、将资料中的test.war项目分别发布到两个tomcat中并测试
Nginx_第6张图片

4.2.代理一台tomcat(反向代理)

修改nginx/conf/nginx.conf文件:
Nginx_第7张图片

4.3.代理多台tomcat(负载均衡)

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

2、修改location /下的反向代理
Nginx_第8张图片

4.4.负载均衡策略

4.4.1.六种负载均衡策略

负载均衡策略 说明
轮询 默认
weight 权重方式
ip_hash 依据ip分配方式
least_conn 按连接数
fair 按响应时间
url_hash 依据URL分配

4.4.2.权重

在这里插入图片描述

4.5.Tomcat集群的session共享

问题:
Nginx_第9张图片
方法一:保证一个ip地址永远的访问一台tomcat服务器,就不存在session共享问题了(只支持linux)
即:upstream中添加 ip_hash;

方法二:session的共享
一种使用tomcat广播机制完成session的共享(只支持windows,不推荐的方式)
一种使用redis服务器的方式完成session的共享(推荐的方式)

5.动静分离

5.1.创建静态资源

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

5.2.配置nginx的nginx.conf

	location ~* \.(gif|jpg|png|jpeg)$ {
		root /usr/upload/images;
	}

5.3.测试

http://192.168.126.133/222.png
Nginx_第11张图片

你可能感兴趣的:(nginx,服务器,网络)