Linux网站架构系列之Apache—-进阶篇

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1320167

本篇博文为Linux网站架构系列之apache的第二篇,我将带大家一起学习apache的编译参数,目录结构和配置文件等方面的知识,实现对apache服务的进一步掌握,并使之能更好的应用到生产实战中去。


一、编译参数

在上篇的apache部署中,我们用了大量的编译参数,其实apache的编译参数并不止这些,这些只是我们生产环境中常用的。我们在apache的源码包目录下,用以下命令可以将他们都输出出来

[root@c64-web httpd-2.4.6]# ./configure --help

此命令的输出这里就不贴出来了,一大堆呢,估计你也不看,有些参数一百年也用不到一次。如果想了解这些参数,你可以百度一下。

这里我将详细为大家说明一下我们常用的编译参数的作用

--prefix=/usr/local/apache-2.4.6 \    #表示指定apache安装路径为/application/apache2.2.25。如果不指定安装路径,则默认路径为/usr/local/apache2
--with-apr=/usr/local/apr \           #指定apr安装路径,不然会报错
--with-apr-util=/usr/local/apr-util \ #指定apr-util安装路径,不然会报错
--with-pcre \                         #支持perl的正则表达式,不然会报错
--enable-so \                         #激活apache服务的DSO(全称Dynamic Shared Object,动态共享对象)支持,即在以后可以以DSO的方式编译安装共享模块,这个模块本身不能以DSO方式编译。
--enable-ssl \                        #基于ssl加密传输
--enable-cgi \                        #开启CGI脚本
--enable-rewrite \                    # 提供基于URL规则的重写功能。即根据已知URL地址,转换其它想要的URL地址。如前文讲解的伪静态功能就是这个模块实现的。这是apache生产环境中必用的一个重要功能。
--with-zlib \                         #支持压缩
--enable-deflate \                    # 提供对内容的压缩传输编码支持,一般html,js,css等内容的站点,使用此参数功能会大大提高传输速度,提升访问者访问体验。在生产环境中,这是apache调优的一个重要选项之一。
--enable-expires \                    # 激活允许通过配置文件控制HTTP的“Expires:”和“Cache-Control:”头内容,即对网站图片、js、css等内容,提供在客户端游览器缓存的设置。这是apache调优的一个重要选项之一。
--enable-headers \                    #提供允许对HTTP请求头的控制
--enable-modules=most \               #支持大多数模块
--enable-mpms-shared=all \            #mpm模块的动态切换
--with-mpm=worker                     #选择apache mpm的模式为worker模式。因worker模式原理是更多的使用线程来处理请求,所以可以处理更多的并发请求,而系统资源的开销小于基于进程的MPM prefork。如果不指定此参数,默认的模式是prefork进程模式。这两者的关系,在调优篇里面我会详细为大家讲解。

二、apache目录结构介绍

熟悉apache的目录结构,对我们对apache知识点的理解和掌握尤为重要,下面我将带大家一起来对apache的目录结构进行了解。以上就是apache的目录结构说明了,大家了解一下知道做什么用就可以了。

[root@c64-web /]# tree -L 3 /usr/local/apache/    #以下我对输出做了精简,仅保留常用的
./
├── bin         #存放apache命令的目录,如apache启动命令apachectl
  ├── ab        #apache http服务器性能测试工具,简单、易用。同类软件还有jmeter、loadrunner、webbench等
  ├── apachectl  #apache的启动程序,需重点掌握,apachectl是一个脚本
  ├── apxs       #apxs是一个为apache HTTP服务器编译和安装扩展模块的工具,在进行DSO方式模块编译时会用到。后面在编译php软件时就用到了这个命令,如:--with-apxs2=/application/apache/bin/apxs
  ├── htcacheclean #这是清理磁盘缓冲区的命令,需要在编译时指定相关参数才可使用,一般用的很少。
  ├── htpasswd   #建立和更新基本认证文件,如:配置nagios等监控服务时会用到。
  ├── httpd      #httpd为apache的控制命令程序,apachectl执行时会调用httpd
  └── rotatelogs #apache自带的日志轮询工具,也还可以用,但在老师工作场景中习惯由cronolog替代之
