工作,学习,生活,这里将会有一些记录. 备用域名:http://meisw.51099.com 注册 | 登陆
浏览模式: 标准 | 列表2012年07月的文章

Xen CentOS 5.5 vif0.0 received packet with own address as source address

用CentOS5.5构建的Xen domain-0突然发现连接不上网络。用ifup eth0一试,出现以下错误:

Device eth0 has different MAC address than expected, ignoring

把/etc/sysconfig/network-scripts/ifcfg-eth0里的HWADDR那一行comment out后,出现以下信息:

vif0.0 received packet with own address as source address

最后,把/etc/sysconfig/network-scripts/ifcfg-eth0里的

HWADDR=00:xx:xx:xx….
改成
MACADDR=00:xx:xx:xx…

再运行/etc/rc.d/init.d/network restart重启网络服务后,终于可以正常连接网络。

#之后,原来是想再现这个错误,却发现把MACADDR改回HWADDR也可以连接上网络

apache rewrite规则全攻略

大家好,今天51开源给大家介绍apache rewrite规则。apache的重写规则主要通过apache的mod_rewrite模块来实现。

(1) 认识规则重写

   规则重写就是Web服务器会改写客户机符合特定规则的URL,用于实现资源重定向。Apache中文手册中所言,Apache的mod_rewreit模块是提供了强大URL操作的杀手级模块。可以实现几乎所有你梦想的URL操作类型,但其复杂性让很多初学者望而止步,对于apache rewrite规则需要你长时间的实践与理解。手册中有句话,我觉得很有意思。“对于mod_rewrite,或者是打退堂鼓永不再用,或是喜欢它并一生受用。”真的,apache rewrite比你想象的更有用。apache rewrite的实用性和灵活性会让你对它痴迷,51开源给大家加气,不要退缩。

(2) 规则重写的配置命令

-rewriteengine  on/off

  设置apache是否启用重写引擎

  -rewriterule

  作用: 为重写引擎定义重写规则

  格式: rewriterule 正则表达式  替代字符串 [标记]

  正则表达式元字符:

          .           任意一个单字符

         [chars]     字符类: "chars"中的任意一个字符

         [^chars]    字符类: 不在"chars"中的字符

         text1|text2 选择: text1 或 text2

         ?           前面的字符出现 0 或 1 次

         *           前面的字符出现 0 或 N 次(N > 0)

         +           前面的字符出现 1 或 N 次(N > 1)

         ^           锚定到行首

         $           锚定到行尾

         \字符       转义字符

   标记: C  链接到下一条件规则

         F  强制禁止URL

         G  强制废弃URL

         L  结尾规则

         N  跳转到开头、从开再来

         NC 忽略大小写

         P  强制为代理

         R  强制为重定向

   实例:rewriterule ^/$    http://bbs.51osos.com [R,L]

        //对网站根目录的访问请求全转向http://bbs.51osos.com

   -rewritecond

   作用:定义重写发生的条件

   格式:rewritecond  字符串   正则表达式  [标记]

   字符串所包含一些特殊字符:

        a. $N  反向rewriterule中的分组

        b. %N  反向rewritecond中的分组

        c. 服务器变量

           %{HTTP_USER_AGENT}   客户机信息,包括操作系统和浏览器信息

           %{HTTP_HOST} 请求的主机名 

           %{REMOTE_ADDR}  客户机IP地址

           %{REMOTE_HOST}  客户机的主机名

           %{REMOTE_PORT}  客户机连接服务器所有端口

           %{REQUEST_METHOD}  客户机的请求方法

           %{REQUEST_FILENAME} 客户机的请求的文件名

           %{REQUEST_URI}  客户机请求URI

           %{DOCUMENT_ROOT} 服务器的站点主目录

           %{SERVER_NAME}  服务器的名称

           %{SERVER_ADDR}  服务器的IP地址

           %{SERVER_PORT}  服务器的端口号

    特殊比较符号:

          <  小于

          >  大于

          =  等于

          -d  判断是不是存在的目录

          -f  判断是不是存在的普通文件

          -s  判断是不是为非空的普通文件

          -x  判断是不是为可执行的文件

          -l  判断是不是为链接文件

          -U  判断是不是有效的URL

      标记:

          -NC   忽略大小写

          -OR   或

      实例:rewritecond %{REMOTE_ADDR} ^192.168.3.1

    -rewritebase

  作用:设置目录级重写的基准URL

  格式:rewritebase  URL-PATH

   (3) 规则重写的应用案例

     -移动站点主目录到站点的/bbs路径下

     rewriteengine on

     rewriterule  ^/$    /bbs [R,L]

     -利用规则重写实现基于域名的虚拟主机

    RewriteEngine on

    RewriteCond   %{HTTP_HOST}    ^www\.abc\.com$

    RewriteRule   ^(.+)     %{HTTP_HOST}$1   [C]

    RewriteRule   ^www\.abc\.com(.*) /web/abc$1

 

    RewriteCond   %{HTTP_HOST}    ^www\.51osos \.com$

    RewriteRule   ^(.+)     %{HTTP_HOST}$1   [C]

    RewriteRule   ^www\.51osos\.com(.*) /web/51osos$1

