当前位置: 澳门新濠3559 > 操作系统 > 正文

3、掌握nginx tomcat反向代理的使用方法,需要用多

时间:2019-10-07 14:54来源:操作系统
Nginx 基本操作 解释 命令 安装 yum install nginx 启动 service nginx start 停止 service nginx stop 重载 service nginx reload 要留心的是设置的时候须求加上八个CentOS7 Nginx yum能源库 rpm -Uvh http://nginx.org/

Nginx

  1. 基本操作
解释 命令
安装 yum install nginx
启动 service nginx start
停止 service nginx stop
重载 service nginx reload

要留心的是设置的时候须求加上八个CentOS7 Nginx yum能源库

rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm,然后再安装yum install nginx

  1. 运转成功后

    • 翻看进度是或不是存在:ps -ef | grep nginx
    • 那儿在本机Win地址栏输入 192.168.2.1(也正是设想机ip),就寻访到款待分界面
      澳门新濠3559 1
  2. 安排设想主机

    • 进入:cd /etc/nginx/,打开vim nginx.conf文件,那是一对配备文件,
    • 然后到:cd /etc/nginx/conf.d/,会有七个暗中认可文件default.conf,在此地能够看来nginx私下认可的根目录,打开 vim /usr/share/nginx/html/index.html,这么些就是nginx的招待分界面
    • 直白在那个目录下把暗许文件default.conf复制一份,比如imooc.conf,根据那些写就能够了,然后重载
    server{
        listen  80;
        server_name  www.imooc.test;
        root /data/www;
        index  index.html  index.htm;
    }
    
    • 若想布署三个设想主机,重复上边包车型大巴操作就能够了,再复制一份,要在意路径,
    • 若二个虚构主机想多端口访谈直接多写一个listen,或许多域名,就在那些域名前面多写二个就能够了,要小心格式,因为此地的域名是虚构的,所以还的在host里增加,和上边同样
    server{
        listen  80;
        listen  9999;
        server_name  www.imooc.test www.imooc2.test;
        root /data/www;
        index  index.html  index.htm;
    }
    

    澳门新濠3559 2

  3. 伪静态

    • 还是在配备设想主机的文本中,此时只要后缀名.htmp的都会拜会index.html页面
    server{
        listen  80;
        server_name  www.imooc.test;
        root /data/www;
        index  index.html  index.htm;
        location / {
            rewrite ^(.*).htmp$ /index.html;
        }
    }
    
  4. 日记的格式化

    • cd /etc/nginx,打开nginx.conf文件,在log_format后边的,会看出部分格式以及存放的路径,/var/log/nginx/access.log,查看一下:tail -f /var/log/nginx/access.log
    • 自定义格式,只须求:
    • 澳门新濠3559 3

    • 也得以在设想主机中钦定日志的职务,那样方便管理,记得从重载服务器

    server{
        listen  80;
        server_name  www.imooc.test;
        root /data/www;
        index  index.html  index.htm;
        # 指定日志关键字 存放的路径 日志格式的名字,就是上面自定义的
        access_log /var/log/nginx/access_imooc.log imooc;
        location / {
            rewrite ^(.*).htmp$ /index.html
        }
    }
    
  5. 反向代理

    • 进入到cd /etc/nginx/conf.d,vim imooc.conf文件,如

      # 这个访问的实际ip地址,方便下面引用
      upstream imooc_hosts {
          server 118.89.106.129:80;
      }
      server {
          listen    80;
          server_name  www.imooc.test;
              root   /data/nginx;
              index  index.html index.htm;
          location / {
             # 实际ip地址对应的Host
              proxy_set_header Host www.54php.cn;
              # 这个就是引用上面的方便管理
              proxy_pass http://imooc_hosts;
          }   
      }   
      
    • 重载服务器,访谈www.imooc.test本条网站,实际上就能拜望到www.54php.cn,此时前边三个正是作为八个代理

  6. 负载均衡

    • 若这一年,再imooc_hosts里增加一条网站,那么在率先次访谈www.imooc.test本条网站,就到到第一条对应的网站,第二拜见,就回到第二条对应的网站,第二回依旧率先条对应的网站,......

    • 若不想这样循环,想让八个服务器访谈的次数多一些,那么,在前面加多一个首要字就足以了,如下,这样第三个网站被访谈的次数正是第四个网站的五倍

       server 118.89.106.129:80 weight=5;
       server 101.132.110.127:80 weight=1;
      
  7. 调解成效

    • 相似出错的时候进行,依旧在设想主机配置文件中,增多底下的情节,重载服务器,此时在页面上就博览会示需要的域名是何等和客商端地址
    server {
        listen    80;
        # 添加下面的内容
        add_header Content-Type "text/plain;charset=utf-8";
        return 200 "$http_host $remote_addr";
        server_name  www.imooc.test;
        root   /data/nginx;
        index  index.html index.htm;
    }   
    

