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地址,你就会映入眼帘如图所示:
      澳门金沙国际 1
  2. 虚拟主机配置

    • 进入:cd /etc/httpd/,然后到cd conf目录,打开vim httpd.conf文件,这是有的布署文件,此时若权力不够记得提权

    • 在这些布局文件中/virtual本条到关键字,配置2个虚拟主机,就在这么些上边写

      <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:\Windows\System32\Drivers\etc,找host文件,在最终添加就足以了,例如192.168.2.1 www.imooc.test,在那之中那个ip是虚拟机的ip,那个地点有个坑,详情看这么些https://jingyan.baidu.com/article/624e7459b194f134e8ba5a8e.html
    • 若访问不成事,执行这些命令sudo setenforce 0,那一个命令主要安装宽松情势
      澳门金沙国际 2

    • 若想布署两个虚拟主机,就把上边的始末复制多次就足以了,要专注路径哟

    • 在那一个/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>
      

澳门金沙国际 3

(1)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那样准备工作就达成了,上边分别设置虚拟主机的三种艺术。
① 、基于IP的虚拟主机配置方式。 大家得以在eth0上绑定八个ip地址。能够用ip
addr add ip地址 dev
eth0绑定ip。在那边我们绑定192.168.109.41与192.168.109.42那四个ip地址。
用ip addr show能够查阅绑定完的音讯,如下图所示
澳门金沙国际 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的剧情是:

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),就相会到欢迎界面
      澳门金沙国际 5
  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;
    }
    
    • 若想布署八个虚拟主机,重复下边包车型地铁操作就能够了,再复制一份,要注意路径,
    • 若3个虚拟主机想多端口访问间接多写多个listen,也许多域名,就在这些域名前边多写二个就足以了,要小心格式,因为此处的域名是编造的,所以还的在host里添加,和方面一样

    server{
        listen  80;
        listen  9999;
        server_name  www.imooc.test www.imooc2.test;
        root /data/www;
        index  index.html  index.htm;
    }
    

    澳门金沙国际 6

  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
    • 自定义格式,只须要:
    • 澳门金沙国际 7

    • 也足以在虚拟主机中钦赐日志的职责,那样方便管理,记得从重载服务器

    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;
          }   
      }   
      
    • Nginx功用简介与主干配备总结,WebServer安装和配置。重载服务器,访问www.imooc.test本条网址,实际上就会造访到www.54php.cn,此时前者就是作为2个代理

  6. 负载均衡

    • 若那些时候,再imooc_hosts里添加一条网址,那么在首先次访问www.imooc.test这么些网址,就到到第②条对应的网址,第一造访,就回去第①条对应的网址,第一回照旧首先条对应的网址,……

    • 若不想那样循环,想让八个服务器访问的次数多一些,那么,在前边添加1个关键字就能够了,如下,那样第②个网址被访问的次数正是第二个网址的五倍

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

1.目标

① 、系统架构通晓

贰 、网络拓扑结构

③ 、明白nginx+tomcat反向代理的施用方法。

四 、领会nginx作为负载均衡器的使用办法。

 

a.com

澳门金沙国际 8 b.com里的index.html的始末是:

大致的话Nginx便是三个高质量的http/反向代理
服务器及电子邮件(IMAP/POP3)代理服务器。官方测试Nginx可以辅助5万并发请求,并且cpu,内部存款和储蓄器等财富消耗非常低,运转很是安静,那就是国内百度,Taobao,腾讯,今日头条等各大网络公司用它的重点原因。     

2.系统架构

b.com

澳门金沙国际 9
配置达成后重启apache、 访问192.168.109.41,如下图
澳门金沙国际 10
访问192.168.109.42,如下图 澳门金沙国际 11
小编们在造访下虚拟机ip 192.168.109.40
澳门金沙国际 12
经过能够知道已经配备成功
② 、基于端口的虚拟主机配置格局。 还得先修改/etc/httpd/httpd.conf那一个布局文件,如图所示:
澳门金沙国际 13
暗中同意监听端口号是80。我们配备基于端口8080的虚拟主机 只要求上边加一行:Listen
8080即可保存退出。 然后正是修改/etc/httpd/extra/httpd-vhosts.conf那些文件。以ip地址为192.168.109.41为例
如图所示: 澳门金沙国际 14
  所以大家还得创制/www/c.com,那些目录,具体做法参考在此之前的。
