Apache服务器之------虚拟主机多功能配置

简介:

Apache虚拟主机的几种基本配置

虚拟主机是服务器采用的节省服务器硬件成本的技术,虚拟主机技术主要应用于HTTP、FTP、邮件等多种服务。将一台服务器的某项或者全部服务内容逻辑划分为多个服务单位,对外展现为一个服务器,从而充分利用服务器硬件资源。如果划分是系统级别,则成为虚拟服务器。

一、虚拟主机具有三种建立模式:
1、基于IP地址
2、基于端口
3、基于FQDN


好,废话不多说,直接上例子:
1、基于IP
如果希望使用172.16.4.1可以访问到/www/htdocs目录的内容,使用172.16.4.2可以访问到/www/web2目录中的内容,就需要配置/etc/httpd/conf/httpd.conf文件中的虚拟主机区域:

 
 
  1. <VirtualHost 172.16.4.1> 
  2.     ServerAdmin agony@example.com           ##这里指网站的管理员的邮箱地址 
  3.     DocumentRoot /www/htdocs            ##这里指的网页存放的目录 
  4.     ServerName 172.16.4.1               ##这里指的是网站的访问的IP地址 
  5.     Errorlog /var/log/htdocs_erro.log       ##这里是定义访问网站错误日志的存放地点 
  6.     CustomLog /var/log/htdocs_access.log        ##这里是定义访问网站的日志存放地点 
  7. </VirtualHost> 
  8.  
  9. <VirtualHost 172.16.4.2> 
  10.     ServerAdmin agony@example.com           ##这里指网站的管理员的邮箱地址 
  11.     DocumentRoot /www/web2              ##这里指的网页存放的目录 
  12.     ServerName 172.16.4.2               ##这里指的是网站的访问的IP地址        
  13.     Errorlog /var/log/web2_erro.log         ##这里是定义访问网站错误日志的存放地点 
  14.     CustomLog /var/log/web2_access.log      ##这里是定义访问网站的日志存放地点 
  15. </VirtualHost> 

注:这里默认监听的端口是80,如果需要重新设置,只需要在IP地址后面跟上端口号即可。

2、基于端口
如果希望使用172.16.4.1的80端口访问/www/htdocs目录的内容,使用172.16.4.1的8080端口访问/www/web2目录的内容,就需要在/etc/httpd/conf/httpd.conf里做如下的配置:

 
 
  1. <VirtualHost 172.16.4.1:80> 
  2.     ServerAdmin agony@example.com           ##这里指网站的管理员的邮箱地址 
  3.     DocumentRoot /www/htdocs            ##这里指的网页存放的目录 
  4.     ServerName 172.16.4.1:80            ##这里指的是网站的访问的IP地址以及端口号 
  5.     Errorlog /var/log/htdocs_erro.log       ##这里是定义访问网站错误日志的存放地点 
  6.     CustomLog /var/log/htdocs_access.log        ##这里是定义访问网站的日志存放地点 
  7. </VirtualHost> 
  8.  
  9. <VirtualHost 172.16.4.1:8080> 
  10.     ServerAdmin agony@example.com           ##这里指网站的管理员的邮箱地址 
  11.     DocumentRoot /www/web2              ##这里指的网页存放的目录 
  12.     ServerName 172.16.4.2:8080          ##这里指的是网站的访问的IP地址已经端口号       
  13.     Errorlog /var/log/web2_erro.log         ##这里是定义访问网站错误日志的存放地点 
  14.     CustomLog /var/log/web2_access.log      ##这里是定义访问网站的日志存放地点 
  15. </VirtualHost> 