“带宽”和“速度”的分别

 所谓 1M 宽带,其实是指 1Mbps (兆比特每秒),亦即 1 x 1024 / 8 = 128KB/sec,但这只是理论上的速度,实际上则要再扣约 12% 的信息头标识等各种控制讯号,故其传输速度上限应为 112KB/sec 左右。这里列出了各个速度单位之间的关系:1 Byte = 8 bits 1 Kb = 1024 bits 1 KB = 1024 bytes 1 Mb = 1024 Kb 1 MB = 1024 KB在这里要注意的是传输单位的写法上,B 和 b 分别代表 Bytes 和 bits,两者的定义是不同的,千万不要混淆了。

  所以各种宽带的极限下载值也可以轻易的计算出来。

  1 M =112 KB/s 2 M =225 KB/s 8 M =901 KB/s 10 M =1126 KB/s Mbps实际上是一个带宽单位,而非速度单位,在"Mbps"单位中的"b"是指"Bit(位)".而真正的速度单位应为MB/s,其中的"B"是指"Byte(字节)".因为数据是按字节传输的,而并非按位。

Nginx 并发连接数控制 Limit Zone Limit simultaneous connections

ngx_http_limit_zone_module

Limit Zone Limit simultaneous connections from a client.

本模块可以针对条件,进行会话的并发连接数控制。(例如:限制每个IP的并发连接数。)

__配置示例__

http { : limit_zone   one  $binary_remote_addr  10m;  : ...  : server {  : ...  : location /download/ { : limit_conn   one  1; : }

指令

  • [#limit_zone limit_zone]
  • [#limit_conn limit_conn]

 

limit_zone

语法: limit_zone zone_name $variable the_size

默认值: no

作用域: http

本指令定义了一个数据区,里面记录会话状态信息。
$variable 定义判断会话的变量;the_size 定义记录区的总容量。

例子:

limit_zone   one  $binary_remote_addr  10m;

定义一个叫“one”的记录区,总容量为 10M,以变量 $binary_remote_addr 作为会话的判断基准(即一个地址一个会话)。


您可以注意到了,在这里使用的是 $binary_remote_addr 而不是 $remote_addr。

$remote_addr 的长度为 7 至 15 bytes,会话信息的长度为 32 或 64 bytes。而 $binary_remote_addr 的长度为 4 bytes,会话信息的长度为 32 bytes。

当区的大小为 1M 的时候,大约可以记录 32000 个会话信息(一个会话占用 32 bytes)。


 

limit_conn

语法: limit_conn zone_name the_size

默认值: no

作用域: http, server, location

指定一个会话最大的并发连接数。当超过指定的最发并发连接数时,服务器将返回 "Service unavailable" (503)。

例子:

limit_zone   one  $binary_remote_addr  10m;  : server { : location /download/ { : limit_conn   one  1; : }

定义一个叫“one”的记录区,总容量为 10M,以变量 $binary_remote_addr 作为会话的判断基准(即一个地址一个会话)。限制 /download/ 目录下,一个会话只能进行一个连接。简单点,就是限制 /download/ 目录下,一个IP只能发起一个连接,多过一个,一律503。

原文:http://wiki.nginx.org/ChsHttpLimitZoneModule

substitutions4nginx

server
{ 
listen 205.105.100.110:80;
server_name www.baidu.net baidu.net;
sub_filter  'baidu.com'  'baidu.net';
sub_filter_once on;


location / { 
subs_filter_types text/html text/css text/xml text/javascript;
subs_filter baidu.com baidu.net;
proxy_set_header X-Real-IP $remote_addr; 
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
proxy_set_header Referer http://www.baidu.com[/url]; #强制定义Referer,程序验证判断会用到 
proxy_set_header Host www.baidu.com; #定义主机头,如果目标站点绑定的域名个server_name项的吻合则使用$host 
proxy_pass http://www.baidu.com; #指定目标,建议使用IP或者nginx自定义池 
proxy_redirect http://www.baidu.com [url]http://www.baidu.net; 
proxy_set_header Accept-Encoding ""; #清除编码 
} 
}

wget/curl测试gzip

Apache启用gzip/deflate或者Nginx启用gzip之后
用wget测试的话需要加上--header="accept-encoding:gzip"
用curl则加上--compressed or -H Accept-Encoding:gzip,defalte

关于gzip和deflate有两篇文章

http://blog.fulin.org/2009/01/deflate_and_gzip.html

http://blog.developers.api.sina.com.cn/?p=266

 

 

vsftpd yum 安装

vsftpd yum 安装,使用系统帐号

pam_service_name=vsftpd

Kickstart Options

Records:1212