前言
- Apache简介
- Apache的主要特点
- httpd 服务器的基本配置
- 搭建httpd虚拟主机
Apache简介:
Apache HTTP Server 是开源软件项目的代表,也是世界使用排名第一的Web服务器软件。它可以运行在几乎所有广泛使用的计算机平台上。 因为它是自由的开源软件,所以不断有人来为它开发新的功能、新的特性、修改原来的缺陷。
Apache的主要特点:
-
开源代码:这是它的重要特点之一,也是其他特性的基础
-
跨平台应用:apache服务器可以运行在绝大多数的平台上
支持各种web编程语言:Apache服务器可支持的网页编程语言包括Perl、PHP、Python、Java等。
-
模块化设计:Apache并没有将所有的功能集中在单一的服务程序内部,而是尽可能的通过标准的模块来实现专有的功能
-
运行非常稳定:Apache服务器可用于构建具有大量负载访问量的web站点
-
良好的安全性:Apache服务器具有相对较好的安全性,这是开源软件共同具有的特性
httpd 服务器的基本配置
1·安装httpd服务 > yum install httpd -y
2·修改主配置文件
vim /etc/httpd/conf/httpd.conf //httpd的主配置文件 修改内容如下: Listen 192.168.100.20:80 //监听地址 #Listen 80 //需要注释掉IPV6的端口 service iptables stop //关闭防火墙 setenforce 0 service httpd start / /开启httpd服务
3·验证httpd:
访问监听地址:192.168.100.20
4·修改站点内容:
cd /var/www/html/ echo "this is test web" > index.html #在站点中写入测试的语句
再来验证一次:
httpd 搭建多网站(虚拟主机)
1·需要建立虚拟主机的配置文件:
cd /etc/httpd/conf.d/ vim vdir.conf #手动建立一个虚拟主机的配置文件 添加虚拟目录的配置文件格式: Alias /test "/opt/test/" #别名,/test = /opt/test(站点存放的位子)访问网站时加上test <Directory "/opt/test/"> #开头定义路径 固定格式 Options Indexes MultiViews FollowSymLinks #建立索引,固定格式 AllowOverride None #不允许重写(固定格式) AuthName "hello" #hello信息 authtype basic #认证类型 basic是一种最基本的认证 authuserfile /etc/httpd/user #身份验证登陆,并且指定文件位子 #authgroupfile /etc/httpd/group #组身份验证登陆和指定文件位子 #require Valid-user #开启用户认证 #require user test #仅允许那些用户登陆 #Require group admin #仅允许那些组登陆 </Directory>
2·我们配置文件写好了,现在需要建立站点,因为在配置文件中我们指定的站点是没有的,所以需要手动建立,然后再站点中写入数据,便于测试!
mkdir /opt/test #建立虚拟主机站点 echo "this is test 2 " > /opt/test/index.html #在站点中写入数据 service httpd restart #重启服务
验证:这样就可以从分利用服务器的性能
3·我们还可以做访问控制列表,需要用户认证配置:
htpasswd -c /etc/httpd/user zhangsan vim /etc/httpd/conf.d/vdir.conf 去掉以下注释的内容: require Valid-user #开启用户认证 service httpd restar #重启服务
验证:
基于不同域名的虚拟主机
1·当虚拟web主机的数量较多时,建议使用独立的虚拟主机配置文件,然后再httpd.conf文件中通过Include来加载这些配置,这样会更方便配置内容的维护。这里就创建两个主机名的配置文件为列。
cd /etc/httpd/conf.d/ vim host.conf #建立独立的主机名配置文件 添加配置如下: NameVirtualHost 192.168.100.20:80 #定义IP地址和端口 <VirtualHost 192.168.100.20:80> #再次定义(固定格式) ServerAdmin webmaster@dummy-host.example.com #管理员邮箱 DocumentRoot /opt/benet #定义站点目录 ServerName www.benet.com #服务器名字 ErrorLog logs/benet.com-error_log #错误日志文件名 CustomLog logs/benet.com-access_log common #访问日子文件名 </VirtualHost>
NameVirtualHost 192.168.100.20:80 #定义IP地址和端口 <VirtualHost 192.168.100.20:80> #再次定义(固定格式) ServerAdmin webmaster@dummy-host.example.com #管理员邮箱 DocumentRoot /opt/baidu #定义站点目录 ServerName www.baidu.com #服务器名字 ErrorLog logs/baidu.com-error_log #错误日志文件名 CustomLog logs/baidu.com-access_log common #访问日子文件名 </VirtualHost>
2·在配置文件中写的站点目录是没有的,所以需要手动创建,在站点写入一些数据方便测试
mkdir /opt/benet mkdir /opt/baidu echo "this is benet" > /opt/benet/index.html echo "this is baidu" > /opt/baidu/index.html
3·既然是基于不同域名访问,那么我们就要搭建DNS服务:
rpm -ivh /mnt/Packages/bind-9.8.2-0.17.rc1.el6_4.6.x86_64.rpm vim /etc/named.conf #修改主配置文件 修改内容如下: options { listen-on port 53 { any; }; listen-on-v6 port 53 { ::1; }; directory "/var/named"; dump-file "/var/named/data/cache_dump.db"; statistics-file "/var/named/data/named_stats.txt"; memstatistics-file "/var/named/data/named_mem_stats.txt"; allow-query { any; }; recursion yes;
修改区域配置文件:
vim /etc/named.rfc1912.zones 修改内容如下: zone "benet.com" IN {
type master; file "benet.com.zone"; allow-update { none; }; }; zone "baidu.com" IN { type master; file "baidu.com.zone"; allow-update { none; }; };
修改区域数据配置文件:
cd /var/named/ cp -p named.localhost benet.com.zone cp -p named.localhost baidu.com.zone vim bent.com.zone 修改内容如下: $TTL 1D @ IN SOA @ admin. ( 0 ; serial 1D ; refresh 1H ; retry 1W ; expire 3H ) ; minimum NS @ A 127.0.0.1 www IN A 192.168.100.20
修改第二个域名的区域数据文件:
vim baidu.com.zone
$TTL 1D @ IN SOA @ admin. ( 0 ; serial 1D ; refresh 1H ; retry 1W ; expire 3H ) ; minimum NS @ A 127.0.0.1 www IN A 192.168.100.20
重启服务,开始验证:
service httpd restart service named restart
相同IP不同端口访问:
在vim /etc/httpd/conf/httpd.conf 添加如内容: Listen 192.168.100.20:8080
在vim /etc/httpd/conf.d/host.conf 配置文件添加数据: 添加内容如下:
NameVirtualHost 192.168.100.20:8080 <VirtualHost 192.168.100.20:8080> ServerAdmin webmaster@dummy-host.example.com DocumentRoot /opt/accp01 ServerName www.accp.com ErrorLog logs/accp.com-error_log CustomLog logs/accp.com-access_log common </VirtualHost>
建立站点,并且写入数据
mkdir /opt/accp echo "this is accp" > /opt/accp/index.html 重启服务,验证:
实验成功!
总结:
httpd 服务器的主配置文件是 httpd.conf,通过Include配置项可以加载其他配置文件 httpd 服务支持虚拟web主机(搭建多网站),可以基于域名、端口来访问