├── build
├── cgi-bin
├── conf   #这是apache的所有的配置文件的目录,极其重要
  ├── extra #这是额外的apache配置文件目录,这个目录里的文件我们会经常访问修改
   ├── httpd-dav.conf   #dav支持配置
   ├── httpd-default.conf    #这个文件里配置的是apache的相关服务参数:超时时间,保持连接时间等。
   ├── httpd-languages.conf  #语言支持配置
   ├── httpd-mpm.conf   #服务器池管理,也就是优化apache的一个配置文件,如:选择apache的模式及配置连接数等,常用的模式有worker模式和profork模式,默认情况是profork模式。
   ├── httpd-ssl.conf   #这是apache SSL支持配置文件
   └── httpd-vhosts.conf  #这是虚拟主机的配置文件
  └── httpd.conf  #apache的主配置文件,这个文件我们会经常访问修改,其每一行的参数作用都应弄清楚明白
├── htdocs   #这是编译安装时apache的默认站点目录,前面已说明。
  └── index.html #默认的首页文件,在实际环境中,大家习惯用index.html、index.php、index.jsp来做首页文件,首页文件名字是在httpd.conf中事先定义好的。具体参数:Directoryindex index.html
├── logs  #存放apache默认的日志路径,包括错误日志及访日志问
  ├── access_log  #这是apache的默认访问日志文件。
  ├── error_log   #这是apache的错误日志文件,如果apache出现启动故障等问题,一定要看看这个错误日志。
 └── httpd.pid    #httpd的pid文件,httpd进程启动后,会把所有进程的ID号写到此文件。
└── modules  #apache的模块目录,比如php.memcache等模块编译后都在这里。

三、apache主配置文件详解

下面我将为大家详细介绍apache的主配置文件,我们通过下面的命令将apache默认开启的行筛选出来以上是我们编译安装完成apache后,apache的默认主配置文件。其中有个别行暂时没有解开注释的,我会在用的时候给大家提到。