#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  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ .php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ .php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /.ht {
        #    deny  all;
        #}
    }




    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       8000;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;

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


    # HTTPS server
    #
    #server {
    #    listen       443 ssl;
    #    server_name  localhost;

    #    ssl_certificate      cert.pem;
    #    ssl_certificate_key  cert.key;

    #    ssl_session_cache    shared:SSL:1m;
    #    ssl_session_timeout  5m;

    #    ssl_ciphers  HIGH:!aNULL:!MD5;
    #    ssl_prefer_server_ciphers  on;

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

}

4.4.停止nginx

方法1,神速结束:

cd /usr/local/nginx/sbin

./nginx -s stop

此方法也正是先摸清nginx进度id再使用kill命令强制杀掉进度。

 

方法2,完整结束(提出利用):

cd /usr/local/nginx/sbin

./nginx -s quit

此形式甘休步骤是待nginx进度管理任务实现举办结束。

 

 

Linux下Apache设想主机的布局

      本文接纳的httpd版本仍旧httpd-2.2.4。

       访谈web服务,本质上看(从事商业业事务上)是探望有些IP的主机上的某部端口(暗中同意是80)。日常供给通过探望差别的域名照旧端口完成对两样网址的拜候(具体到服务器里正是见仁见智目录),那一年就要求设置设想主机(VirtualHost).平时分为那样3种:      (1)基于主机       (2)基于端口       (3)基于IP 以及那三种艺术的长短不一。虚构机的ip为192.168.109.40。本机的ip为192.168.109.1 策画干活:关闭防火墙,步向apache配置文件httpd.conf 找到这一行并注释掉DocumentRoot "/usr/local/apache/htdocs" 然后找到 #Virtual hosts #Include /etc/httpd/extra/httpd-vhosts.conf将第二行启用,然后步向/etc/httpd/extra/httpd-vhosts.conf那样准备干活就成功了,下边分别安装虚拟主机的两种方法。 1、基于IP的设想主机配置方式。 大家能够在eth0上绑定三个ip地址。能够用ip addr add ip地址 dev eth0绑定ip。在此处大家绑定192.168.109.41与192.168.109.42那五个ip地址。 用ip addr show能够查看绑定完的消息,如下图所示 澳门新濠3559 4 然后修改 /etc/httpd/extra/httpd-vhosts.conf里的内容。举个例子下边:      ServerName www.a.com             设置虚构主机名字为www.a.com      DocumentRoot "/www/b.com"   web页面存放地方      Options none      AllowOverride none      Require all granted     ErrorLog "/var/log/httpd/b.com-error_log"     CustomLog "/var/log/httpd/b.com-access_log" common 同理,对安排192.168.109.42的虚构主机只须要按下边内容复制,然后修改相应地方就能够。 因为大家把web页面放在/www/a.com与/www/b.com下,所以成立这两索引 mkdir -p /www/a.com mkdir -p /www/b.com 在a.com与b.com里面创立测验文件index.html。为了差异在a.com里的index.html的内容是:

Apache

  1. 基本操作
