Nginx安装以及常用的代理机制

1.Nginx简介

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

2 Nginx的应用场景

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

3 Nginx的下载及安装

3.1 下载

进入http://nginx.org/en/download.html 下载nginx1.8.0版本(当前最新稳定版本)。

这里写图片描述

3.2 Nginx的安装

3.2.1 环境:
1、Linux:centos6.4(32位)
2、Gcc的编译环境。使用make命令编辑。
yum install gcc-c++
3、PCRE
PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。
yum install -y pcre pcre-devel
注:pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库。
4、zlib
zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。
yum install -y zlib zlib-devel

5、openssl
OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。
nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。
yum install -y openssl openssl-devel
3.2.2 安装步骤
第一步:把Nginx的安装包上传到linux系统。
第二步:解压压缩包。
[root@bogon ~]# tar -zxf nginx-1.8.0.tar.gz
第三步:进入源码目录。
参数设置如下:

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

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

4 Nginx的启动和停止

在nginx的安装目录(/usr/local/nginx/sbin)下有一个nginx的可执行文件。
启动:[root@bogon sbin]# ./nginx
这里写图片描述
关闭服务:
[root@bogon sbin]# ./nginx -s stop

重新加载配置文件:
[root@bogon sbin]# ./nginx -s reload

关闭防火墙:[root@bogon sbin]# service iptables stop

5.Nginx实现虚拟机

1、可以使用ip地址区分网站。
2、使用端口区分网站

Nginx的配置文件:conf/nginx.conf


#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

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

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

    }

    server {
        listen       81;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

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

6 通过域名区分虚拟机

域名:为了便于记忆。
这里写图片描述
一个域名对应一个ip地址。
一个ip地址可以对应多个域名。
Nginx虚拟机可以通过域名区分访问哪个网站。

6.1 可以修改host文件修改域名的指向。

如果本地host文件中有域名和ip的对应关系,不走dns服务器。直接访问。

Host文件的存放路径:
修改window的hosts文件:(C:\Windows\System32\drivers\etc)

6.2 修改nginx的配置文件:

 server {
        listen       80;
        server_name  test1.taotao.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html-test1;
            index  index.html index.htm;
        }
   }
   server {
        listen       80;
        server_name  test2.taotao.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

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

7 Nginx的反向代理

这里写图片描述
这里写图片描述
使用nginx做反向代理,访问同一个域名让两个Tomcat提供服务。
第一步:启动两个Tomcat
第二步:修改host配置域名。
第三步:配置nginx。

upstream tomcat1 {
    server 192.168.25.133:8080;
    server 192.168.25.133:8081;
   }

   server {
        listen       80;
        server_name  images.taiaofa.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            proxy_pass   http://tomcat1;
            index  index.html index.htm;
        }
   }

第四步:重新加载配置文件

8 负载均衡

这里写图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值