Apache Options指令详解

前言:Options指令是Apache配置文件中一个比较常见也比较重要的指令,Options指令可以在Apache服务器核心配置(server config)、虚拟主机配置(virtual host)、特定目录配置(directory)以及.htaccess文件中使用。Options指令的主要作用是控制特定目录将启用哪些服务器特性。

Options指令常见的配置示例代码如下:
<Directory "/home/www">
    #指定根目录/home/www启用Indexes、FollowSymLinks两种特性
    Options Indexes FollowSymLinks
    AllowOverride all
    Require all granted
</Directory>
Options服务器特性

Options指令的完整语法为:Options [+|-]option [[+|-]option];简而言之,Options指令后可以附加指定多种服务器特性,特性选项之间以空格分隔。下面我们来看看Options指令后可以附加的特性选项的具体作用及含义(Apache配置中的内容均不区分大小写):

1、All

表示除MultiViews之外的所有特性(这也是Options指令的默认设置)

2、None

表示不启用任何的服务器特性

服务器允许在此目录中使用符号连接(如果该配置选项位于配置段中,将会被忽略)

4、Indexes

如果输入的网址对应服务器上的一个文件目录,而此目录中又没有DirectoryIndex指令(例如:DirectoryIndex index.html index.php),那么服务器会返回由mod_autoindex模块生成的一个格式化后的目录列表,并列出该目录下的所有文件(如下图)

directory

4、MultiViews

允许使用mod_negotiation模块提供内容协商的”多重视图”。简而言之,如果客户端请求的路径可能对应多种类型的文件,那么服务器将根据客户端请求的具体情况自动选择一个最匹配客户端要求的文件。例如,在服务器站点的file文件夹下中存在名为hello.jpg和hello.html的两个文件,此时用户输入Http://localhost/file/hello,如果在file文件夹下并没有hello子目录,那么服务器将会尝试在file文件夹下查找形如hello.*的文件,然后根据用户请求的具体情况返回最匹配要求的hello.jpg或者hello.html

5、SymLinksIfOwnerMatch

服务器仅在符号连接与目标文件或目录的所有者具有相同的用户ID时才使用它。简而言之,只有当符号连接和符号连接指向的目标文件或目录的所有者是同一用户时,才会使用符号连接(如果该配置选项位于配置段中,将会被忽略)

6、ExecCGI

允许使用mod_cgi模块执行CGI脚本

7、Includes

允许使用mod_include模块提供的服务器端包含功能

8、IncludesNOEXEC

允许服务器端包含,但禁用”#exec cmd”和”#exec cgi”。但仍可以从ScriptAlias目录使用”#include virtual”虚拟CGI脚本

注意

此外,比较细心的读者应该注意到,Options指令语法允许在配置选项前加上符号”+”或者”-“,那么这到底是什么意思呢?

实际上,Apache允许在一个目录配置中设置多个Options指令。不过,一般来说,如果一个目录被多次设置了Options,则指定特性数量最多的一个Options指令会被完全接受(其它的被忽略),而各个Options指令之间并不会合并。但是如果我们在可选配置项前加上了符号”+”或”-“,那么表示该可选项将会被合并。所有前面加有”+”号的可选项将强制覆盖当前的可选项设置,而所有前面有”-“号的可选项将强制从当前可选项设置中去除。你可以参考下面的例子:

#示例1
<Directory /web/file>
    Options Indexes FollowSymLinks
</Directory>

<Directory /web/file/image>
    Options Includes
</Directory>
#目录/web/file/image只会被设置Includes特性
#示例2
<Directory /web/file>
    Options Indexes FollowSymLinks
</Directory>

<Directory /web/file/image>
    Options +Includes -Indexes
</Directory>
#目录/web/file/image将会被设置Includes、FollowSymLinks两种特性

备注1:混合使用前面带”+”/”-“和前面不带”+”/”-“的同一可选项,可能会导致出现意料之外的结果
备注2:使用-IncludesNOEXEC或-Includes时,不论前面如何设置,都会完全禁用服务器端包含

结束语:团队服务器配置需要,所以简单的研究了下apache的配置文件;本文纯属转载,感谢原博主(原文地址

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个使用Apache Beam Options的Python代码示例,用于将一个文本文件中的每行字符串转化为小写并输出到控制台: ```python import apache_beam as beam from apache_beam.options.pipeline_options import PipelineOptions, StandardOptions class LowercaseTextOptions(PipelineOptions): @classmethod def _add_argparse_args(cls, parser): parser.add_argument('--input', help='Input file') parser.add_argument('--output', help='Output file') # 定义一个将每行字符串转化为小写的DoFn class LowercaseFn(beam.DoFn): def process(self, element): return [element.lower()] def run(): # 创建一个PipelineOptions对象,并设置输入和输出文件路径 options = LowercaseTextOptions(['--input', 'gs://my-bucket/input.txt', '--output', 'gs://my-bucket/output.txt', '--runner', 'DataflowRunner']) # 创建一个Pipeline对象 with beam.Pipeline(options=options) as pipeline: # 读取文本文件 lines = pipeline | 'ReadFromText' >> beam.io.ReadFromText(options.input) # 将每行字符串转化为小写 lower_case_lines = (lines | 'Lowercase' >> beam.ParDo(LowercaseFn())) # 输出到文本文件 lower_case_lines | 'WriteToText' >> beam.io.WriteToText(options.output) if __name__ == '__main__': run() ``` 在上面的代码中,我们首先创建了一个继承自`PipelineOptions`的`LowercaseTextOptions`类,用于设置输入和输出文件路径。然后,我们定义了一个将每行字符串转化为小写的`LowercaseFn`函数,作为`ParDo`操作的参数。接着,我们创建了一个`Pipeline`对象,并使用`PipelineOptions`对象来配置数据处理流程。最后,我们使用`beam.io.ReadFromText`读取文本文件,使用`ParDo`操作将每行字符串转化为小写,并使用`beam.io.WriteToText`将结果输出到文本文件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值