解释 命令
安装 yum install httpd
启动 service httpd start
停止 service httpd stop
  1. 起步完结后

    • 查阅进程是或不是存在:ps -ef | grep httpd
    • 此刻在本机Win地址栏输入 192.168.2.1(也正是设想机ip),你会开掘访谈是败退
    • 下一场查看端口是不是监听:sudo netstat -anpl | grep 'http',此时端口也在监听,这为什么访问不成功吗?
    • 这时关闭防火墙,sudo service firewalld stop,然后再从新输入ip地址,你就能够映器重帘如图所示:
      澳门新濠3559 5
  2. 虚构主机配置

    • 进入:cd /etc/httpd/,然后到cd conf目录,打开vim httpd.conf文本,那是有的安顿文件,此时若权力缺乏记得提权

    • 在这几个布局文件中/virtual其一到重要字,配置三个虚构主机,就在那些上面写

      <VirtualHost *:80>
         ServerName www.imooc.test
         DocumentRoot /data/www
         <Directory "/data/www">
             Options Indexes FollowSymLinks
             AllowOverride None
             Require all granted
         </Directory>
      </VirtualHost>
      
    • 地方的DocumentRoot就是文本的根目录,因为子虚乌有,所以创建这么些目录sudo mkdir -p /data/www,到那么些www文件夹下,创制贰个index.html文件,随意写一些内容,保存退出,重启服务器,此时在本机Win地址栏出入ServerName,此时你会意识访谈不成功,为何吗,因为那么些域名是杜撰的,要开展配备,

    • 那Win中到那几个目录下c:WindowsSystem32Driversetc,找host文件,在最后增多就能够了,比如192.168.2.1 www.imooc.test,个中那个ip是虚构机的ip,那一个地方有个坑,详细的情况看这几个https://jingyan.baidu.com/article/624e7459b194f134e8ba5a8e.html
    • 若访问不成事,实践这么些命令sudo setenforce 0,这么些命令主要安装宽松情势
      澳门新濠3559 6

    • 若想计划三个设想主机,就把地点的从头到尾的经过复制数十次就能够了,要留心路线哟

    • 在那么些/etc/httpd目录下有三个logs目录,记录的日志,步向到这么些目录中,有七个公文,access_log、error_log,分别记录那访谈和万分的日记,展开tail -f error_log在此处您会看见部分错误的音信记录
  3. 伪静态操作

    • cd /etc/httpd/modules拜见到全体的模块的类

    • cd /etc/httpd/conf.modules.d,那个是模块的陈设

    • 接下来步入cd /etc/httpd/conf,打开vim httpd.conf文本,找到/LoadModule这么些主要字,

    • 在这些主要字上边增添LoadModule rewrite_module modules/mod_rewrite.so,

    • 此刻在配置设想主机的代码中增加,重启一下服务器,也等于说,只要访谈地址后缀名是.htmp,那么就转到index.html

      <VirtualHost *:80>
         ServerName www.imooc.test
         DocumentRoot /data/www
         <Directory "/data/www">
             Options Indexes FollowSymLinks
             AllowOverride None
             Require all granted
             # 添加一下代码
             <IfModule mod_rewrite.c>
                 RewriteEngine On
                 RewriteRule ^(.*).htmp$ index.html
             </IfModule>
         </Directory>
      </VirtualHost>
      

澳门新濠3559 7

(3)Nginx实现行反革命向代理

ii.编写翻译安装

将nginx-1.8.0.tar.gz拷贝至linux服务器。

 

解压:

tar -zxvf nginx-1.8.0.tar.gz

cd nginx-1.8.0

 

1、  configure

./configure --help查询详细参数(参考本教程附录部分:nginx编写翻译参数)

 

参数设置如下:

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

 

留意:上面将不时文件目录钦赐为/var/temp/nginx,要求在/var下开创temp及nginx目录

 

 

2、  编写翻译安装

make

makeinstall

 

设置成功查看安装目录 :

澳门新濠3559 8

 

 

b.com

澳门新濠3559 9 配置完结后重启apache、 访问192.168.109.41,如下图 澳门新濠3559 10
访问192.168.109.42,如下图 澳门新濠3559 11
大家在拜望下虚构机ip 192.168.109.40 澳门新濠3559 12
通过能够了然已经布置成功 2、基于端口的虚构主机配置格局。 还得先修改/etc/httpd/httpd.conf那些布局文件,如图所示: 澳门新濠3559 13
暗许监听端口号是80。大家配备基于端口8080的虚构主机 只须求上面加一行:Listen 8080就能够保存退出。 然后正是修改/etc/httpd/extra/httpd-vhosts.conf这几个文件。以ip地址为192.168.109.41为举例图所示: 澳门新濠3559 14   所以大家还得创制/www/c.com,这几个目录,具体做法参考此前的。 访谈192.168.109.41:80端口如下图所示 澳门新濠3559 15
访谈192.168.109.41:8080端口如下图所示 澳门新濠3559 16
通过能够精晓已经安插成功 2、基于域名的虚构主机配置形式 由于大家在地点配置未有DNS服务器,所以大家须要本身在地面分析,未来以ip为192.168.109.42为例 本地深入分析DNS的做法是:张开作者的管理器修改C:WindowsSystem32driversetc里的hosts文件 192.168.109.42 www.b.com 192.168.109.42 www.d.com 将这两行增加进去。然后在修改/etc/httpd/extra/httpd-vhosts.conf那一个文件如图所示澳门新濠3559 17 同理,还得创制/www/d.com这里不在描述。 访谈www.b.com,如下图所示 澳门新濠3559 18
拜见www.d.com,如下图所示 澳门新濠3559 19

