快速了解nginx

1. 基本概念

1.1 nginx

Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。

1.2 特点

占有内存少,并发能力强,能够支持高达 50,000 个并发连接数的响应,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。

1.3 应用场景

1、http服务器。Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器。
2、虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。
3、反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用nginx做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。

1.4 进行安装

请点击这里进行安装
我的CentOS 版本为7.4
点击这里获取nginx的安装软件
提取码:z4kn
安装中途可能碰到没有C++,大家不要慌,
建议先安装C++
yum -y install gcc gcc-c++
安装成功会提示 Complete!

2. 反向代理

无论时正向代理还是反向代理,代理服务器都存在。举个例子:
我想要访问www.baidu.com时,即访问目标服务器(www.baidu.com),
我将请求提交给中间一个代理服务器,
代理服务器带着我的请求访问目标服务器,
目标服务器将结果返回给代理服务器,
代理服务器将结果返回给我。

2.1 正向代理

正向代理就是通过在客户端设置代理服务器,然后通过代理服务器访问目标服务器
将客户端和代理服务器看成一个局域网,目标服务器时另一个局域网。
目标服务器知道代理服务器的存在,但是不知道客户端(用户)的存在。

在这里插入图片描述

2.2反向代理

反向代理服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器的资源。
反向代理服务器:将用户的请求进行转发,让其它的服务器进行处理,可以做到负载均衡。
同时,用户不需要知道目标服务器的地址,也无须在用户端作任何设定。反向代理服务器通常可用来作为Web加速,即使用反向代理作为Web服务器的前置机来降低网络和服务器的负载,提高访问效率.

在这里插入图片描述

2.3 使用nginx实现反向代理

Nginx只做请求的转发,后台有多个http服务器提供服务,nginx的功能就是把请求转发给后面的服务器,决定把请求转发给谁。
1.安装tomcat
点击获取链接
在这里插入图片描述
使用rz命令时,首先要进入linux中上传的目录

yum install lrzsz -y  #安装rz命令
rz #从本地选择你上传的文件

2.配置tomcat

 tar -zxvf apache-tomcat-7.0.103.tar.gz #解压缩
 mv apache-tomcat-7.0.103 tomcat1  #修改名字为tomcat1
 cp tomcat1/ tomcat2  #进行复制
 mkdir /usr/local/tomcat #创建文件夹
 #mv tomcat1/ tomcat2/ /usr/local/tomcat/将tomcat1 和 tomcat2 移动到tomcat中
vi /usr/local/tomcat/tomcat2/conf/server.xml   #进行修改配置文件(两个tomcat端口会产生冲突,选择修改tomcat2)(下面第一二张图)
/usr/local/tomcat/tomcat1/bin/startup.sh     #重启tomcat1
/usr/local/tomcat/tomcat2/bin/startup.sh     #重启tomcat2
vi /usr/local/tomcat/tomcat2/webapps/ROOT/index.jsp# 在展示页面进行标注(第三张图)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  1. 配置hosts
    在这里插入图片描述
  2. 配置nginx
    vi /usr/local/nginx/conf/nginx.conf添加以下配置
    http://8081.taotao.com/请求过来时,proxy_pass会将server_name的请求进行转发到proxy_pass指定的服务器上进行处理。
 upstream tomcatserver1 {
        server 192.168.121.131:8080;
    }
    upstream tomcatserver2 {
        server 192.168.121.131:8081;
    }
   server {
        listen       80;
        server_name  8080.taotao.com;
        location / {
        	#将域名为8080.taotao.com的请求转发到tomcatserver1的服务器上
            proxy_pass   http://tomcatserver1;
            index  index.html index.htm;
        }
    }
    server {
        listen       80;
        server_name  8081.taotao.com;
        location / {
            proxy_pass   http://tomcatserver2;
            index  index.html index.htm;
        }
       
    }

在这里插入图片描述
在这里插入图片描述

3. 负载均衡

负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。
负载均衡,英文名称为Load Balance,其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。

请求量增大时,一台服务器应付不过来了,我们可以选择更换高级的服务器,一般不太适用;我们还可以增加服务器的数量,将请求分发到各个服务器上,将原来请求到单个服务器的情况改为请求到多个服务器上,将负载分发到多个服务器上,即负载均衡。
在这里插入图片描述

