在Nginx环境下,可以通过两种方式实现对flv文件的支持。
方式1,配置mime类型。
配置文件nginx.conf通常会加载一个定义mime类型的文件mime.types:
include mime.types;
此文件中配置了各种各样的mime类型。
其中对flv文件的设置如下:
video/x-flv flv;
方式2、安装flv模块。
这种方式需要重新编译nginx。
编译时,加上选项 --with-http_flv_module,然后在nginx.conf中开启该模块:
flv;
}
小编推荐:建议使用第一种方式。
先来看下虚拟主机的原理
虚拟主机名使用server_name指令定义,用于决定由某台虚拟主机来处理请求。
nginx以名字查找虚拟主机时,如果名字可以匹配多于一个主机名定义,比如同时匹配了通配符的名字和正则表达式的名字,那么nginx按照下面的优先级别进行查找,并选中第一个匹配的虚拟主机:
1,确切的名字;
2,最长的以星号起始的通配符名字:*.xxx.org;
3,最长的以星号结束的通配符名字:mail.*;
4,第一个匹配的正则表达式名字(按在配置文件中出现的顺序)。
**通配符名字只可以在名字的起始处或结尾处包含一个星号,并且星号与其他字符之间用点分隔。所以,“www.*.xxx.org”和“w*.xxx.org”都是非法的。
nginx使用的正则表达式兼容PCRE。
为了使用正则表达式,虚拟主机名必须以波浪线“~”起始:
server_name ~^www\d+\.xxx\.net$;
否则该名字会被认为是个确切的名字,如果表达式含星号,则会被认为是个通配符名字(而且很可能是一个非法的通配符名字)。不要忘记设置“^”和“$”锚点,语法上它们不是必须的,但是逻辑上是的。
注意:域名中的点“.”需要用反斜线“\”转义。含有“{”和“}”的正则表达式需要被引用,例如:
server_name "~^(?<name>\w\d{1,3}+)\.xxx\.net$";
否则nginx就不能启动,错误提示是:
directive "server_name" is not terminated by ";" in ...
PCRE使用下面语法支持命名捕获组:
<name> 从PCRE-7.0开始支持,兼容Perl 5.10语法
'name' 从PCRE-7.0开始支持,兼容Perl 5.10语法
P<name> 从PCRE-4.0开始支持,兼容Python语法
如果nginx不能启动,并显示错误信息:
pcre_compile() failed: unrecognized character after (?< in ...
说明PCRE版本太旧
如果以“$hostname”(nginx 0.9.4及以上版本)定义虚拟主机名,机器名将被使用。
nginx直到0.6.25版本还支持一个特殊的名字“*”,这个名字一直被错误地理解成是一个匹配所有的名字。但它从来没有像匹配所有的名字,或者通配符那样工作过,而是用来支持一种功能,此功能现在已经改由server_name_in_redirect指令提供支持了。所以,现在这个特殊的名字“*”已经过时了,应该使用server_name_in_redirect指令取代它。需要注意的是,使用server_name指令无法描述匹配所有的名字或者默认服务器。这是listen指令的属性,而不是server_name指令的属性。具体请参考《nginx如何处理一个请求》。可以定义两个服务器都监听*:80和*:8080端口,然后指定一个作为端口*:8080的默认服务器,另一个作为端口*:80的默认服务器:
listen 80;
listen 8080 default_server;
server_name xxx.net;
...
}
server {
listen 80 default_server;
listen 8080;
server_name xxx.org;
...
}
优化
确切名字和通配符名字存储在哈希表中。哈希表和监听端口关联。哈希表的尺寸在配置阶段进行了优化,可以以最小的CPU缓存命中失败来找到名字。
nginx首先搜索确切名字的哈希表,如果没有找到,搜索以星号起始的通配符名字的哈希表,如果还是没有找到,继续搜索以星号结束的通配符名字的哈希表。
因为名字是按照域名的节来搜索的,所以搜索通配符名字的哈希表比搜索确切名字的哈希表慢。注意特殊的通配符名字“.xxx.org”存储在通配符名字的哈希表中,而不在确切名字的哈希表中。
正则表达式是一个一个串行的测试,所以是最慢的,而且不可扩展。
鉴于以上原因,请尽可能使用确切的名字。举个例子,如果使用xxx.org和www.xxx.org来访问服务器是最频繁的,那么将它们明确的定义出来就更为有效:
listen 80;
server_name xxx.org www.xxx.org *.xxx.org;
...
}
以下方法相比更简单,但是效率也更低:
listen 80;
server_name .xxx.org;
...
}
如果定义了大量名字,或者定义了非常长的名字,那可能需要在http配置块中使用server_names_hash_max_size和server_names_hash_bucket_size指令进行调整。server_names_hash_bucket_size的默认值可能是32,或者是64,或者是其他值,取决于CPU的缓存行的长度。如果这个值是32,那么定义“too.long.server.name.xxx.org”作为虚拟主机名就会失败,而nginx显示下面错误信息:
could not build the server_names_hash,
you should increase server_names_hash_bucket_size: 32
出现了这种情况,那就需要将指令的值扩大一倍:
server_names_hash_bucket_size 64;
如果定义了大量名字,得到了另外一个错误:
you should increase either server_names_hash_max_size: 512
or server_names_hash_bucket_size: 32
那么应该先尝试设置server_names_hash_max_size的值差不多等于名字列表的名字总量。
如果还不能解决问题,或者服务器启动非常缓慢,再尝试提高server_names_hash_bucket_size的值。
如果只为一个监听端口配置了唯一的主机,那么nginx就完全不会测试虚拟主机名了(也不会为监听端口建立哈希表)。
不过,有一个例外,如果定义的虚拟主机名是一个含有捕获组的正则表达式,这时nginx就不得不执行这个表达式以得到捕获组。
兼容性
从0.8.48版本开始,默认的虚拟主机名是空名字“”。
从0.8.25版本开始,支持虚拟主机名中使用命名的正则表达式捕获组。
从0.7.40版本开始,支持虚拟主机名中使用正则表达式的捕获组。
从0.7.12版本开始,支持空名字“”。
从0.6.25版本开始,通配符和正则表达式名字可以作为第一个虚拟主机名。
从0.6.7版本开始,支持正则表达式的虚拟主机名。
从0.6.0版本开始,支持形如example.*的通配符名字。
从0.3.18版本开始,支持形如.example.org的特殊通配符名字。
从0.1.13版本开始,支持形如*.example.org的通配符名字。
配置
上文已经说过nginx匹配虚拟主机是从哈希表中查询的,所以,虚拟主机的配置如下。
{
listen 80; 端口
server_name www. www.xxx.cn; 虚拟主机名称
}
server
{
listen 80;
server_name donghua.;
}
在玩nginx的过程中,意识到:
对于站点中不经常修改的静态内容(如图片,JS,CSS),可以在服务器中设置expires过期时间,控制浏览器缓存,达到有效减小带宽流量,降低服务器压力的目的。
例如:
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {
#过期时间为30天,
#图片文件不怎么更新,过期可以设大一点,
#如果频繁更新,则可以设置得小一点。
expires 30d;
}
location ~ .*\.(js|css)$ {
expires 10d;
}
说明:
Expires是Web服务器响应消息头字段,在响应http请求时告诉浏览器在过期时间前浏览器可以直接从浏览器缓存取数据,而无需再次请求。
1、Cache-control策略
Cache-Control与Expires的作用一致,都是指明当前资源的有效期,控制浏览器是否直接从浏览器缓存取数据还是重新发请求到服务器取数据。只不过Cache-Control的选择更多,设置更细致,如果同时设置的话,其优先级高于Expires。
http协议头Cache-Control :
值可以是public、private、no-cache、no- store、no-transform、must-revalidate、proxy-revalidate、max-age
各个消息中的指令含义如下:
Private指示对于单个用户的整个或部分响应消息,不能被共享缓存处理。这允许服务器仅仅描述当用户的部分响应消息,此响应消息对于其他用户的请求无效。
no-cache指示请求或响应消息不能缓存
no-store用于防止重要的信息被无意的发布。在请求消息中发送将使得请求和响应消息都不使用缓存。
max-age指示客户机可以接收生存期不大于指定时间(以秒为单位)的响应。
min-fresh指示客户机可以接收响应时间小于当前时间加上指定时间的响应。
max-stale指示客户机可以接收超出超时期间的响应消息。如果指定max-stale消息的值,那么客户机可以接收超出超时期指定值之内的响应消息。
Last-Modified/If-Modified-Since
Last-Modified/If-Modified-Since要配合Cache-Control使用。
Last-Modified:标示这个响应资源的最后修改时间。web服务器在响应请求时,告诉浏览器资源的最后修改时间。
If-Modified-Since:当资源过期时(使用Cache-Control标识的max-age),发现资源具有Last-Modified声明,则再次向web服务器请求时带上头 If-Modified-Since,表示请求时间。
web服务器收到请求后,发现有头If-Modified-Since 则与被请求资源的最后修改时间进行比对。
若最后修改时间较新,说明资源又被改动过,则响应整片资源内容(写在响应消息包体内),HTTP 200;
若最后修改时间较旧,说明资源无新修改,则响应HTTP 304 (无需包体,节省浏览),告知浏览器继续使用所保存的cache。