NGINX使用

NGINX使用

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

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

  3. nginx安装
    3.1. 下载nginx
    官方网址 link http://nginx.org/download/.使用的版本是1.8.0版本。
    3.2. 需要安装gcc的环境。yum install gcc-c++
    3.3. 第三方的开发包。
    3.3.1. PCRE
    PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。
    yum install -y pcre pcre-devel
    注:pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库。
    3.3.2. zlib
    zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。
    yum install -y zlib zlib-devel
    3.3.3. openssl
    OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。
    nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。
    yum install -y openssl openssl-devel
    3.4. 安装步骤
    第一步:把nginx的源码包上传到linux系统
    第二步:解压缩
    [root@localhost ~]# tar zxf nginx-1.8.0.tar.gz
    第三步:使用configure命令创建一makeFile文件。
    ./configure
    –prefix=/usr/local/nginx
    –pid-path=/var/run/nginx/nginx.pid
    –lock-path=/var/lock/nginx.lock
    –error-log-path=/var/log/nginx/error.log
    –http-log-path=/var/log/nginx/access.log
    –with-http_gzip_static_module
    –http-client-body-temp-path=/var/temp/nginx/client
    –http-proxy-temp-path=/var/temp/nginx/proxy
    –http-fastcgi-temp-path=/var/temp/nginx/fastcgi
    –http-uwsgi-temp-path=/var/temp/nginx/uwsgi
    –http-scgi-temp-path=/var/temp/nginx/scgi
    注意:启动nginx之前,上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录
    [root@localhost sbin]# mkdir /var/temp/nginx/client -p
    第四步:make
    第五步:make install
    .

  4. 启动nginx

    进入sbin目录
    [root@localhost sbin]# ./nginx
    关闭nginx:
    [root@localhost sbin]# ./nginx -s stop
    推荐使用:
    [root@localhost sbin]# ./nginx -s quit

    重启nginx:
    1、先关闭后启动。
    2、刷新配置文件:
    [root@localhost sbin]# ./nginx -s reload

  5. 配置虚拟主机
    5.1. 就是在一台服务器启动多个网站。
    如何区分不同的网站:1域名不同、2端口不同
    5.2. 通过端口区分不同虚拟机
    Nginx的配置文件:
    /usr/local/nginx/conf/nginx.conf

server {
		#监听81端口
        listen       81;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;
		# “/” 代表nginx安装根路径
        location / {
        	# 根路径下的html81文件夹
            root   html81;
            #默认首页  index.html
            index  index.html index.htm;
        }

    }

上面配置监听80和81端口 转发到不同的url地址
5.3. 通过域名区分虚拟主机
5.3.1什么是域名
www.baidu.com
www.taobao.com
www.jd.com
Tcp/ip
Dns服务器:把域名解析为ip地址。保存的就是域名和ip的映射关系。
一级域名:
Baidu.com
Taobao.com
Jd.com
二级域名:
www.baidu.com
Image.baidu.com
Item.baidu.com
三级域名:
1.Image.baidu.com
Aaa.image.baidu.com
一个域名对应一个ip地址,一个ip地址可以被多个域名绑定。
本地测试可以修改hosts文件。
修改window的hosts文件:(C:\Windows\System32\drivers\etc)
可以配置域名和ip的映射关系,如果hosts文件中配置了域名和ip的对应关系,不需要走dns服务器。
6.0 反向代理
6.1 什么是反向代理
在这里插入图片描述
返回代理服务器不提供服务器。也是请求的转发
6.1 NGINX实现反向代理
两个域名指向同一台nginx服务器,用户访问不同的域名显示不同的网页内容。
两个域名是www.mytest1.com和www.mytest2.com
nginx服务器使用虚拟机192.168.25.129
第一步:安装两个tomcat,分别运行在8080和8081端口。
第二步:启动两个tomcat。
第三步:反向代理服务器的配置
复制一个server节点,将root改成proxy_pass
配置upstream

# tomcat1
upstream tomcat1{
	#远端tomcat01
	server 192.168.25.129:8080;
    }
   #tomcat2 
    upstream tomcat2{
    #远端tomcat01
	server 192.168.25.129:8081;
    }
    server {
        listen       80;
        server_name  www.mytest1.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            proxy_pass   http://tomcat1;
            index  index.html index.htm;
        }
    }
    server {
        listen       80;
        server_name  www.mytest2.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;
		
        location / {
            proxy_pass   http://tomcat2;
            index  index.html index.htm;
        }
    }

第四步:nginx重新加载配置文件
第五步:配置域名
在hosts文件中添加域名和ip的映射关系
192.168.25.129 www.mytest1.com
192.168.25.129 www.mytest2.com

效果:在这里插入图片描述
在这里插入图片描述
7.0 负载均衡
如果一个服务由多条服务器提供,需要把负载分配到不同的服务器处理,需要负载均衡。
upstream tomcat2 {
#weight是权重 默认为1
server 192.168.25.129:8081 weight=1;
server 192.168.25.129:8082 weight=1;
}

upstream tomcat1{
	server 192.168.25.129:8080;
	server 192.168.25.129:8082;
    }

效果:
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值