[root@c64-web /]# egrep -v "^$|#" /usr/local/apache/conf/httpd.conf|cat -n
     1  ServerRoot "/usr/local/apache-2.4.6"   #apache的根目录,应只能root访问,一般不需要更改此配置
     2  Listen 80  #apache监听的端口,默认为80端口,如果同时监听81可以增加一行,如 Listen 81
     3  LoadModule authn_file_module modules/mod_authn_file.so
     4  LoadModule authn_core_module modules/mod_authn_core.so
     5  LoadModule authz_host_module modules/mod_authz_host.so
     6  LoadModule authz_groupfile_module modules/mod_authz_groupfile.so
     7  LoadModule authz_user_module modules/mod_authz_user.so
     8  LoadModule authz_core_module modules/mod_authz_core.so
     9  LoadModule access_compat_module modules/mod_access_compat.so
    10  LoadModule auth_basic_module modules/mod_auth_basic.so
    11  LoadModule reqtimeout_module modules/mod_reqtimeout.so
    12  LoadModule filter_module modules/mod_filter.so
    13  LoadModule mime_module modules/mod_mime.so
    14  LoadModule log_config_module modules/mod_log_config.so
    15  LoadModule env_module modules/mod_env.so
    16  LoadModule headers_module modules/mod_headers.so
    17  LoadModule setenvif_module modules/mod_setenvif.so
    18  LoadModule version_module modules/mod_version.so
    19  LoadModule mpm_worker_module modules/mod_mpm_worker.so
    20  LoadModule unixd_module modules/mod_unixd.so
    21  LoadModule status_module modules/mod_status.so
    22  LoadModule autoindex_module modules/mod_autoindex.so
    23  LoadModule dir_module modules/mod_dir.so
    24  LoadModule alias_module modules/mod_alias.so
    25  <IfModule unixd_module>
    26  User daemon   #apache的用户,默认为daemon,建议修改为特定普通用户,如sunsky
    27  Group daemon  #apache的用户组,默认为daemon,建议修改为特定普通用户,如sunsky
    28  </IfModule>
    29  ServerAdmin you@example.com   #系统管理员的邮箱
    30  <Directory />   #这将禁止访问文件系统所在的目录,并添加你希望允许访问的目录块
    31      AllowOverride none  #表示禁止用户对目录配置文件(.htaccess进行修改)重载,普通站点目录此项建议不开
    32      Require all denied   #拒绝所有请求
    33  </Directory>
    34  DocumentRoot "/usr/local/apache-2.4.6/htdocs"
    35  <Directory "/usr/local/apache-2.4.6/htdocs">
    36      Options Indexes FollowSymLinks   #允许目录游览和符号链接,生产环境默认这里为None一项也不打开
    37      AllowOverride None  #表示禁止用户对目录配置文件(.htaccess进行修改)重载,普通站点目录此项建议不开
    38      Require all granted   #授权所有请求
    39  </Directory>
    40  <IfModule dir_module>
    41      DirectoryIndex index.html  #配置默认的apache首页文件,如虚拟主机没有此配置,默认应用这里的配置。首页文件可以有多个,每个文件用空格分开,调用时,前面优先匹配。
    42  </IfModule>
    43  <Files ".ht*">     #防止.htaccess和.htpasswd等重要隐藏文件被web用户查看
    44      Require all denied
    45  </Files>
    46  ErrorLog "logs/error_log"  #错误日志路径,logs为apache安装目录的相对路径,遇到apache错误要记得查看此文件
    47  LogLevel warn
    48  <IfModule log_config_module>
    49      LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined   #访问日志格式
    50      LogFormat "%h %l %u %t \"%r\" %>s %b" common #普通访问日志格式
    51      <IfModule logio_module>
    52        LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio
    53      </IfModule>
    54      CustomLog "logs/access_log" common   #默认站点访问日志配置
    55  </IfModule>
    56  <IfModule alias_module>
    57      ScriptAlias /cgi-bin/ "/usr/local/apache-2.4.6/cgi-bin/"    #配置cgi别名,ScriptAlias 方法可以学习。
    58  </IfModule>
    59  <IfModule cgid_module>
    60  </IfModule>
    61  <Directory "/usr/local/apache-2.4.6/cgi-bin">   #允许cgi-bin路径访问
    62      AllowOverride None
    63      Options None
    64      Require all granted
    65  </Directory>
    66  <IfModule mime_module>
    67      TypesConfig conf/mime.types
    68      AddType application/x-compress .Z    #AddEncoding允许你在信息传送中使用(Mosaic/X 2.1+)解压缩信息。不是所有游览器的支持这个选项。
    69      AddType application/x-gzip .gz .tgz
    70  </IfModule>
    71  <IfModule proxy_html_module>
    72  Include conf/extra/proxy-html.conf
    73  </IfModule>
    74  <IfModule ssl_module>
    75  SSLRandomSeed startup builtin
    76  SSLRandomSeed connect builtin
    77  </IfModule>

四、虚拟主机配置文件

生产环境中,我们通常都要用到apache的扩展文件中的虚拟主机配置文件,它位于apache安装目录下的conf/extra/httpd-vhost.conf。注意,如果要让该配置文件的内容起作用,我们需要解锁apache主配置文件httpd.conf中扩展虚拟主机的配置行

[root@c64-web /]# grep httpd-vhost /usr/local/apache/conf/httpd.conf
#Include conf/extra/httpd-vhosts.conf   #将此行解锁即可

此处我们可以用一键解锁命令

[root@web apache]# sed -i 's#\#Include conf/extra/httpd-vhosts.conf#Include conf/extra/httpd-vhosts.conf#g' /usr/local/apache/conf/httpd.conf #使用sed命令一键替换
[root@web apache]# grep httpd-vhost /usr/local/apache/conf/httpd.conf  #查看替换结果
Include conf/extra/httpd-vhosts.conf

现在开始为大家讲解httpd-vhost.conf这个文件,我们依旧只显示解开注释的行默认配置文件会准备出来两个虚拟主机模板,此处我们仅拿一个做讲解,两者内容是相通的。

