Nginx的安装与配置

Nginx

  1. 什么是nginx

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

 

Nginx的应用场景

1、http服务器。Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器。 

2、虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。 

3、反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用nginx做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。

 

Nginx的安装步骤

第一步:把nginx的压缩包上传到服务器 

第二步:解压。 

第三步:创建一个makefile(配置文件 )。  

    ./configure \            // 创建makefile文件后 ,执行这个命令

 

    --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   

    注意:上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录 

第四步:编译make 

第五步:安装make install

 

Nginx实现虚拟机

 

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

同一个服务器可能有一个ip,网站需要使用80端口。网站的域名不同。 

区分不同的网站有三种方式: 

    1、ip区分

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

1/etc/sysconfig/network-scripts/ifcfg-eth0文件复制一份,命名为ifcfg-eth0:1

修改其中内容:

DEVICE=eth0:1

IPADDR=192.168.xxx.xxx

其他项不用修改

2、重启系统

 

二、基于ip的虚拟主机配置 nignx/conf/nginx.conf配置文件

server { #一个server就是一个虚拟主机

        listen       80;

        server_name  192.168.253.181;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            root   html-181; #root是指nginx的根目录  nginx目录下的html文件夹

            index  index.html index.htm; 

        }

        

    }

    server {

        listen       80;

        server_name  192.168.253.182;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            root   html-182;

            index  index.html index.htm; 

        } 

    }

三、Nginx重新加载配置文件。 ./nginx -s reload

 

   2、端口区分 

 

一、修改nignx/conf/nginx.conf配置文件

    server {

        listen       81;

        server_name  192.168.253.181;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            root   html-81;

            index  index.html index.htm;

        }

        

    }

    server {

        listen       82;

        server_name  192.168.253.181;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            root   html-82;

            index  index.html index.htm;

        }

    }

二、Nginx重新加载配置文件。

   3、域名区分

最有用的虚拟主机配置方式。一个域名只能绑定一个ip地址,一个ip地址可以被多个域名绑定。

可以修改windows下的host文件实现域名访问。

一、修改nignx/conf/nginx.conf配置文件 

   server {

        listen       80;

        server_name  www.taotao.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            root   html-com;

            index  index.html index.htm;

        }

        

    }

    server {

        listen       80;

        server_name  www.taotao.cn;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            root   html-cn;

            index  index.html index.htm;

        }

        

    }

二、Nginx重新加载配置文件。

 

Nginx的反向代理

使用nginx实现反向代理

Nginx只做请求的转发,后台有多个http服务器提供服务,nginx的功能就是把请求转发给后面的服务器,决定把请求转发给谁。

1、安装tomcat

  在一个虚拟机上创建两个tomcat实例,模拟多个服务器。  

2、配置nginx.conf

    upstream tomcatserver1 {

        server 192.168.253.181:8080;

    }

    upstream tomcatserver2 {

        server 192.168.253.181:8081;

    }

   server {

        listen       80;

        server_name  8080.taotao.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            proxy_pass   http://tomcatserver1;

            index  index.html index.htm;

        }

        

    }

    server {

        listen       80;

        server_name  8081.taotao.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            proxy_pass   http://tomcatserver2;

            index  index.html index.htm;

        }

        

    }

如果在同一个域名下有多台服务器提供服务,此时需要nginx负载均衡。

 

负载均衡

1、什么是负载均衡负载均衡 

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

 

  配置nginx的负载均衡   

 upstream tomcatserver1 {

        server 192.168.253.181:8080;

        server 192.168.253.181:8081; #增加一台服务器在这个重定向中

    }

   server {

        listen       80;

        server_name  8080.taotao.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            proxy_pass   http://tomcatserver1;

            index  index.html index.htm;

        }

        

    }

    server {

        listen       80;

        server_name  8081.taotao.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            proxy_pass   http://tomcatserver2;

            index  index.html index.htm;

        }

    }

 

配置负载均衡的权重

    在配置负载均衡的基础上配置权重

 upstream tomcatserver1 {

        server 192.168.253.181:8080 weight=3; #权重成比例关系

        server 192.168.253.181:8081 weight=1; #weight默认为1,权重越高,处理的请求越多

    }
server {

        listen       80;

        server_name  8080.taotao.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            proxy_pass   http://tomcatserver1;

            index  index.html index.htm;

        }

    }

    server {

        listen       80;

        server_name  8081.taotao.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            proxy_pass   http://tomcatserver2;

            index  index.html index.htm;

        }

    }

 

节点说明:

在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机器。所以这台机器压力会最轻。

 

Nginx的高可用

    解决高可用的方案就是添加冗余。 

     使用keepalive监听

 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值