Nginx服务器

1.Nginx服务器

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

2.应用场景

  • 作为Http服务器:可以作为网页静态页面服务器.
  • 虚拟主机:一台服务器可以虚拟出多个网站.
  • 反向代理,负载均衡:当网站访问量达到一定程度时,单台服务器不能满足时,可以利用Nginx做反向代理服务器,多台服务器可以平均分担负载.

3.Nginx的安装   

下载nginx

 

官方网站:

 

http://nginx.org/

 

    环境

1、需要安装gcc的环境。yum install gcc-c++

 

2、第三方的开发包。

 

PCRE

 

PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginxhttp模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。

 

yum install -y pcre pcre-devel

 

注:pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库。

 

 zlib

 

zlib库提供了很多种压缩和解压缩的方式,nginx使用zlibhttp包的内容进行gzip,所以需要在linux上安装zlib库。

 

yum install -y zlib zlib-devel

 

 openssl

 

OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。

 

nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。

 

yum install -y openssl openssl-devel

安装

第一步:把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下创建tempnginx目录

[root@localhost sbin]# mkdir /var/temp/nginx/client -p

第四步:make

第五步:make install

   启动和重启

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

 

4.虚拟主机的配置

  在一台服务器可以启动多个网站.

可以通过端口或者域名来区分.不同的站点.

   1.通过端口来区分不同的虚拟主机.

     进入/conf/Nginx.conf .来修改配置,增加一个server就是一个不同的虚拟主机,这种配置方法是来用端口号来去分不同的虚拟主机,不常用,其中,location则为静态页面所在的位置.

server {
        listen       81;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html81;
            index  index.html index.htm;
        }
 
    }

 

   2.通过域名来区分不同的虚拟主机.(静态页面)

   一个域名对应一个ip地址,一个ip地址可以被多个域名绑定。

        本地测试可以修改hosts文件(C:\Windows\System32\drivers\etc)

在其中可以配置域名和ip地址的映射关系,如果配置了,则不走DNS服务器.

server {
        listen       80;
        server_name  www.taobao.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

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

 

server {
        listen       80;
        server_name  www.baidu.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

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

 

其中www.taobao.com www.baidu.com为Nginx的IP绑定的域名.可以通过域名的不同来区分主机

5.Nginx的反向代理.

    1.Nginx实现反向代理的原理.

       假设有绑定两个不同的域名在Nginx服务器的ip上,当访问不同的域名时,显示不同的页面,在这里Nginx服务器作为一个代理服务器,负责转发到内部不同的tomcat或者别的服务器.

    2.反向代理服务器的测试.

        1.安装两个tomcat,运行在8080和8081端口

         2.启动tomcat服务器

         3.进行反向代理的配置.

upstream tomcat1 {
    server 192.168.25.148:8080;
    }
    server {
        listen       80;
        server_name  www.sina.com.cn;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            proxy_pass   http://tomcat1;
            index  index.html index.htm;
        }
    }
    upstream tomcat2 {
    server 192.168.25.148:8081;
    }
    server {
        listen       80;
#配置域名 host文件下配置 server_name www.sohu.com; #charset koi8-r; #access_log logs/host.access.log main; location / {
#代理 proxy_pass http://tomcat2; index index.html index.htm; } }

hosts文件中添加域名和ip的映射关系

192.168.25.148 www.sina.com.cn

192.168.25.148 www.sohu.com

3.负载均衡

如果一个服务由多条服务器提供,需要把负载分配到不同的服务器处理,需要负载均衡。

 upstream tomcat2 {

server 192.168.25.148:8081;

server 192.168.25.148:8082;

  }

可以根据服务器的实际情况调整服务器权重。权重越高分配的请求越多,权重越低,请求越少。默认是都是1

 upstream tomcat2 {

server 192.168.25.148:8081;

server 192.168.25.148:8082 weight=2;

    }

 

 

6. Nginx的高可用.

    keepalived+nginx实现主备

参考QQ云文件 keepalived高可用

 

posted @ 2018-08-11 23:08  流浪的小蛤蟆  阅读(162)  评论(0)    收藏  举报