配置环境:
linux版本:Centos6.4
httpd版本:
1,安装httpd服务
yum install httpd -y
2,关闭selinux和防火墙
临时设置selinux为permissive( disabled )状态
永久修改方法:
[root@centos64Study ~]# vim /etc/sysconfig/selinux
SELINUX=permissive
3,关闭防火墙
service iptables stop
第一种,基于多ip访问的配置:
1,先把httpd.conf备份一下,以防出错,可以恢复
httpd.conf的文件路径( /etc/httpd/conf )
[root@centos64Study conf]# ls
httpd.conf httpd.conf.bak magic
2,如果需要启用虚拟主机配置,在文件httpd.conf中,先把中心主机的配置注释
#DocumentRoot "/var/www/html"
3,在httpd.conf中,会默认包conf.d目录中的所有 以.conf结尾的配置文件
Include conf.d/*.conf
所以,把虚拟主机的配置文件独立出来放在conf.d目录下
VirtualHost.conf 配置文件内容:
我的主机ip是192.168.1.8,添加另一个ip:
ip addr add 192.168.1.2/24 dev eth0
在对应的目录建立文件:
[root@centos64Study www]# tree
.
├── 7mxt.com
│ └── index.html
└── 7mxt.net
└── index.html
重启服务: service httpd restart,在浏览器中分别用这两个ip访问,就能看到对应的页面
第二种,基于多端口访问的配置:
1,在VirtualHost.conf中增加一项配置:
2,在httpd.conf监听8080端口
Listen 80
Listen 8080
3,/www建立对应的目录和文件
重启服务: service httpd restart,在浏览器中用http://192.168.1.2:8080/ 就能访问到abc.net目录下面的文件index.html内容
[root@centos64Study www]# tree
.
├── 7mxt.com
│ └── index.html
├── 7mxt.net
│ └── index.html
└── abc.net
└── index.html
第三种:基于域名的主机配置
1,NameVirtualHost:指定192.168.1.8:80这个ip地址使用域名解释
2,在对应的目录下建立文件
[root@centos64Study www]# tree
.
├── 7mxt.com
│ └── index.html
├── 7mxt.net
│ └── index.html
├── 7mxt.org
│ └── index.html
└── abc.net
└── index.html
3,在windows host文件中增加主机映射配置
【C:\Windows\System32\drivers\etc】
192.168.1.8 www.7mxt.com
192.168.1.8 www.7mxt.org
4,重启服务: service httpd restart,分别用域名www.7mxt.com, www.7mxt.org就能访问到对应的文件内容
使用ip: 192.168.1.8返回的是第一个虚拟主机的配置,即:www.7mxt.com对应目录下面的内容
----------------------------------------------------------------------------------------------------------------------------------------------------
更详细的配置信息:
1,www.7mxt.com这个域名下面的Directory配置为 需要用户验证,支持3种情况的配置:
。只允许某个用户访问
。只允许文件中的用户
。只允许组文件中定义的用户
AllowOverride AuthConfig: 需要授权
AuthType Basic:基本授权
AuthName "Restricted Site..." :授权说明
AuthUserFile "/etc/httpd/conf/htpasswd" : 需要授权的用户 保存在这个文件中,这个文件中的内容用
htpasswd这个命令创建,第一次带参数c表示创建,第二次不需要带c
htpasswd -c -m /etc/httpd/conf/htpasswd ghost
htpasswd -m /etc/httpd/conf/htpasswd ghostwu
AuthGroupFile "/etc/httpd/conf/htgroup": 需要授权的用户保存在这个文件中
#Require user ghost:只允许ghost这个用户登录
Require group myusers: 只允许myusers这个组中的用户登录
#Require valid-user:只允许htpasswd这个文件中定义的用户登录
[root@centos64Study conf]# ls
htgroup htpasswd httpd.conf httpd.conf.bak magic
[root@centos64Study conf]# cat htgroup
myusers: ghost ghostwu
[root@centos64Study conf]# cat htpasswd
ghost:$apr1$IeKI2YLO$RX8EjYBoHbMzCkHocFK0l/
ghostwu:$apr1$LoA/O0i0$0/EJu3xTXo2yCMimMUAcQ.
2,CustomLog /var/log/httpd/7mxt.org/access_log combined
自定义访问日志的文件路径,【注意:需要在/var/log/httpd下面存在7mxt.org这个目录】
3,
<Directory "/www/7mxt.net">
Options none
AllowOverride none
Order deny,allow
Deny from 192.168.1.100
</Directory>
这个配置针对的是7mxt.net,禁止192.168.1.100访问7mxt.net,其他的ip都允许