3.1 配置nginx的负载均衡

vi /usr/local/nginx/conf/nginx.conf  #配置负载均衡
 /usr/local/nginx/sbin/nginx -s reload  #从新加载配置

在这里插入图片描述

节点说明:
在http节点里添加:
#定义负载均衡设备的 Ip及设备状态
upstream myServer {
server 127.0.0.1:9090 down;
server 127.0.0.1:8080 weight=2;
server 127.0.0.1:6060;
server 127.0.0.1:7070 backup;
}
在需要使用负载的Server节点下添加
proxy_pass http://myServer;
upstream 每个设备的状态:
down 表示单前的server暂时不参与负载
weight 默认为1.weight越大,负载的权重就越大。
max_fails :允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误
fail_timeout:max_fails 次失败后,暂停的时间。
backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。

4. 动静分离

动静不分离时,服务器压力比较大哦
在这里插入图片描述
为了加快网站的解析速度,可以把静态页面和动态页面由不同的服务器来解析,降低原来单个服务器的压力。
在这里插入图片描述

5. nginx 实现虚拟主机

本地ip是192.168.121.131
在这里插入图片描述

可以实现在同一台服务运行多个网站,而且网站之间互相不干扰。

同一个服务器可能有一个ip,网站需要使用80端口。网站的域名不同。
区分不同的网站有三种方式:
1、ip区分
2、端口区
3、分域名区分

7.1 ip区分

需要一台服务器绑定多个ip地址。

  1. /etc/sysconfig/network-scripts/ifcfg-eth33文件复制一份,命名为ifcfg-eth33:1
    修改其中内容:
    NAME=ens33:1
    DEVICE=eth33:1
    IPADDR=192.168.121.132
    其他项不用修改
cd /etc/sysconfig/network-scripts
ls
cp ifcfg-ens33 ifcfg-ens33:1
vi ifcfg-ens33:1

在这里插入图片描述
2. 重启系统并查看ip

reboot
ifconfig

在这里插入图片描述
3. 浏览器访问 192.168.121.132
在这里插入图片描述

7.2 基于nginx的配置

一个server就是一个虚拟主机,通过配置nginx中conf/nginx.conf的配置文件,来配置虚拟主机
server 虚拟主机的配置
listen 监听端口
root 根路径
index 打开的页面

命令:在nginx/sbin下执行

 ./nginx -s reload   重新加载配置文件
 ./nginx   启动nginx
 nginx -t    查看配置文件是否正确

7.2.1 基于ip地址的虚拟主机

7.2.2 基于端口的虚拟主机

server {
        listen       81;
        server_name  localhost;
        location / {
            root   html-138;
            index  index.html index.htm;
        }
        location  /images/  {
        root    /home/ftpuser/www;
        autoindex  on;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }


    }

在这里插入图片描述

7.2.3 基于域名的虚拟主机

最有用的虚拟主机配置方式。
一个域名只能绑定一个ip地址,一个ip地址可以被多个域名绑定。
在这里插入图片描述

  1. 配置nginx.conf的配置文件,添加一个server
server {
		#监听端口
        listen       80;
        #域名可以有多个,用空格隔开
        server_name  www.taotao.com;


        location / {
            root   html-www;
            index  index.html index.htm;
        }



        location  /images/  {
        root    /home/ftpuser/www;
        autoindex  on;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }


    }
  1. 创建html-www的文件,在nginx目录下执行
    修改标题便于观察,没有实质性作用
cp html/ html-www
vi html-www/index.html 

在这里插入图片描述

可以修改hosts(C:\Windows\System32\drivers\etc\hosts)文件实现域名访问。
在这里插入图片描述
3. 浏览器访问
在这里插入图片描述

补充个小知识点:
域名解析:
定义:给一个域名绑定一个ip地址。
域名:ip地址=1:n
流程:
①用户要打开www.baidu.com时,
②首先查看本地DNS服务器,
如果有,则告诉用户,用户ip地址,用户通过ip地址直接访问该网站;
如果没有www.baidu.com的域名,则向下一级继续查找;
③该级查找方式和上一级一样,依此类推,进行查找。
④到最后访问的时DNS根服务器,它记录着所有的域名和ip的映射,
如果查到,则依次写入经过的服务器;
如果没有,不好意思,很抱歉,真的找不到了。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值