• Linux服务器部署系列之一—Apache篇(上)


    Linux系统的应用越来越广泛了,学习linux系统的网管兄弟也有增加的趋势。很久以前就有些想法,要将自己学的linux知识整理一下。最近,终于下定决心,挤出时间开始动手写些东西了。虽然不一定好,不过,留些笔记至少可以方便记忆。
    Apache是Linux服务里面用得最多的之一,今天我们就从它开始来一次Linux服务部署之旅。
    本文分以下章节介绍:
    1. 安装Apache
    2. 配置Apache
    3. 配置虚拟主机
    4. 管理日志文件
    5. 配置PHP运行环境
     
    一、安装Apache
    1. 安装Apache
    # tar  zxvf  httpd-2.2.11.tar.gz
    # cd  httpd-2.2.11
    # ./configure  --prefix=/usr/local/apache  --enable-so
    //编译时加上加载模块参数--enable-so
    # make
    # make  install
     
    2. 配置系统启动时自动启动Apache服务。
    # vi  /etc/rc.d/rc.local
      //在rc.local上加入一行/usr/local/apache/bin/apachectl –k  start。
     
     
    二、配置Apache
    1. 修改httpd.conf文件
    # vi  /usr/local/apache/conf/httpd.conf
    1) 设置根目录的路径
    根目录是指Apache存放配置文件和日志文件的目录,配置参数为ServerRoot,默认位于“/usr/local/apache”。命令如下:
     
    2) 设置监听IP地址及端口号
    默认侦听本机所有IP地址的TCP80端口,命令如下:
    Listen 80
    用户也可以按自己的需求,使用多个Listen语句在多个地址和端口上侦听客户端请求。比如:
    Listen 192.168.99.9:80
    Linsten 172.16.0.20:8080
    3) 设置系统管理员E-mail
    使用ServerAdmin参数设置管理员E-mail,比如管理员的Email地址为root@guoxuemin.cn:
     
    4) 设置服务器主机的名称
    参数ServerName用来设置服务器的主机名称,如果没有域名则填入服务器的IP地址,比如服务器的IP地址为192.168.99.9:
     
    5) 设置主目录的路径
    用户可以使用参数DocumentRoot配置服务器主目录默认路径,比如,主目录路径为:
     
    6) 设置默认文件
    Apache的默认文件名为index.html,可以使用Directory Index参数来配置,比如,将index.php设置为默认文件名:
     
    7)测试:
    打开浏览器,输入地址:http://192.168.99.9,可以打开站点了:
     
     
    2. 配置目录权限
    使用<Directory 目录路径>和</Directory>设置目录的权限。比如:
    <Directory  “/var/www/icons”>
    Options  Indexes  MultiViews
    AllowOverride  None
    Order  allow,deny
    Allow  from  all
    </Directory>
    说明:
    1)定义目录特性选项Options
    可选参数:
    Indexes:该特性表明目录允许“目录浏览”;
    MultiViews:该特性表明目录允许内容协商的多重试图;
    All:包含了除MultiViews外的所有特性;
    ExecCGI:该特性表明允许在该目录下执行CGI脚本;
    FollowSymLinks:该特性表明允许在该目录下使用符号连接。
    2).htaccess文件
    可以通过.htaccess文件(访问控制文件)设置目录的权限。
    AccessFileName  .htaccess
    配置参数AllowOverride指定目录的.htaccess文件中指令的类型,包括All、None与Options、FileInfo、AuthConfig、Limit的任意组合。一般将AllowOverride设置为“None”,禁止使用.htaccess文件,当AllowOverride参数为All时,.htaccess文件可以覆盖任何以前的配置。
    3)设置访问控制
    使用Order选项来定义访问权限。
    比如以下语句表明允许所有客户机的访问:
    Order  allow,deny
    Allow  from  all
    以下语句表明只允许网段192.168.99.0/24的客户机访问,但IP地址为192.168.99.254这个客户机除外:
    Order  allow,deny
    Allow from  192.168.99.0/24
    Deny from  192.168.99.254
    用户可以根据需要,按上述方法配置自己的目录权限。
     
    3. 创建虚拟目录
    使用Alias选项创建虚拟目录,比如,建立“/icons/”这个虚拟目录,其对应的物理路径为“/var/www/icons/”:
    Alias  /icons/  “/var/www/icons/”
     
    4. 用户认证
    比如,有一个名为myweb的虚拟目录,其对应的物理路径是“/usr/local/myweb”,现对其启用用户认证功能,只允许用户Tonyguo和Wayne访问。
    1)建立虚拟目录并设置用户认证:
     
    2) 建立口令文件并为用户设置口令
     
    -c选项表示无论口令文件是否已经存在,都会重新写入文件并删除原内容。所以第二个用户wayne不需要使用-c选项。
    3)测试
    在浏览器中输入:http://192.168.99.9/myweb,可以看到如下对话框:
     
    输入用户名和密码后就可以访问网站了:
     
     
    三、配置虚拟主机
    1. 配置基于IP的虚拟主机
    1)IP地址相同,但端口号不同的虚拟主机配置
    比如使用192.168.99.9的两个不同端口80和8080发布两个不同站点, 虚拟主机分别对应的目录为/usr/local/apache/htdocs/web1和/usr/local/apache/htdocs/web2:
    Listen 80
    Listen 8080
    <VirtualHost  192.168.99.9:80>
      ServerSignature  email
      DocumentRoot  /usr/local/apache/htdocs/web1
      DirectoryIndex  index.html  index.htm
      LogLevel  warm
      HostNameLookups  off
    </VirtualHost>
    <VirtualHost  192.168.99.9:8080>
      ServerSignature  email
      DocumentRoot  /usr/local/apache/htdocs/web2
      DirectoryIndex  index.html  index.htm
      LogLevel  warm
      HostNameLookups  off
    </VirtualHost>
    2)配置基于域名的虚拟主机
    比如服务器有两个IP地址192.168.99.9和192.168.99.10,使用这两个IP创建两台虚拟主机,虚拟主机分别对应的目录为/usr/local/apache/htdocs/web1和/usr/local/apache/htdocs/web2。设置方法如下:
    <VirtualHost  192.168.99.9>
      ServerName  192.168.99.9:80
      DocumentRoot  /usr/local/apache/htdocs/web1
      DirectoryIndex  index.html  index.htm
    </VirtualHost>
    <VirtualHost  192.168.99.10>
      ServerName  192.168.99.10:80
      DocumentRoot  /usr/local/apache/htdocs/web2
      DirectoryIndex  index.html  index.htm
    </VirtualHost>
     
    2. 配置基于域名的虚拟主机
    比如有两个域名guoxuemin.cn和tonyguo.com需要使用同一台服务器192.168.99.9,那么可以这样配置:
    NameVirtualHost  192.168.99.9
    <VirtualHost  www.guoxuemin.cn>
      ServerName  www.guoxuemin.cn:80
      ServerAdmin  admin@guoxuemin.cn
      DocumentRoot  /usr/local/apache/htdocs/web1
      DirectoryIndex  index.html  index.htm
      ErrorLog  logs/web1/error_log
      Customlog  logs/web1/access_log  combined
    </VirtualHost>
    <VirtualHost  www.tonyguo.com>
      ServerName   www.tonyguo.com:80
      ServerAdmin  admin@tonyguo.com 
    DocumentRoot  /usr/local/apache/htdocs/web2
      DirectoryIndex  index.html  index.htm
      ErrorLog  logs/web1/error_log
      Customlog  logs/web1/access_log  combined
    </VirtualHost>
     
    未完,待续。。。

    本文出自 “Tonyguo De博客【知识..” 博客,请务必保留此出处http://tonyguo.blog.51cto.com/379574/168534

  • 相关阅读:
    企业网盘针对文件权限管理的技术实现
    学校私有云盘在学校信息化建设中的作用-教学资源库平台
    Mobox 知识管理平台助推市长质量奖
    为勇敢的华裔女子点赞
    一群喵星人把他家包围了。。
    【OI】简单的分块
    【OI】Kruskal & ufs (克鲁斯卡与并查集)
    【OI】向量&矩阵乘法
    【OI】同余方程
    【Ubuntu】某灯图标过大
  • 原文地址:https://www.cnblogs.com/lanliying/p/4152618.html
Copyright © 2020-2023  润新知