Ubuntu Server 14.04 安装Web服务器(Linux Apache MySQL PHP) 

Linux下安装配置PHP意况(Apache2) 

Ubuntu 13.04 安装 LAMPVsftpdWebminphpMyAdmin 服务及安装

CentOS 5.9下编译安装LAMP(Apache 2.2.44 MySQL 5.6.10 PHP 5.4.12)

RedHat 5.4下Web服务器架设之源码营造LAMP情状及运用PHPWind

Apache 的详尽介绍:请点这里
Apache 的下载地址:请点这里

本文恒久更新链接地址:

本文采取的httpd版本依旧httpd-2.2.4。 访谈web服务,本质上看(从左券上)是拜望有些IP的主机上的某部端口(私下认可是8...

进入 sbin,  执行 ./nginx -s reload。

2.1.系统架构图

澳门新濠3559 20

 

a.com

澳门新濠3559 21 b.com里的index.html的剧情是:

3、反向代理,负载均衡。当网址的访谈量抵达自然水准后,单台服务器不可能满意客户的央求时,要求用多台服务器集群能够采用nginx做反向代理。况且多台服务器能够平分摊派负载,不会因为某台服务器负荷高宕机而某台服务器闲置的情形。

1.目标

1、系统架构领悟

2、互联网拓扑结构

3、精晓nginx tomcat反向代理的利用办法。

4、明白nginx作为负载均衡器的运用办法。

 

末段记得重新加载下nginx的铺排文件
澳门新濠3559 22

ix.需求

nginx对外提供80和8080四个端口监听服务。

伸手80端口则请求html80目录下的html

呼吁8080端口则呼吁html8080索引下的html

 

2、域名差别

xvii.配置虚构主机

修改/usr/local/nginx/conf/nginx.conf文件,增加三个虚构主机,如下:

#计划设想主机aaa.test.com

server {

                   #监听的ip和端口,配置本机ip和端口

listen 192.168.101.3:80;         

                   #虚构主机名称是aaa.test.com,诉求域名aaa.test.com的url将经过server配置分析

3、掌握nginx tomcat反向代理的使用方法,需要用多台服务器集群可以使用nginx做反向代理。server_name aaa.test.com;  

                   #享有的央浼都是/开始,全部的央浼都能够同盟此location

location / {

                   #应用root指令钦定设想主机目录即网页寄放目录

                   #比如说访谈

                   #例如访谈

                root /usr/local/aaa_html;       

                                #钦点接待页面,按从左到右顺序查找

                index index.html index.htm;   

}

    }

 

#铺排设想主机bbb.test.com

server {

listen 192.168.101.3:80;

server_name bbb.test.com;

location / {

                root /usr/local/bbb_html;

                index index.html index.htm;

}

    }

 

澳门新濠3559 23

4.nginx安装

贰个域名对应二个ip地址,三个ip地址能够被多少个域名绑定。

vii.配置虚构主机

修改/usr/local/nginx/conf/nginx.conf文件,增添五个设想主机,如下:

 

 

#user  nobody;

worker_processes  1;

 

events {

    worker_connections  1024;

}

 

http {

    include       mime.types;

    default_type  application/octet-stream;

 

    sendfile        on;

   

    keepalive_timeout  65;

    #配备设想主机192.168.101.3

    server {

         #监听的ip和端口,配置192.168.101.3:80

        listen       80;

         #虚构主机名称这里配置ip地址

        server_name  192.168.101.3;

         #怀有的乞求都是/先河,全体的呼吁都得以协作此location

        location / {

         #动用root指令内定设想主机目录即网页存放目录

         #诸如访问

         #比如说访问

 

            root/usr/local/nginx/html3;

         #点名应接页面,按从左到右顺序查找

            index  index.html index.htm;

        }

 

    }

    #安排设想主机192.168.101.103

    server {

        listen       80;

        server_name  192.168.101.103;

 

        location / {

            root   /usr/local/nginx/html103;

            index  index.html index.htm;

        }

 

    }

 

}

 

upstream tomcat2 {

i.nginx安装情状

         nginx是C语言开垦,建议在linux上运行,本课程使用Centos6.5作为安装境况。

n  gcc

         安装nginx需求先少将方网址下载的源码举办编写翻译,编写翻译依赖gcc蒙受,若无gcc意况,须要安装gcc:yum install gcc-c

n  PCRE

         PCRE(Perl Compatible Regular Expressions)是八个Perl库,满含 perl 宽容的正则表明式库。nginx的http模块使用pcre来深入分析正则表达式,所以必要在linux上设置pcre库。

yum install -y pcre pcre-devel

注:pcre-devel是利用pcre开垦的一个三遍开辟库。nginx也要求此库。

nzlib

         zlib库提供了比很多样减小和平解决压缩的章程,nginx使用zlib对http包的从头到尾的经过张开gzip,所以必要在linux上设置zlib库。

yum install -y zlib zlib-devel

 

nopenssl

         OpenSSL 是八个强有力的平安套接字层密码库,囊括首要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰硕的应用程序供测量检验或任何目标选择。

         nginx不独有辅助http公约,还帮忙https(即在ssl公约上传输http),所以须求在linux安装openssl库。

yum install -y openssl openssl-devel

 

修改window的hosts文件:(C:WindowsSystem32driversetc)

xiii.测试

开行nginx,查看端口监听状态:

澳门新濠3559 24

 

访问

澳门新濠3559 25

 

访问

澳门新濠3559 26

 

 

澳门新濠3559 27

 

正向代理:

xx.启动tomcat

         tomcat使用apache-tomcat-7.0.57版本,在192.168.101.5和192.168.101.6设想机上运转tomcat。

 

2、设想主机。能够达成在一台服务器设想出八个网站。举个例子个人网址选拔的设想主机。

4.6.装置测量检验

nginx安装成功,运转nginx,就能够访谈虚构机上的nginx:

澳门新濠3559 28

 

到那表明nginx基本上安装成功。

 

 

什么看头?简单来说,举例:www.4399.com 和 www.7k7k.com 都指向同一ip,都以访谈同一个Nginx服务器,Nginx依照分化的这一个域名访问分化的目录,也就对应分裂的能源,不一致的网址了。

xxiv.配置

基于上边的需求在nginx.conf文件中布局负载均衡,如下:

 

upstream tomcat_server_pool{

server 192.168.101.5:8080 weight=10;

server 192.168.101.6:8080 weight=10;

}

 

server {

listen 80;

server_name aaa.test.com;

location / {

                 proxy_pass ;

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

 

澳门新濠3559 29

xxiii.需求

         nginx作为负载均衡服务器,顾客诉求先到达nginx,再由nginx遵照负荷配置将呼吁转载至 tomcat服务器。

         nginx负载均衡服务器:192.168.101.3

         tomcat1服务器:192.168.101.5

         tomcat2服务器:192.168.101.6

 

澳门新濠3559 30

 

(2)使用

vi.绑定多ip

方法一:

采用标准的网络布局工具(举个例子ifconfig和route命令)加多lP别称:

 

此时此刻ip配置情况:

澳门新濠3559 31

 

在eth0网卡再绑定二个ip:192.168.101.103

 

/sbin/ifconfig eth0:1 192.168.101.103 broadcast 192.168.101.255 netmask 255.255.255.0 up

/sbin/route add -host 192.168.101.103 dev eth0:1

 

澳门新濠3559 32

 

方法二:

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

修改当中内容:

DEVICE=eth0:1

IPADDR=192.168.25.103

别的项不用修改

2、重启系统

当大家访谈 ,然后他却不是找 Nginx服务器里面的静态能源,而是反向给了对应的Tomcat服务器找对应的财富。

5.3.基于ip的设想主机配置

         Linux操作系统允许加多IP别名,IP外号正是在一块物理网卡上绑定八个lP地址。这样就能够在动用单一网卡的同三个服务器上运维四个基于IP的虚构主机。

 

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

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

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

xii.配置虚构主机

修改/usr/local/nginx/conf/nginx.conf文件,增加四个设想主机,如下:

 

 

#user  nobody;

worker_processes  1;

 

events {

    worker_connections  1024;

}

 

http {

    include       mime.types;

    default_type  application/octet-stream;

 

    sendfile        on;

   

    keepalive_timeout  65;

    #配备设想主机

    server {

         #监听的ip和端口,配置80

        listen       80;

         #设想主机名称这里配置ip地址

server_name  192.168.101.3;

         #有着的央求都是/初叶,全数的伏乞都得以协作此location

        location / {

         #动用root指令钦命设想主机目录即网页寄放目录

         #诸如访谈

         #比方说访谈

 

            root   /usr/local/nginx/html80;

         #点名迎接页面,按从左到右顺序查找

            index  index.html index.htm;

        }

 

    }

    #布署设想主机

    server {

        listen       8080;

server_name  192.168.101.3;

 

        location / {

            root   /usr/local/nginx/html8080;

            index  index.html index.htm;

        }

 

    }

 

}

 

聊到底 重新加载配置文件   推行   ./nginx -s reload。

5.4.基于端口的虚构主机

upstream tomcat1 {
    server 192.168.147.128:8080;
    }
    server {
        listen       80;
        server_name  www.4399.com;

        #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.147.128:8081;
    }
    server {
        listen       80;
        server_name  www.7k7k.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

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

5.5.基于域名的设想主机配置

server 192.168.147.128:8081;

7.负载均衡

一旦贰个劳务由多条服务器提供,供给把负载分配到区别的服务器管理,必要负载均衡。

iii.需求

一台nginx服务器绑定三个ip:192.168.101.3、192.168.101.103

拜见分化的ip供给例外的html目录,即:

访问

访问

 

其三步:反向代理服务器的配置 ( 加多如下的节点 )

xix.需求

         多个tomcat服务通过nginx反向代理,本例子使用三台虚构机进行测量试验,

         nginx服务器:192.168.101.3

         tomcat1服务器:192.168.101.5

         tomcat2服务器:192.168.101.6 

如下图:

 

澳门新濠3559 33

 

 

}

2.2.网络拓扑图

 

澳门新濠3559 34

 

澳门新濠3559 35

xxi.nginx反向代理配置

依照上边的需要在nginx.conf文件中配置反向代理,如下:

 

#配备二个代理即tomcat1服务器

upstream tomcat_server1 {

server 192.168.101.5:8080;

}

#布署二个代理即tomcat2服务器

upstream tomcat_server2 {

server 192.168.101.6:8080;

}

 

#计划一个虚构主机

server {

listen 80;

server_name aaa.test.com;

location / {

                                     #域名aaa.test.com的乞请全部转化到tomcat_server1即tomcat1服务上

                proxy_pass ;

                                     #迎接页面,根据从左到右的一一查找页面

                index index.jsp index.html index.htm;

}

 

    }

 

    server {

listen 80;

server_name bbb.test.com;

 

location / {

                                      #域名bbb.test.com的恳求全体倒车到tomcat_server2即tomcat2服务上

                  proxy_pass ;

                  index index.jsp index.html index.htm;

}

    }

 

澳门新濠3559 36

viii.测试

 

启航nginx,观看端口监听状态:

澳门新濠3559 37

 

澳门新濠3559,访问

澳门新濠3559 38

 

访问

澳门新濠3559 39

 

澳门新濠3559 40

6.nginx反向代理

如图所示:正向代理就好比 在局域网里的多台PC机上不停外网,但又要拜会外网,这一年PC机供给代理服务器,代理服务器将它们的乞求转载到网络,然后在将响应的剧情重临给种种PC机。

2.体系架构

    server {
        listen       81;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

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

xxv.测试

要求aaa.test.com,通过nginx负载均衡,将呼吁转发到tomcat服务器。

通过观看tomcat的走访日志或tomcat访问页面就能够见道当前恳请由哪些tomcat服务器受理。

 

澳门新濠3559 41

xvi.html目录创制

 

在192.168.101.3上创建/usr/local/aaa_html,此目录为aaa.test.com域名访谈的目录

在192.168.101.3上创建/usr/local/bbb_html,此目录为bbb.test.com域名访谈的目录

 

目录中的内容使用nginx自带的html文件,将/usr/local/nginx/html中的内容拷贝分别拷贝到上面五个目录中,何况将aaa_html目录中的index.html内容改为:“Welcome to aaa nginx!”

将bbb_html目录中的index.html内容改为“Welcome to bbb nginx!”

 

 

7.1.怎么样是负载均衡

         负载均衡创立在存活互连网布局如上,它提供了一种廉价有效透明的方式扩展互联网设施和服务器的带宽、扩展吞吐量、抓牢互联网数据管理工科夫、进步网络的狡滑和可用性。

         负载均衡,克罗地亚语名字为Load Balance,其意思正是分摊到八个操作单元上海展览中心开实施,举例Web服务器、FTP服务器、公司根本应用服务器和其余首要任务服务器等,进而共同实现工作任务。

(1)Nginx的介绍

v.html目录创制

将本来nginx的html目录拷贝七个目录 “html3”和“html103”,为了有协助测验须求修改各种目录下的index.html内容使之特性化。

cd /usr/local/nginx

cp -r html html3

cp -r html html103

澳门新濠3559 42

 

 

第五步:配置域名

4.3.启动nginx

cd /usr/local/nginx/sbin/

./nginx

 

查询nginx进程:

澳门新濠3559 43

 

15098是nginx主进度的进程id,15099是nginx职业进程的进度id

 

留心:实践./nginx运营nginx,这里能够-c钦定加载的nginx配置文件,如下:

./nginx -c /usr/local/nginx/conf/nginx.conf

一经不钦点-c,nginx在运转时暗中认可加载conf/nginx.conf文件,此文件的地点也能够在编译安装nginx时钦命./configure的参数(--conf-path= 指向配置文件(nginx.conf))

 

澳门新濠3559 44

4.5.重启nginx

办法1,先结束再开行(提议利用):

对nginx进行重启也正是先甘休nginx再开发银行nginx,即先推行甘休命令再实行运转命令。

如下:

./nginx -s quit

./nginx

 

艺术2,重新加载配置文件:

当nginx的安顿文件nginx.conf修改后,要想让配置生效要求重启nginx,使用-s reload不用先甘休nginx再开发银行nginx就可以将配备音讯在nginx中生效,如下:

./nginx -s reload

 

3. 反向代理。

6.1.什么样是反向代理

         日常的代理服务器,只用于代理内部网络对Internet的连年供给,顾客机必得钦点代理服务器,并将自然要直接发送到Web服务器上的http需要发送到代理服务器中由代理服务器向Internet上的web服务器发起呼吁,最后到达客商机上网的指标。

         而反向代理(Reverse Proxy)格局是指以代理服务器来经受internet上的连接央浼,然后将央浼转载给内部互连网上的服务器,并将从服务器上赢得的结果回到给internet上呼吁连接的客商端,此时期理服务器对外就展现为一个反向代理服务器。

 

如下图:

澳门新濠3559 45

 

 

1、端口不一致

6.2.nginx tomcat反向代理

多个域名指向同一台nginx服务器,顾客访谈差异的域名彰显不相同的网页内容。
五个域名是www.4399.com.cn和www.7k7k.com
nginx服务器使用设想机 192.168.147.128

xiv.需求

三个域名指向同一台nginx服务器,顾客访谈分歧的域名彰显分化的网页内容。

多个域名是aaa.test.com和bbb.test.com

nginx服务器使用虚构机192.168.101.3

 

澳门新濠3559 46

3.2.Nginx的行使场景

1、http服务器。Nginx是三个http服务能够独立提供http服务。能够做网页静态服务器。

2、虚构主机。能够完结在一台服务器设想出多个网址。比如个人网址选用的设想主机。

3、反向代理,负载均衡。当网址的访谈量到达一定水准后,单台服务器无法满意顾客的呼吁时,要求用多台服务器集群能够选择nginx做反向代理。况兼多台服务器能够平分摊派负载,不会因为某台服务器负荷高宕机而某台服务器闲置的状态。

 

率先步:安装八个tomcat,分别运营在8080和8081端口。

xv.筹算条件

创制192.168.101.3设想机,有限支撑本地Computer和编造网络通畅。

在192.168.101.3上安装nginx。

 

经过host文件钦赐aaa.test.com和bbb.test.com对应192.168.101.3虚构机:

修改window的hosts文件:(C:WindowsSystem32driversetc)

澳门新濠3559 47

 

在hosts文件中增多域名和ip的映照关系

3.nginx介绍

先是,修改本地host(能够运用SwitchHosts软件,直接改造,不用去C盘慢慢找Hosts):

xi.html目录成立

将原来nginx的html目录拷贝多个目录 “html80”和“html8080”,为了便利测量试验需求修改每一个目录下的index.html内容使之特性化。

参谋依靠ip或域名的虚构主机章节。

 

1、http服务器。Nginx是叁个http服务能够独自提供http服务。可以做网页静态服务器。

5.1.怎么着是设想主机

         设想主机是一种独特的软硬件才具,它能够将网络上的每一台Computer分成多少个虚拟主机,每种虚构主机能够单独对外提供www服务,那样就能够完毕一台主机对外提供三个web服务,每种虚构主机之间是单身的,互不影响的。

 

如下图:

 

澳门新濠3559 48

 

通过nginx能够达成虚构主机的安插,nginx援助二种档案的次序的虚构主机配置,1、基于ip的虚构主机, 2、基于域名的设想主机 3、基于端口的设想主机

澳门新濠3559 49

xviii.测试

访问aaa.test.com、bbb.test.com

 

 

 

??? 什么反向代理。既然有反向代理就有正向代理。

iv.计划条件

创建192.168.101.3设想机,有限支撑本地计算机和编造互联网通畅。

在192.168.101.3上安装nginx。

 

当地质度量试能够修改hosts文件。

7.2.nginx兑现负载均衡

只必要在nginx.conf文件加上多个server节点!退换下端口和访谈的根目录,注意若无此根目录要先创设,不然访谈不到。

x.盘算条件

创建192.168.101.3设想机,保险本地计算机和设想网络通畅。

在192.168.101.3上安装nginx。

 

在地方栏上输入如下你的服务器ip,那样我们只需求将大家要求的静态财富拖进html里面访问就足以了。

5.配置设想主机

能够看看 server那一个节点,暗中认可帮大家安插了端口80,访谈文件根目录 html, 这么些html正是大家设置Nginx里面包车型大巴五个文件夹

xxii.测试

独家修改多个tomcat下的webapps/ROOT/index.jsp的内容,使用tomcat1和tomcat2五个劳务首页突显不相同的开始和结果,如下:

tomcat1下的index.jsp修改后:

澳门新濠3559 50

 

tomcat2下的index.jsp修改后:

澳门新濠3559 51

 

 

各自探问aaa.test.com、bbb.test.com测量检验反向代理。

 

恳请访谈aaa.test.com通过nginx代理访谈tomcat1,央浼访谈bbb.test.com通过nginx代理访谈tomcat2。

 

 

能够配备域名和ip的照射关系,假如hosts文件中安插了域名和ip的照管关系,无需走dns服务器。

4.1.下载

 

进入 下载nginx1.8.0本子(当前风尚牢固版本)。

澳门新濠3559 52

 

澳门新濠3559 53

 

澳门新濠3559 54

4.2.安装

第一安装好Nginx,若是不懂怎么在Linux安装Nginx 可从前往本身的另一篇博文:  在Linux上安装Nginx

5.2.nginx布局文件的布局

nginx的配置文件结构如下:

 

......

events {

    .......

}

http{

.......

server{

         .......

         }

server{

         .......

         }

 

}

种种server就是三个虚构主机。

 

反向代理:澳门新濠3559 55

3.1.什么是nginx

         Nginx是一款高品质的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗丝的次第设计员伊戈尔 Sysoev所开垦,官方测量试验nginx能够支支撑5万并发链接,况兼cpu、内部存款和储蓄器等能源消耗而不是常的低,运行特别安静。

粗略来讲Nginx便是一个高质量的http/反向代理 服务器及电子邮件(IMAP/POP3)代理服务器。官方测量试验Nginx可以辅助5万并发乞求,况兼cpu,内部存款和储蓄器等财富消耗相当的低,运维特别平稳,那正是本国百度,Tmall,腾讯,博客园等各大网络集团用它的首要性缘由。     

 

澳门新濠3559 56

其一文件便是Nginx 的为主配置文件,张开采现其间

在您安装的nginx目录下的conf 目录下的nginx.conf澳门新濠3559 57

1)通过端口分化界别差别设想机:

澳门新濠3559 58

 upstream tomcat2 {
    server 192.168.147.128:8081;
    server 192.168.147.128:8082 weight=2;
 }

2)域名差别配置虚构主机

运用场景

第二步:运转几个tomcat。

澳门新濠3559 59

怎么样区分不相同的网址?

注意:

(4)负载均衡

澳门新濠3559 60

server 192.168.147.128:8082;

2. 虚构主机,也正是说一台服务器能够运转八个网址!

澳门新濠3559 61

澳门新濠3559 62

能够依靠服务器的实在景况调度服务器权重。权重越高分红的呼吁越多,权重越低,伏乞越少。私下认可是都以1

澳门新濠3559 63

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

然后配置 nginx.conf ,增多八个server节点

如图所示:互连网产生贰个央浼,然后那些代理服务器,将呼吁转发给了别的的服务器。而这么些代理服务器就是Nginx,举个例子大家有一台服务器 192.168.1.100,运维了Nginx

1, 当作http服务器使用,也正是说大家由此  ,能够访谈到内部的财富,注意是静态的能源,jsp,php这些是走访不到的,端口默许80。

编辑:操作系统 本文来源:3、掌握nginx tomcat反向代理的使用方法,需要用多

关键词: 澳门新濠3559