3、基于FQDN,这也是最常用的方法
如果需要使用www.coolinuz.com访问/www/htdocs目录下的内容,使用www.magedu.com目录下的内容时,就需要将虚拟主机按照下面的配置方式进行配置:

 
 
  1. <VirtualHost 172.16.4.1> 
  2.     ServerAdmin agony@example.com           ##这里指网站的管理员的邮箱地址 
  3.     DocumentRoot /www/htdocs            ##这里指的网页存放的目录 
  4.     ServerName www.coolinuz.com         ##这里指的是访问网站时用的域名即FQDN 
  5.     Errorlog /var/log/htdocs_erro.log       ##这里是定义访问网站错误日志的存放地点 
  6.     CustomLog /var/log/htdocs_access.log        ##这里是定义访问网站的日志存放地点 
  7. </VirtualHost> 
  8.  
  9. <VirtualHost 172.16.4.1> 
  10.     ServerAdmin agony@example.com           ##这里指网站的管理员的邮箱地址 
  11.     DocumentRoot /www/web2              ##这里指的网页存放的目录 
  12.     ServerName www.magedu.com           ##这里指的是网站的访问的IP地址已经端口号       
  13.     Errorlog /var/log/web2_erro.log         ##这里是定义访问网站错误日志的存放地点 
  14.     CustomLog /var/log/web2_access.log      ##这里是定义访问网站的日志存放地点 
  15. </VirtualHost> 

注:当使用基于FQDN建立虚拟主机时还需要开启这项<NameVirtualHost 172.16.4.1:80>,该项在httpd-2.2.3的配置文件中是存在的,在httpd-2.4.1中没有该项。

二、别名的配置
当需要用户请求的URL过长时,在Apache中可以通过别名的配置减少客户端URL的输入量,并且通过别名可以跳转网页存放的目录,

例如:
apache的默认存放网页目录为/www/htdocs中,其访问FQDN为www.coolinuz.com,现需要访问/www/phpmyadmin目录中的网页,那么就可以使用别名来定义,具体配置如下:

 
 
  1. NameVirtualHost 172.16.4.1:80 
  2. <VirtualHost 172.16.4.1:80> 
  3.     Alias /php "/www/phpmyadmin" 
  4.     ServerAdmin agony@example.com 
  5.     DocumentRoot /www/htdocs 
  6.     ServerName www.coolinuz.com 
  7.     Errorlog /var/log/htdocs_erro.log 
  8.     CustomLog /var/log/htdocs_access.log 
  9. </VirtualHost> 

这时用户只需要在将URL置于www.coolinuz.com/php即可正常访问/www/phpmyadmin目录中的内容。

Alias string FilePath
string:指访问原网页的URL后面追加的那段字符串
FilePath:指需要跳转到哪个目录。

三、客户端的访问控制
Apache默认情况下,允许所有客户端对已配置好的网站进行访问,通过Order、Allow、From、Deny这些参数来允许和阻止指定客户端对网站中的目录或内容的访问控制的。

客户端的制定方法:
1、具体的IP地址
2、指定的网络
3、FQDN
4、域
5、所有的客户端,使用关键字"All"


例如:www.coolinuz.com这个网站只允许172.16.0.0/16网络中的主机访问。

 
 
  1. <VirtualHost 172.16.4.1:80> 
  2.     ServerAdmin agony@example.com 
  3.     DocumentRoot /www/htdocs 
  4.     ServerName www.coolinuz.com 
  5.     Errorlog /var/log/htdocs_erro.log 
  6.     CustomLog /var/log/htdocs_access.log 
  7.     <Directory /www/htdocs> 
  8.         Order Allow,Deny 
  9.         Allow From 172.16.0.0/16 
  10.     </Directory> 
  11. </VirtualHost> 

注:Order Allow,Deny,如果没有其他的Allow或Deny定义,则其默认动作为Order最后一个动作,在这里是Deny,如果是"Order Deny,Allow",则其默认动作为Allow。

四、基于用户认证的方式进行访问
在Apache的默认情况下,允许客户端进行匿名访问,Apache可以实现基于身份认证和摘要式身份验证。这里只做基本身份验证的实现详解。
在做基本身份验证时,认证用户来源可以是htpasswd工具生成的密码文件。

具体实现步骤:
1、使用apache自带的htpasswd工具生成密码文件来作为用户访问认证的来源
格式htpasswd options FilePath user
    -c :第一次创建时使用该选项
    -m :将密码使用MD5加密存放
    -D :从密码文件中删除用户


如:创建一个用户redhat,将密码文件存放在/etc/httpd/.htpasswd
#htpasswd -cm /etc/httpd/.htpasswd redhat
删除用户
#htpasswd -D /etc/httpd/.htpasswd redhat