[root@c64-web apache]# egrep -v "^$|#" /usr/local/apache/conf/extra/httpd-vhosts.conf|cat -n
     1 <VirtualHost *:80>  #定义一个虚拟主机,监听本机所有IP地址80端口上提供的http服务请求
     2     ServerAdmin webmaster@dummy-host.example.com   #这里可以配置管理员的邮箱
     3     DocumentRoot "/usr/local/apache-2.4.6/docs/dummy-host.example.com"  #提供服务的程序目录,也称站点目录
     4     ServerName dummy-host.example.com #这是配置提供服务的域名,如www.baidu.com,如果是生产环境需要把www.baidu.com解析到服务器上配置的外网VIP或IP上。如果仅为测试,可以直接在本机上做测试。
     5     ServerAlias www.dummy-host.example.com  #这是配置虚拟主机的别名,也就是可以配置多个域名访问同一站点,如此处配置baidu.com后,当输入baidu.com可以得到和www.baidu.com同样的结果。此功能需要apache mod_alias模块支持。
     6     ErrorLog "logs/dummy-host.example.com-error_log"  #这里可以配置apache错误日志的路径。错误日志是调试apache的一个非常重要的日志。有什么错误信息这里一般都会有记录。
     7     CustomLog "logs/dummy-host.example.com-access_log" common #访问日志配置。在生产环境中,我们一般用combined格式替代common格式,以获取更多的日志格式输出。
     8 </VirtualHost>    #这是一个虚拟主机的结尾,如果需要添加新的虚拟主机,则可以增加<VirtualHost></VirtualHost>即可
     9
    10     ServerAdmin webmaster@dummy-host2.example.com
    11     DocumentRoot "/usr/local/apache-2.4.6/docs/dummy-host2.example.com"
    12     ServerName dummy-host2.example.com
    13     ErrorLog "logs/dummy-host2.example.com-error_log"
    14     CustomLog "logs/dummy-host2.example.com-access_log" common
    15 </VirtualHost>

到这里本篇博文就结束了,相信对于编译参数,apache目录结构,主配置文件和虚拟主机配置文件的内容,大家已经了然于心了。下一篇将是非常重要的针对生产环境的apache的调优介绍了。希望能帮助到大家。

转自:http://nolinux.blog.51cto.com/4824967/1320167

原创文章,作者:s19930811,如若转载,请注明出处:http://www.178linux.com/2013

(1)
上一篇 2016-08-15 12:12
下一篇 2016-08-15 12:12

相关推荐

  • select循环解析

    前言:   select命令用于创建菜单,在select循环执行时会根据list数组给出选择菜单,用户选择后的结果保存在变量中,然后给出菜单,等待用户选择。select是个死循环,如果用户用户想跳出选择循环,需要在循环体中根据条件增加break语句。 格式: select variable in list do 循环体命令 done 示例: 在这个…

    Linux干货 2016-08-24
  • 高级文件系统管理之mdadm与lvm的创建

    ※配置配额系统 磁盘配额就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间,比如一些网盘就是基于这个功能来做的,分配给用户固定的空间,花钱买,可以将空间设置的更大。 功能作用 磁盘配额可以限制指定账户能够使用的磁盘空间,这样可以避免因某个用户的过度的使用磁盘空间造成其它用户无法运行或工作甚至影响系统运行。这个功能不止…

    Linux干货 2016-08-27
  • 程序包管理:rpm、yum以及(make)源代码编译安装

    程序包管理:rpm、yum以及(make)源代码编译安装 在Linux上安装程序一般都有三种方法:源代码编译安装,rpm包安装和rpm包的前端安装yum, (rpm,和yum程序包管理器是针对CentOS6平台的) 程序包管理方式都大同小异:  源代码–>目标二进制格式(二进制程序、库文件、配置文件、帮助文件)–&gt…

    Linux干货 2017-01-10
  • Mariadb基于ssl的主从复制

    Mariadb基于ssl的主从复制 一、前言 备份数据库是生产环境中的首要任务,重中之重。一般配置中mariadb的主从传输是明文传输,但是有时候对一些特殊业务来说是不允许的,为了保证数据在传输过程中的安全性,因此使用基于SSL的复制会大大加强数据的安全性。 二、准备工作 1、实验系统环境: CentOS7.2,SELinux关闭,iptables关闭,安装…

    Linux干货 2017-02-24
  • N25-第九周作业

    第九周 1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash # sum_login=0 sum_nologin=0 for i in $(awk -F: ‘{print $7}’ /etc/passwd);do if…

    Linux干货 2017-03-10
  • 显示历史命令时间

        历史命令中默认是不显示时间的,如果我们想要在使用history命令时显示时间可以通过设置环境变量来实现。     HISTTIMEFORMAT变量的具体参数与date命令中的类似,可以参数date命令的对日期时间格式时行修改。    &nbs…

    Linux干货 2015-05-02