***********************
修改apache默认的网页文件存放位置
]# mkdir /var/www/myweb
]# echo "I am MyWeb" > /var/www/myweb/index.html
]# vim /etc/httpd/conf/httpd.conf
DocumentRoot  "/var/www/myweb"
]# systemctl restart httpd
]# firefox 172.25.0.11
***********************
  作用:一台服务器可以提供多个Web站点
  一旦使用虚拟web主机功能,所有的站点都必须用虚拟web主机来实现

• 区分方式
– 基于域名的虚拟主机
– 基于端口的虚拟主机
– 基于IP地址的虚拟主机

• 为每个虚拟站点添加配置
  ServerName 此站点的DNS名称
  DocumentRoot 此站点的网页根目录

• 配置文件路径
– /etc/httpd/conf/httpd.conf  (主配置文件)
– /etc/httpd/conf.d/*.conf (调用配置文件)

目标
webapp0.example.com -> 企鹅
www0.example.com   
-> MyWeb
server0.example.com -> 百度

虚拟机Server0:
1.创建配置文件:
]# vim /etc/httpd/conf.d/nsd01.conf
<.VirtualHost  *:80>
    ServerName
webapp0.example.com
    DocumentRoot
/var/www/qq
<./VirtualHost>

<.VirtualHost  *:80>
    ServerName
www0.example.com
    DocumentRoot
/var/www/myweb
<./VirtualHost>

<.VirtualHost  *:80>
    ServerName
server0.example.com
    DocumentRoot
/var/www/baidu
<./VirtualHost>

可以添加访问规则:
<.Directory  "/webroot">
    Require all
granted
<./Directory>

<.Directory  "/webroot/private">
    Require ip
127.0.0.1  ::1  172.25.0.11
<./Directory>
2.创建对应网页文件夹
]# mkdir /var/www/qq  /var/www/baidu
/var/www/myweb
]# echo '企鹅' > /var/www/qq/index.html
]# echo '百度' > /var/www/baidu/index.html
]# echo 'MyWeb' > /var/www/qq/index.html
]# systemctl restart httpd
3.访问:
]# firefox www0.example.com
]# firefox webapp0.example.com
]# firefox server0.example.com

************************

访问控制:
只允许172.25.0.11访问server0.example.com站点的/var/www/myweb/private目录的网页

<.VirtualHost  *:80>
    ServerName
www0.example.com
    DocumentRoot
/var/www/myweb
<./VirtualHost>

]# mkdir /var/www/myweb/private
]# echo "I am private" > /var/www/myweb/private/index.html
]# vim /etc/httpd/conf.d/nsd01.conf
增加这段:
<.Directory  "/webroot/private">
    Require ip
127.0.0.1  ::1  172.25.0.11
<./Directory>
]# systemctl restart httpd

不同主机访问测试:
]# firefox server0.example.com/private

**************************

自定Web根目录
调整 Web 站点 http://server0.example.com 的网页
目录,要求如下: /webroot,作为此站点新的网页文件目录
]# mkdir /webroot
]# echo 'wo shi webroot' > /webroot/index.html
]# vim /etc/httpd/conf.d/nsd01.conf
...
<.VirtualHost  *:80>
    ServerName
server0.example.com
   
DocumentRoot  /webroot
<./VirtualHost>
...
]# systemctl restart httpd

SELinux的安全上下文(标签)
]# ls -Zd /var/www/  #查看安全上下文值
]# ls -Zd /webroot
]# chcon -R --reference=/var/www /webroot/
]# ls -Zd /webroot/
]# firefox server0.example.com #验证
**************************
部署动态网站

LAMP:Linux  Apache  MariaDB/MySQL
php/Python
    
LNMP:Linux  Nginx  MariaDB/MySQL
php/Python

静态网站的运行
• 服务端的原始网页 = 浏览器访问到的网页
– 由Web服务软件处理所有请求
– 文本(txt/html)、图片(jpg/png)等静态资源

动态网站的运行
• 服务端的原始网页 ≠ 浏览器访问到的网页
– 由Web服务软件接受请求,动态程序转后端模块处理
– PHP网页、Python网页、JSP网页......

为站点 webapp0.example.com 配置提供动态Web内容:
<.VirtualHost  *:80>
    ServerName
server0.example.com
    DocumentRoot
/var/www/baidu
<./VirtualHost>

1.下载动态页面到指定目录:
/var/www/baidu/webinfo.wsgi
]# ls
index.html  webinfo.wsgi
2.修改配置文件
]# vim /etc/httpd/conf.d/nsd01.conf
<.VirtualHost *:80>
    
ServerName webapp0.example.com
    
DocumentRoot /var/www/baidu
    
Alias /  /var/www/baidu/webinfo.wsgi
<./VirtualHost>
当用户访问到网页文件根目录时,进行跳转到webinfo.wsgi
3.重启查看:
]# systemctl restart httpd
]# firefox webapp0.example.com(看到的是源码)
4.安装mod_wsgi软件,专用于Python页面代码翻译
]# yum -y install mod_wsgi
5.修改配置文件
]# vim /etc/httpd/conf.d/nsd01.conf
<.VirtualHost *:80>
    
ServerName webapp0.example.com
    
DocumentRoot /var/www/baidu
    
WSGIScriptAlias / 
/var/www/baidu/webinfo.wsgi
<./VirtualHost>
]# systemctl restart httpd
]# firefox webapp0.example.com
6.此虚拟主机侦听在端口8909
Listen 8909
<.VirtualHost *:8909>
    
ServerName webapp0.example.com
    
DocumentRoot /var/www/baidu
    
WSGIScriptAlias / 
/var/www/baidu/webinfo.wsgi
<./VirtualHost>
SELinux非默认端口的开放:
]# semanage port -l | grep http 
#查看http允许开放端口(有8909)
]# semanage port -a -t http_port_t -p tcp 8909
  
-a:添加  
-t:类型   -p:协议
]# systemctl restart httpd
7.验证
]# firefox webapp0.example.com:8909
********************************

十二.虚拟Web主机的更多相关文章

  1. Apache的权限设置与构建虚拟web主机

    实验拓扑图: 实验要求: 1.  搭建WEB服务器,能访问默认站点,并使用awstats软件能监控到默认站点的访问情况. 2.  修改Apache的主配置文件,设置1.10只能访问awstats网站, ...

  2. 工程师技术(三):独立Web站点的快速部署、虚拟Web主机的部署、配置网页内容访问、使用自定Web根目录、配置安全Web服务、部署并测试WSGI站点

    一.独立Web站点的快速部署 目标: 本例要求为 http://server0.example.com 配置Web站点,要求如下: 1> 从http://classroom/pub/materi ...

  3. Apache虚拟web主机构建

    目录 一.构建虚拟web主机 1.1.虚拟web主机概述 二.搭建虚拟web主机步骤 2.1.基于域名搭建虚拟主机 ①为虚拟主机提供域名解析 ②为虚拟主机准备网页文档 ③添加虚拟主机配置 ④设置访问路 ...

  4. (3)虚拟Web主机

    虚拟Web主机 作用:让一台Web服务器,提供多个页面 搭建方式: 1.基于域名的虚拟Web 2.基于端口的虚拟Web 3.基于IP地址的虚拟Web ######################### ...

  5. odoo10学习笔记十二:web controller

    转载请注明原文地址:https://www.cnblogs.com/ygj0930/p/11189332.html 一:路由 odoo.http.route(route=None, **kw) 装饰器 ...

  6. (十二) web服务与javaweb结合(3)

    一.需求 上一章节虽然将webservice和web项目绑定在了一起,但是还是不能共同一个端口,本章讲解webservice和web项目绑定且共同端口. 二.案例 2.1 创建web工程,并引入依赖 ...

  7. 第十二章 WEB渗透

    Web技术发展 • 静态WEB• 动态WEB • 应用程序 • 数据库 • 每个人看到的内容不同 • 根据用户输入返回不同结果 WEB攻击面• Network• OS• WEB Server• App ...

  8. 创建dynamics CRM client-side (十二) - HTML Web Resource

    HTML Web Resource是我们经常使用的一个功能. 第一步, 我们先创建好一个HTML. 接下来,我们要在web resource中创建新的html web resource. 我们在tex ...

  9. 三十二:WEB漏洞-文件操作之文件下载读取全解

    文件下载读取 原路,检测,利用,修复 利用 数据库配置文件下载或者读取后续 接口密钥信息文件下载或者读取后续 文件名,参数值,目录符号 read.xxx?filename= down.xxx?file ...

随机推荐

  1. python学习-54 正则表达式2

    re模块 之分组 >>> import re >>> re.findall("ab|c","sdfab|csdf") ['a ...

  2. Win自带mastc远程Cenots7桌面

    1.Centos7安装桌面 yum -y groups install "GNOME Desktop" startx 2.安装xrdp 操作需要root用户权限,所以,我们先切换为 ...

  3. 原生 js 录屏功能

    <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8& ...

  4. DNS 解析

    DNS即为Domain Name System的缩写形式,就是所谓的域名系统,它是互联网的一项服务.它作为将域名和IP地址相互映射的一个分布式数据库,能够使人更方便地访问互联网. 如果想访问某个网站( ...

  5. 求亲篇:数据库操作,SqlHelper,增删改查

    1.利用SqlHelper类 2.简单的数据绑定输出 string strSql = "select * from login"; DataTable dt = SqlHelper ...

  6. Consul 注册中心介绍

    在 Spring Cloud 体系中,几乎每个角色都会有两个以上的产品提供选择,比如在注册中心有:Eureka.Consul.zookeeper.etcd 等:网关的产品有 Zuul.Spring C ...

  7. 关于 false sharing

    问题来源 在多线程操作中,每个线程对操作对象都会有单独的缓存,最后将缓存同步到内存上,不加锁的话会导致数据缺乏同步出现错误,如果只是简单地加锁,性能就会飞速下降 解法 spacing &&am ...

  8. 微信小程序通讯录字母排序

    微信小程序通讯录 字母排序效果: demo地址:https://github.com/PeachCoder/wechat-contacts

  9. ElementUI+命名视图实现复杂顶部和左侧导航栏

    在了解了命名视图的用途后,发现用命名视图来实现复杂导航更加省力.更多知识请参考这里 这里只说明重要配置内容,其他内容配置请参考上一篇初始版本: ElementUI 复杂顶部和左侧导航栏实现 或参考文末 ...

  10. axiso 的使用

    Vue官方推荐的ajax请求框架叫做:axios axios的Get请求语法: axios.get("/item/category/list?pid=0") // 请求路径和请求参 ...