访问192.168.109.41:80端口如下图所示
澳门金沙国际 15
走访192.168.109.41:8080端口如下图所示
澳门金沙国际 16
透过能够领略已经安插成功
二 、基于域名的虚拟主机配置格局 由于大家在地点配置没有DNS服务器,所以大家须要自个儿在地头解析,未来以ip为192.168.109.42为例
本地解析DNS的做法是:打开自个儿的计算机械修理改C:\Windows\System32\drivers\etc里的hosts文件
192.168.109.42 www.b.com 192.168.109.42 www.d.com
将那两行添加进去。然后在修改/etc/httpd/extra/httpd-vhosts.conf那些文件如图所示澳门金沙国际 17
同理,还得创设/www/d.com那里不在描述。 访问www.b.com,如下图所示
澳门金沙国际 18
做客www.d.com,如下图所示
澳门金沙国际 19

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

Linux下安装配置PHP环境(Apache2) 

Ubuntu 13.04 安装 LAMP\Vsftpd\Webmin\phpMyAdmin 服务及安装

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…

行使场景

2.1.系统架构图

澳门金沙国际 20

 

① 、http服务器。Nginx是八个http服务可以单独提供http服务。能够做网页静态服务器。

2.2.互联网拓扑图

 

澳门金沙国际 21

 

贰 、虚拟主机。可以兑今后一台服务器虚拟出四个网站。例如个人网站接纳的虚拟主机。

3.nginx介绍

③ 、反向代理,负载均衡。当网站的访问量达到一定水平后,单台服务器不能够满意用户的伸手时,必要用多台服务器集群能够应用nginx做反向代理。并且多台服务器可以平分摊派负载,不会因为某台服务器负荷高宕机而某台服务器闲置的情况。

3.1.什么是nginx

         Nginx是一款高品质的http
服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗丝的顺序设计师Igor Sysoev所付出,官方测试nginx能够支支撑5万并发链接,并且cpu、内部存款和储蓄器等能源消耗却非常低,运行卓殊安静。

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

3.2.Nginx的选拔场景

壹 、http服务器。Nginx是3个http服务能够单独提供http服务。能够做网页静态服务器。

贰 、虚拟主机。能够兑以往一台服务器虚拟出三个网站。例如个人网站选取的虚拟主机。

叁 、反向代理,负载均衡。当网站的访问量达到一定水准后,单台服务器不能够满足用户的请求时,必要用多台服务器集群能够应用nginx做反向代理。并且多台服务器能够平分摊派负载,不会因为某台服务器负荷高宕机而某台服务器闲置的意况。

 

(2)使用

4.nginx安装

4.1.下载

 

进入 下载nginx1.8.0本子(当前风靡稳定版本)。

澳门金沙国际 22

 

澳门金沙国际 23

 

1,
当做http服务器使用,也便是说大家因此
 ,能够访问到内部的财富,注意是静态的财富,jsp,php那几个是造访不到的,端口私下认可80。

4.2.安装

在你安装的nginx目录下的conf
目录下的nginx.conf澳门金沙国际 24

i.nginx安装环境

         nginx是C语言开发,建议在linux上运维,本学科使用Centos6.5作为安装环境。


gcc

         安装nginx供给先元帅网下载的源码进行编写翻译,编写翻译注重gcc环境,倘使没有gcc环境,须求安装gcc:yum install gcc-c++


PCRE

         PCRE(Perl Compatible Regular
Expressions)是3个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

 

澳门金沙国际 25

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

 

 

② 、 
编写翻译安装

make

makeinstall

 

安装成功查看安装目录 :

澳门金沙国际 26

 

 

其一文件便是Nginx
的中坚配置文件,打开发现其间

4.3.启动nginx

cd /usr/local/nginx/sbin/

./nginx

 

查询nginx进程:

澳门金沙国际 27

 

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

 

#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进度处理职责达成举办停止。

 

 

能够看看
server那一个节点,暗许帮大家配备了端口80,访问文件根目录 html,
那一个html就是大家设置Nginx里面包车型客车一个文书夹

4.5.重启nginx

方法1,先甘休再起步(提议利用):

对nginx进行重启相当于先结束nginx再起步nginx,即先实施截止命令再履行运营命令。

如下:

./nginx -s quit

./nginx

 

主意2,重新加载配置文件:

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

./nginx -s reload

 

澳门金沙国际 28

4.6.设置测试

nginx安装成功,运营nginx,即可访问虚拟机上的nginx:

