用实验快速掌握web服务器Apache

    Apache是大多数linux版本的标准web 服务器,掌握他的意义就非常大。
  
    本文以实验的方式,让读者快速掌握Apache的基本配置。
  
    [实验目的]
  
    1.Apache的基本安装和配置。
  
    2.Apache中应用CGI。
  
    3.基本代理配置。
  
    [实验要求]
  
    1.两台互通的RH8.0机。
  
    2.这两台机已配置过DNS。
  
    [实验步骤]
  
    1.准备工作。
  
    由于web 服务器与DNS关系非常紧密。作好这步准备工作,请参考本人的另一篇文章
  
    “用实验快速掌握DNS配置”。这篇文章发表在linuxsir的网络版块。
  
    DNS 能够实现的主要功能就是能能解析:station1.exmaple1.com,
  
    server1.example1.com 两个域名的IP,如果你想在/etc/hosts中实现,我想也不是不可
  
    以。这里不提倡这么做。
  
    本文中作法比较教条,这里指明机器1为:server1.example1.com,机器2为:
  
    station1.example1.com .读者也可以自己变通。
  
    2.在机器1上安装和配置简单的Apache。
  
    1) 检查下列包是否安装,
  
    httpd
  
    httpd-manual
  
    缺什么,装什么。
  
    2) 开启httpd服务
  
    # service httpd start
  
    如果开启失败,查看/var/log/httpd/下的相关日志,切记要在/etc/hosts中添加类似
  
    192.168.0.254 example1.com server1 的一行。
  
    3) 检查/etc/httpd/conf/httpd.conf中,有下列一行活动
  
    DocumentRoot /var/www/html
  
    4) 用一个浏览器打开:
  
    http://server1.example1.com
  
    如果是正常情况,你会看到Apache的介绍页面。
  
    5) 创建新的目录和html文件。
  
    # mkdir -p /var/www/virtual/server1.example1.com/html
  
    # vi /var/www/virtual/server1.example1.com/html/index.html
  
    Server1.example1.com
  
    6) 编辑/etc/httpd/conf/httpd.conf,末尾追加下列文本。
  
    NameVirtualHost 192.168.0.254
  
    ServerName server1.example1.com
  
    ServerAdmin root@server1.example1.com
  
    DocumentRoot /var/www/virtual/server1.example1.com/html
  
    ErrorLog logs/server1.example1.com-error_log
  
    CustomLog logs/server1.example1.com-access_log combined
  
    Options Indexes Includes
  
    7) 确保DNS能够解析你的VirtualHost
  
    # host server1.example1.com
  
    8) 重新启动httpd
  
    # service httpd restart
  
    如果启动失败,看/var/log/httpd/下的相应日志,会告诉你具体哪里错误。
  
    9) 在浏览器里能够看到你自己写的网页了吗?
  
    http://server1.example1.com
  
    10) 在机器2上能看到http://server1.example1.com吗?
  
    3.机器1,在Apache中应用CGI
  
    1) 编辑/etc/httpd/conf/httpd.conf,在块中添加下列一行:
  
    ScriptAlias /cgi-bin/ /var/www/virtual/server1.example1.com/cgi-bin/
  
    2) 创建目录,创建文件。
  
    # mkdir /var/www/virtual/server1.example1.com/cgi-bin
  
    #vi /var/www/virtual/server1.example1.com/cgi-bin/test.sh
  
    #!/bin/bash
  
    echo Content-Type: text/html
  
    echo
  
    echo “”
  
    echo My username is :
  
    whoami
  
    echo
  
    echo My id i????s?? ??ゐ?!s :
  
    id
  
    echo
  
    echo Here is /etc/passwd :
  
    cat /etc/passwd
  
    echo “”
  
    3) 改变test.sh的执行权限:
  
    # chmod 555 test.sh
  
    4) 重启httpd服务:
  
    # service httpd restart
  
    若有错,看日志。
  
    5) 浏览:http://server1.example1.com/cgi-bin/test.sh
  
    6) 机器2能浏览http://server1.example1.com/cgi-bin/test.sh吗?
  
    4.基本代理配置:
  
    1) 机器1,检查squid 包装了没有,没有的话,则进行安装。
  
    2) 机器1,启动squid 服务。
  
    # service squid start
  
    有问题? 看/var/log/messages.
  
    3) 机器1,浏览器中设置代理端口为3128,举例:在mozilla: Edit | Preferences…|
  
    Advanced | proxies 中,设定手动,端口为:3128,其他不动。
  
    机器2,浏览器中类似设置为:手动,http代理:192.168.0.254 端口:3128。
  
    4) 此时,机器1,能浏览server1.exmaple1.com.,若平时能上internet,此时也正常上
  
    internet。
  
    5) 机器2,不能浏览server1.example1.com 或internet。
  
    查看/var/log/httpd/*的日志文件,原因是什么?
  
    6) 编辑/etc/squid/squid.conf,在acl CONNECT method CONNECT行下,添加下列一行:
  
    acl examample1 src 192.168.0.0/24
  
    找到INSERT YOUR OWN RULE(S) HERE 增加下列一行:
  
    http_access allow example1
  
    7) 重启squid
  
    # service squid restart
  
    有错?看日志。
  
    8) 此时,机器2能够浏览server1.example1.com 或 internet网页.
  
    9) 编辑/etc/squid/squid.conf ,在acl examample1 src 192.168.0.0/24行下添加
  
    acl otherdeny dstdomain .sina.com.cn
  
    在http_access allow example1下添加:
  
    http_access deny otherdeny
  
    10) 重启squid.
  
    # service squid restart
  
    有错? 看日志。
  
    11) 机器2,仍能浏览 http://www.sina.com.cn,为什么
  
    12) 编辑/etc/squid/squid.conf ,把http_access deny otherdeny放到http_access allow example1前面,重启squid,机器2还能看到http://www.sina.com.cn
  
    [实验总结]
  
    Apache配置是否成功,与DNS有很大关系,所以,要求读者先花时间作好DNS工作。本文以最通俗的方式,教你简单的配置Apache,如果想深入掌握它,还得研究Apache2.0的文档。最近看到http://kajaa.bbs.us/ApacheManual/zh-cn/是kajaa老兄翻译成了Apache的中文文档,相信对大家一定有好处。