httpd配置文件详解
#vim /etc/etc/httpd/conf/httpd.conf
1、监听套接字
Listen [IP:]port
此指令可以出现多次, 用于指定监听多个不同的套接字:
Listen 80
Listen 172.16.100.7:8080
data:image/s3,"s3://crabby-images/cf795/cf7958588bd78a92e90a942b6c49c99ace2dffcc" alt="1侦听套接字.png bubuko.com,布布扣"
2、 配置使用keep alive(生存活跃时间)
KeepAlive {On|Off}
KeepAliveTimeout 2
MaxKeepAliveRequests 50
data:image/s3,"s3://crabby-images/b0174/b017496c26a4830d7804ba977a37677799e8fcfe" alt="2 配置keepalive.png bubuko.com,布布扣"
3、 MPM
<IfModule prefork.c>
StartServers: 默认启动的工作进程数;
MinSpareServers: 最少空闲进程数;
MaxSpareServers: 最大空闲进程数;
ServerLimit: 最大活动进程数;
MaxClients: 并发请求的最大数;
MaxRequestsPerChild: 每个子进程在生命周期内所能够服务的最多请求个数;
data:image/s3,"s3://crabby-images/b3ff8/b3ff89d6cee1d2c5d387a41ee1195571b2615d2c" alt="3prefork模型参数.png bubuko.com,布布扣"
</IfModule>
<IfModule worker.c>
StartServers:启动的子进程的个数
MaxClients: 并发请求的最大数;
MinSpareThreads:最小空闲线程数;
MaxSpareThreads:最大空闲线程数;
ThreadsPerChild:每个子进程可生成的线程数;
MaxRequestsPerChild:每个子进程在生命周期内所能够服务的最多请求个数,0表示不限定;
</IfModule>
data:image/s3,"s3://crabby-images/3fc69/3fc696c1cf3b816a8ca8e5202d2c4eac948f7b74" alt="4worker模型.png bubuko.com,布布扣"
4、DSO模块加载方式
LoadModule module_name /path/to/module
如果使用相对路径,则对于ServerRoot所定义的位置而言;例如:
LoadModule php5_module /usr/lib64/httpd/modules/php5.so
让服务重载配置文件方能生效;
httpd -M: 列出已经装载的所有DSO及非DSO模块
httpd -l: 列出支持使用的非DSO模块
data:image/s3,"s3://crabby-images/0fdaa/0fdaac6b5a1d4bfcac5755e36fb4e7d29aa16a27" alt="5LoadModule加载DSO模块.png bubuko.com,布布扣"
5、 配置站点根补录
data:image/s3,"s3://crabby-images/e3282/e3282fc25f48c651c76be9fa4b0680d8c14207e8" alt="6DocumentRoot站点根目录.png bubuko.com,布布扣"
6 配置网页访问属性
<Direcotry "/path/to/somewhere">
Options:
Indexes: 缺少指定的默认页面时,允许将目录中的所有文件以列表形式返回给用户;危险;
FollowSymLinks: 允许跟随符号链接所指向的原始文件;
None: 所有都启用;
All: 所有都启用;
ExecCGI: 允许使用mod_cgi模块执行CGI脚本;
Includes: 允许使用mod_include模块实现服务器端包含(SSI);
MultiViews:允许使用mod_negotiation实现内容协商;
SymLinksIfOwnerMatch:在链接文件属主属组与原始文件的属主属组相同时,允许跟随符号链接所指向 的原始文件;
<Directory>
data:image/s3,"s3://crabby-images/ba4b1/ba4b117e6106f20fa729d6973626b8c69d3a28d8" alt="7 配置页面访问属性.png bubuko.com,布布扣"
7、 基于主机的访问控制
<Direcotry "/path/to/somewhere">
Options
AllowOverride None
Order Deny,Allow
Allow
Deny
<Directory>
最佳匹配:从列表中找出最小的能匹配到访问者的地址的条目为最终生效的;
Allow from
Deny from
IP, Network Address
172.16
172.16.0.0
172.16.0.0/16
172.16.0.0/255.255.0.0
data:image/s3,"s3://crabby-images/2ae17/2ae17a04d368a5fdc135685999edb93fd006a623" alt="8 基于主机的访问控制.png bubuko.com,布布扣"
8、 定义默认主页面
DirectoryIndex index.php index.html home.html default.html
data:image/s3,"s3://crabby-images/f464d/f464d816da08cdb71d74fc25945f2061f962fd0d" alt="9 设置默认路径.png bubuko.com,布布扣"
9、用户目录
如果期望让每个用户都可以创建个人站点:http://Server_IP/~Username/
userdir disabled: 禁止
userdir public_html
public_html是用户家目录下的目录名称,所有位于此目录中的文件均可通过前述的访问路径进行访问
用户的家目录得赋予运行httpd进程的用户拥有执行权限;
data:image/s3,"s3://crabby-images/b5571/b557157b1c9d168fad916906063e0ed2e7e05e75" alt="10 用户家目录.png bubuko.com,布布扣"
10、配置日志功能
/var/log/httpd/
access.log: 访问日志,其需要记录的内容需要自定义
error.log: 错误日志
访问日志:
CustomLog "/path/to/access_log_file" Format_Name
LogFormat Format_String Format_Name
%h: 客户端地址
%l: 远程登录名,通常为-
%u: 认证时的远程用户名,没有认证时为-
%t: 收到请求时的时间;
%r: 请求报文的起始行;
%>s: 响应状态码;
%b: 响应报文的长度,单位为字节
%{Header_Name}i: 记录指定请求报文首部的内容(value);
data:image/s3,"s3://crabby-images/bef46/bef46f1d96d8e169e0d5d65dc2c6593a7343cc68" alt="11 日志配置.png bubuko.com,布布扣"
11、 路径别名
Alias /alias/ "/path/to/somewhere"
意味着访问http://Server_IP/alias/时,其页面文件来自于/path/to/somewhere这个位置;
data:image/s3,"s3://crabby-images/d75dc/d75dc856990fd7543ccded9183c63b41e23327d7" alt="12 路径别名配置.png bubuko.com,布布扣"
12、设置默认字符集
AddDefaultCharset
data:image/s3,"s3://crabby-images/f2c6d/f2c6d66d3d780eee5d6d38f103f3d69cd6b7cee0" alt="13 设置默认子附近UTF8.png bubuko.com,布布扣"
13、CGI脚本路径别名
CGI路径 /var/www/cgi-bin
URL --> FileSystem Directory
CGI: Common Gateway Interface协议
Content-Type: text/html 文本类型为text/html
14、 基于用户的访问控制
虚拟用户:
文件:/etc/httpd/conf/.htpasswd
认证类型(auth):
basic: 基本认证,帐号和密码明文发送;
digest:摘要认证,hash编程之后发送;
认证提供者(authentication provider):帐号和密码的存放位置
authn
授权机制(authorization):根据什么进行授权
15、虚拟主机
一个物理服务器提供多个站点; 使用虚拟主机得先取消中心主机
Web: Socket(IP, port)
基于不同的IP实现不同的虚拟主机
变化IP
基于不同的port实现不同的虚拟主机
变化port
基于不同的FQDN实现不同的虚拟主机
变化ServerName的值
NameVirtualHost *:80
<virtualhost IP:port>
ServerName
DocumentRoot ""
<Directory "">
Options
</Directory>
ServerAlias
ServerAdmin
</virtualhost>
虚拟主机的单独配置:
用户认证
访问日志
错误日志
别名
脚本别名
=======================未完==============================================
PS:后续还有
本文出自 “西风瘦猪” 博客,请务必保留此出处http://jungege.blog.51cto.com/4102814/1379733
httpd协议详解(二),布布扣,bubuko.com
httpd协议详解(二)
原文:http://jungege.blog.51cto.com/4102814/1379733