澳门金沙国际 29

 

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

 

 

澳门金沙国际 30

5.安插虚拟主机

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

5.1.什么样是虚拟主机

         虚拟主机是一种独特的软硬件技术,它能够将网络上的每一台电脑分成四个虚拟主机,各样虚拟主机可以单独对外提供www服务,那样就能够实现一台主机对外提供八个web服务,各类虚拟主机之间是独自的,互不影响的。

 

如下图:

 

澳门金沙国际 31

 

通过nginx能够兑现虚拟主机的配置,nginx扶助三种类型的虚拟主机配置,壹 、基于ip的虚拟主机,
二 、基于域名的虚拟主机 ③ 、基于端口的虚拟主机

澳门金沙国际 32

5.2.nginx布署文件的组织

nginx的配备文件结构如下:

 

……

events {

    …….

}

http{

…….

server{

         …….

         }

server{

         …….

         }

 

}

各类server便是二个虚拟主机。

 

澳门金沙国际 33

5.3.基于ip的虚拟主机配置

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

 

2.
虚拟主机,也等于说一台服务器能够运维四个网站!

iii.需求

一台nginx服务器绑定八个ip:192.168.101.三 、192.168.101.103

走访分歧的ip请求例外的html目录,即:

访问

访问

 

如何区分差别的网站?

iv.准备条件

始建192.168.101.3虚拟机,保险本地电脑和编造互连网通畅。

在192.168.101.3上安装nginx。

 

壹 、端口差别

v.html目录成立

将原先nginx的html目录拷贝多个目录 “html3”和“html103”,为了方便测试须求修改每一种目录下的index.html内容使之本性化。

cd /usr/local/nginx

cp -r html html3

cp -r html html103

澳门金沙国际 34

 

 

二 、域名分裂

vi.绑定多ip

方法一:

动用正式的互连网布局工具(比如ifconfig和route命令)添加lP别称:

 

眼下ip配置情状:

澳门金沙国际 35

 

在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

 

澳门金沙国际 36

 

方法二:

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

修改个中内容:

DEVICE=eth0:1

IPADDR=192.168.25.103

其余项不用修改

② 、重启系统

1)通过端口差别组别不相同虚拟机:

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;

        }

 

    }

 

}

 

    server {
        listen       81;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

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

viii.测试

 

启航nginx,阅览端口监听状态:

澳门金沙国际 37

 

访问

澳门金沙国际 38

 

访问

澳门金沙国际 39

 

只要求在nginx.conf文件加上二个server节点!更换下端口和做客的根目录,注意若是没有此根目录要先创立,不然访问不到。

5.4.基于端口的虚拟主机

末尾记得重新加载下nginx的布署文件
澳门金沙国际 40

ix.需求

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

请求80端口则请求html80索引下的html

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

 

澳门金沙国际 41

x.准备条件

创建192.168.101.3虚拟机,保证本地电脑和编造互联网通畅。

在192.168.101.3上安装nginx。

 

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

xi.html目录创立

将原来nginx的html目录拷贝五个目录 “html80”和“html8080”,为了便于测试须要修改每种目录下的index.html内容使之特性化。

参照依据ip或域名的虚拟主机章节。

 

澳门金沙国际 42

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;

        }

 

    }

 

}

 

澳门金沙国际 43

xiii.测试

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

澳门金沙国际 44

 

访问

澳门金沙国际 45

 

访问

澳门金沙国际 46

 

 

2)域名分歧配置虚拟主机

5.5.基于域名的虚拟主机配置

何以看头?不难的话,比如:www.4399.com
和 www.7k7k.com
都指向同一ip,都以造访同三个Nginx服务器,Nginx依照分化的那个域名访问区别的目录,也就对应分裂的能源,分化的网站了。

xiv.需求

四个域名指向同一台nginx服务器,用户访问分裂的域名展现不相同的网页内容。

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

nginx服务器使用虚拟机192.168.101.3

 

注意:

xv.准备条件

成立192.168.101.3虚拟机,保障本地电脑和编造互联网通畅。

在192.168.101.3上安装nginx。

 

透过host文件钦定aaa.test.com和bbb.test.com对应192.168.101.3虚拟机:

修改window的hosts文件:(C:\Windows\System32\drivers\etc)

澳门金沙国际 47

 

三个域名对应二个ip地址,二个ip地址可以被四个域名绑定。

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

 

 

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

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配置分析

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;

}

    }

 