2、对指定的网页目录使用基本身份认证

如对www.coolinuz.com网站的访问需要基于用户认证
配置apache的主配置文件:/etc/httpd/conf/httpd.conf

 
 
  1. NameVirtualHost 172.16.4.1:80 
  2. <VirtualHost 172.16.4.1:80> 
  3.     ServerAdmin agony@example.com 
  4.     DocumentRoot /www/htdocs 
  5.     ServerName www.coolinuz.com 
  6.     Errorlog /var/log/htdocs_erro.log 
  7.     CustomLog /var/log/htdocs_access.log 
  8.     <Directory /www/htdocs> 
  9.         AuthName PRIVATE            ##这里指在需要用户认证时的提示信息 
  10.         AuthType Basic              ##这里指认证的类型为基本认证 
  11.         AuthUserFile /etc/httpd/.htpasswd   ##这里指存放密码文件的路径 
  12.         Require valid-user          ##这里指密码文件中允许访问的用户,这里指的是全部,如果要具体允许某些用户则可写为"Require User redhat centos" 
  13.     </Directory> 
  14. </VirtualHost> 

 

好了,到此apache的几种常用的配置到此就完成了,只需要重新载入配置文件或者重启服务即可生效了,下篇将讲述apache启用https功能。

 








本文转自 向阳草米奇 51CTO博客,原文链接:http://blog.51cto.com/grass51/812523,如需转载请自行联系原作者
相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
12天前
|
消息中间件 安全 Unix
SSH配置多台服务器之间的免密登陆以及登陆别名
SSH配置多台服务器之间的免密登陆以及登陆别名
23 1
|
15天前
|
网络安全 Apache
Apache服务器安装SSL证书
Apache服务器安装SSL证书
19 0
|
6天前
|
存储 Java 网络安全
ZooKeeper【搭建 03】apache-zookeeper-3.6.0 伪集群版(一台服务器实现三个节点的ZooKeeper集群)
【4月更文挑战第10天】ZooKeeper【搭建 03】apache-zookeeper-3.6.0 伪集群版(一台服务器实现三个节点的ZooKeeper集群)
12 1
|
9天前
|
存储 弹性计算 安全
阿里云服务器2核2G、2核4G配置最新租用收费标准及活动价格参考
2核2G、2核4G配置是很多个人和企业建站以及部署中小型的web应用等场景时首选的云服务器配置,这些配置的租用价格也是用户非常关心的问题,本文为大家整理汇总了2024年阿里云服务器2核2G、2核4G配置不同实例规格及地域之间的收费标准,同时整理了这些配置最新活动价格,以供大家参考和选择。
阿里云服务器2核2G、2核4G配置最新租用收费标准及活动价格参考
|
12天前
|
域名解析 网络协议 应用服务中间件
阿里云服务器配置免费https服务
阿里云服务器配置免费https服务
|
15天前
|
安全 关系型数据库 MySQL
国产麒麟服务器等保二级 配置规范(一)
国产麒麟服务器等保二级 配置规范(一)
33 0
|
15天前
|
数据采集
robots.txt配置 减小服务器压力
robots.txt配置 减小服务器压力
13 0
|
2月前
|
消息中间件 Kafka Apache
Apache Flink 是一个开源的分布式流处理框架
Apache Flink 是一个开源的分布式流处理框架
482 5
|
1月前
|
消息中间件 API Apache
官宣|阿里巴巴捐赠的 Flink CDC 项目正式加入 Apache 基金会
本文整理自阿里云开源大数据平台徐榜江 (雪尽),关于阿里巴巴捐赠的 Flink CDC 项目正式加入 Apache 基金会。
1410 1
官宣|阿里巴巴捐赠的 Flink CDC 项目正式加入 Apache 基金会
|
1月前
|
SQL Java API
官宣|Apache Flink 1.19 发布公告
Apache Flink PMC(项目管理委员)很高兴地宣布发布 Apache Flink 1.19.0。
1345 1
官宣|Apache Flink 1.19 发布公告

推荐镜像

更多