Your Ad Here
首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 冲浪宝典 > 网络资源 > RAID5的校验方式(XOR)[ZT]
【标  题】:RAID5的校验方式(XOR)[ZT]
【关键字】:RAID5,XOR,ZT
【来  源】:http://www.cublog.cn/u/21848/showart.php?id=169960

RAID5的校验方式(XOR)[ZT]

Your Ad Here

1  RAID5的校验方式(XOR)

XOR(Exclusive OR)的校验原理如下表:


这里的A与B值就代表了两个位,从中可以发现,A与B一样时,XOR结果为0,A与B不一样时,XOR结果就是1,而且知道XOR结果和A与B中的任何一个数值,就可以反推出另一个数值。比如A为1,XOR结果为1,那么B肯定为0,如果XOR结果为0,那么B肯定为1。这就是XOR编码与校验的基本原理。

 

 

2  奇偶校验:

 

串行数据在传输过程中,由于干扰可能引起信息的出错,例如,传输字符‘E’,其各位为:

0100,0101=45H

D7 D0

由于干扰,可能使位变为1,这种情况,我们称为出现了“误码”。我们把如何发现传输中的错误,叫“检错”。发现错误后,如何消除错误,叫“纠错”。

最简单的检错方法是“奇偶校验”,即在传送字符的各位之外,再传送1位奇/偶校验位。可采用奇校验或偶校验。

奇校验:所有传送的数位(含字符的各数位和校验位)中,“1”的个数为奇数,如:

1 0110,0101

0 0110,0001

偶校验:所有传送的数位(含字符的各数位和校验位)中,“1”的个数为偶数,如:

1 0100,0101

0 0100,0001

 

奇偶校验能够检测出信息传输过程中的部分误码(1位误码能检出,2位及2位以上误码不能检出),同时,它不能纠错。在发现错误后,只能要求重发。但由于其实现简单,仍得到了广泛使用。

有些检错方法,具有自动纠错能力。如循环冗余码(CRC)检错等。

 

 

   3  CRC校验码:

CRC校验码的基本思想是利用线性编码理论, 在发送端根据要传送的k位二进制码序列,以一定的规则产生一个校验用的监督码(既CRC码)r位,并附在信息后边,构成一个新的二进制码序列数共(k+r)位,最后发送出去。在接收端,则根据信息码和CRC码之间所遵循的规则进行检验,以确定传送中是否出错。
    在数据存储和数据通讯领域,CRC无处不在:著名的通讯协议X.25的FCS(帧检错序列)采用的是CRC. CCITT,ARJ、LHA等压缩工具软件采用的是CRC32,磁盘驱动器的读写采用了CRC16,通用的图像存储格式GIF、TIFF等也都用CRC作为检错手段。
    CRC的本质是模-2除法的余数,采用的除数不同,CRC的类型也就不一样。通常,CRC的除数用生成多项式来表示。最常用的CRC码的生成多项式有CRC16,CRC32.

    以CRC16为例,16位的CRC码产生的规则是先将要发送的二进制序列数左移16位(既乘以2^16)后,再除以一个多项式,最后所得到的余数既是CRC码,如下式所示,其中K(X)表示n位的二进制序列数,G(X)为多项式,Q(X)为整数,R(X)是余数(既CRC码)。
K(X)>>16=G(x)Q(x)+R(x)
    求CRC码所采用模2加减运算法则,既是不带进位和借位的按位加减,这种加减运算实际上就是逻辑上的异或运算,加法和减法等价,乘法和除法运算与普通代数式的乘除法运算是一样,符合同样的规律。生成CRC码的多项式如下,其中CRC-16和CRC-CCITT产生16位的CRC码,而CRC-32则产生的是32位的CRC码
    接收方将接收到的二进制序列数(包括信息码和CRC码)除以多项式,如果余数为0,则说明传输中无错误发生,否则说明传输有误,关于其原理这里不再多述。用软件计算CRC码时,接收方可以将接收到的信息码求CRC码,比较结果和接收到的CRC码是否相同。
    CCITT推荐的高级数据链路控制规程HDLC的帧校验序列FCS中,使用CCITT-16即CRC16,其生成多项式为G(x)=x16+x12+x5+1, CRC-32的生成多项式为G(x)=x32+x26+x23+x22+x16+x1
1+x10+x16+x8+x7+x5+x4+x2+x+1

OracleCluster_RAID的种类:【上一篇】
EXP IMP导入/导出详细[ZT]:【下一篇】
【相关文章】
  • HTTP协议的作用原理 [ZT]
  • Linux 文件压缩工具指南(ZT)
  • (ZT)bash入门教程
  • (ZT)TCSH入门教程
  • (ZT)About Shell
  • 如何记录键盘操作--ZT
  • 内核_.config 内核配置[ZT]--make menuconfig
  • 内核_如何加载自己写的模块[ZT]
  • 编程_何为glibc?[ZT]
  • 内核_几个重要的RedHat Linux内核文件介绍[ZT]
  • 【随机文章】
  • 一个DataGrid多次绑定不同数据的时候我的用法
  • mqsql数据库中如何查看表结构
  • 看到短信想爆笑:D)
  • 2005年1月19日 工作中的组织与协调很重要
  • Linux信号简介
  • 【性能技巧】使用DataReader[列序号]的方法读取DataReader对象
  • 一个改变最后选中datagrid的Color的javascript
  • 播放自定义的声音
  • VB在ACADWIN 中的使用
  • 连接件的排序(冒泡、归并)
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 软讯网络 All Rigths Reserved.