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这个到关键字,配置一个虚拟主机,就在这个下面写

      <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,这个命令主要设置宽松模式
      图片 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的介绍

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),就会看到欢迎界面
      图片 4
  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;
    }
    

    图片 5

  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
    • 自定义格式,只需要:
    • 图片 6

    • 也可以在虚拟主机中指定日志的位置,这样方便管理,记得从重载服务器

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

简单来说Nginx就是一个高性能的http/反向代理
服务器及电子邮件(IMAP/POP3)代理服务器。官方测试Nginx能够支撑5万并发请求,并且cpu,内存等资源消耗非常低,运行非常稳定,这就是国内百度,淘宝,腾讯,网易等各大互联网公司用它的主要原因。     

应用场景

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

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

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

首先安装好Nginx,如果不懂怎么在Linux安装Nginx
可以前往我的另一篇博文:
 在Linux上安装Nginx

(2)使用

1,
当做http服务器使用,也就是说我们通过
 ,可以访问到里面的资源,注意是静态的资源,jsp,php那些是访问不到的,端口默认80。

在你安装的nginx目录下的conf
目录下的nginx.conf图片 7

图片 8

这个文件就是Nginx
的核心配置文件,打开发现里面

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

}

可以看到
server这个节点,默认帮我们配置了端口80,访问文件根目录 html,
这个html就是我们安装Nginx里面的一个文件夹

图片 9

图片 10

在地址栏上输入如下你的服务器ip,这样我们只需要将我们需要的静态资源拖进html里面访问就可以了。

图片 11

图片 12

2.
虚拟主机,也就是说一台服务器可以启动多个网站!

如何区别不同的网站?

1、端口不同

2、域名不同

1)通过端口不同区分不同虚拟机:

    server {
        listen       81;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

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

只需要在nginx.conf文件加上一个
server节点!更换下端口和访问的根目录,注意如果没有此根目录要先创建,不然访问不到。

最后记得重新加载下nginx的配置文件
图片 13

图片 14

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

图片 15

图片 16

2)域名不同配置虚拟主机

什么意思?简单来说,比如:www.4399.com
和 www.7k7k.com
都指向同一ip,都是访问同一个Nginx服务器,Nginx根据不同的这些域名访问不同的目录,也就对应不同的资源,不同的网站了。

注意:

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

本地测试可以修改hosts文件。

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

可以配置域名和ip的映射关系,如果hosts文件中配置了域名和ip的对应关系,不需要走dns服务器。

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

图片 17

图片 18

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

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

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

图片 19

图片 20

3.
反向代理。

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

正向代理:

图片 21

图片 22

图片 23

如图所示:正向代理就好比
在局域网里的多台PC机上不了外网,但又要访问外网,这个时候PC机请求代理服务器,代理服务器将它们的请求转发到互联网,然后在将响应的内容返回给各个PC机。

反向代理:图片 24

图片 25

图片 26

如图所示:互联网发出一个请求,然后这个代理服务器,将请求转发给了其他的服务器。而这个代理服务器就是Nginx,比如我们有一台服务器
192.168.1.100,启动了Nginx

当我们访问
,然后他却不是找
Nginx服务器里面的静态资源,而是反向给了对应的Tomcat服务器找对应的资源。

(3)Nginx实现反向代理

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

图片 27

第一步:安装两个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;
 }