修改window的hosts文件:(C:\Windows\System32\drivers\etc)

xviii.测试

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

 

 

 

能够安顿域名和ip的映射关系,假设hosts文件中安排了域名和ip的对应关系,不需求走dns服务器。

6.nginx反向代理

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

6.1.怎么着是反向代理

         平时的代理服务器,只用于代理内部网络对Internet的连年请求,客户机必须钦点代理服务器,并将本来要平素发送到Web服务器上的http请求发送到代理服务器中由代理服务器向Internet上的web服务器发起呼吁,最后达到客户机上网的指标。

         而反向代理(Reverse
Proxy)格局是指以代理服务器来接受internet上的一而再请求,然后将呼吁转载给内部互连网上的服务器,并将从服务器上取得的结果重返给internet上呼吁连接的客户端,此时期理服务器对外就表现为3个反向代理服务器。

 

如下图:

澳门金沙国际 48

 

 

澳门金沙国际 49

6.2.nginx+tomcat反向代理

澳门金沙国际 50

xix.需求

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

         nginx服务器:192.168.101.3

         tomcat1服务器:192.168.101.5

         tomcat2服务器:192.168.101.6 

如下图:

 

澳门金沙国际 51

 

 

然后配置
nginx.conf ,添加二个server节点

xx.启动tomcat

         tomcat使用apache-tomcat-7.0.57版本,在192.168.101.5和192.168.101.6虚拟机上运维tomcat。

 

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

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;

}

    }

 

最终 重新加载配置文件   执行   ./nginx -s
reload。

xxii.测试

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

tomcat1下的index.jsp修改后:

澳门金沙国际 52

 

tomcat2下的index.jsp修改后:

澳门金沙国际 53

 

 

独家庭访问问aaa.test.com、bbb.test.com测试反向代理。

 

恳请访问aaa.test.com通过nginx代理访问tomcat1,请求访问bbb.test.com通过nginx代理访问tomcat2。

 

 

澳门金沙国际 54

7.负载均衡

澳门金沙国际 55

7.1.什么是负载均衡

         负载均衡建立在现有互联网布局如上,它提供了一种廉价有效透明的方法扩大网络设施和服务器的带宽、增添吞吐量、抓好网络数据处理能力、升高网络的油滑和可用性。

         负载均衡,英文名称为Load Balance,其意思就是分派到四个操作单元上实行实施,例如Web服务器、FTP服务器、集团根本应用服务器和其它首要职责服务器等,从而共同完毕工作职务。

3.
反向代理。

7.2.nginx落实负载均衡

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

xxiii.需求

         nginx作为负载均衡服务器,用户请求先抵达nginx,再由nginx依据负荷配置将呼吁转载至 tomcat服务器。

         nginx负载均衡服务器:192.168.101.3

         tomcat1服务器:192.168.101.5

         tomcat2服务器:192.168.101.6

 

澳门金沙国际 56

 

正向代理:

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

 

澳门金沙国际 57

xxv.测试

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

通过观看tomcat的访问日志或tomcat访问页面即可见道当前呼吁由哪些tomcat服务器受理。

 

澳门金沙国际 58

澳门金沙国际 59

如图所示:正向代理就好比
在局域网里的多台PC机上持续外网,但又要拜访外网,那一个时候PC机请求代理服务器,代理服务器将它们的乞请转发到网络,然后在将响应的剧情重临给各种PC机。

反向代理:澳门金沙国际 60

澳门金沙国际 61

澳门金沙国际 62

如图所示:互连网发生叁个呼吁,然后这么些代理服务器,将请求转载给了其他的服务器。而以此代理服务器正是Nginx,比如大家有一台服务器
192.168.1.100,运转了Nginx

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

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

三个域名指向同一台nginx服务器,用户访问不一样的域名突显不一致的网页内容。
五个域名是www.4399.com.cn和www.7k7k.com
nginx服务器使用虚拟机 192.168.147.128

澳门金沙国际 63

第②步:安装八个tomcat,分别运转在8080和8081端口。

其次步:运营七个tomcat。

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

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

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

第四步:配置域名

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

(4)负载均衡

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

upstream tomcat2 {

server
192.168.147.128:8081;

server
192.168.147.128:8082;

}

 

能够依照服务器的实在情状调整服务器权重。权重越高分红的伸手更加多,权重越低,请求越少。私下认可是都是1

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

相关文章