md5sum命令详解
原文链接:https://blog.csdn.net/cbbbc/article/details/48563023
前言
在网络传输、设备之间转存、复制大文件等时,可能会出现传输前后数据不一致的情况。这种情况在网络这种相对更不稳定的环境中,容易出现。那么校验文件的完整性,也是势在必行的。
使用说明
md5sum命令用于生成和校验文件的md5值。它会逐位对文件的内容进行校验。是文件的内容,与文件名无关,也就是文件内容相同,其md5值相同。md5值是一个128位的二进制数据,转换成16进制则是32(128/4)位的进制值。
md5校验,有很小的概率不同的文件生成的md5可能相同。比md5更安全的校验算法还有SHA*系列的。
在网络传输时,我们校验源文件获得其md5sum,传输完毕后,校验其目标文件,并对比如果源文件和目标文件md5 一致的话,则表示文件传输无异常。否则说明文件在传输过程中未正确传输。
重要的选项:
-b 以二进制模式读入文件内容
-t 以文本模式读入文件内容
-c 根据已生成的md5值,对现存文件进行校验
--status 校验完成后,不生成错误或正确的提示信息,可以通过命令的返回值来判断。
使用举例
生成文件md5值
md5sum file
[root@master lianxi]# md5sum data 0a6de444981b68d6a049053296491e49 data
使用通配对多个文件进行md5
[root@master lianxi]# md5sum * 0a6de444981b68d6a049053296491e49 data 13df384c47dd2638fd923f60c40224c6 data2md5sum校验的是文件内容,与文件名无关
相同内容的文件的md5一样。如下我先对文件进行复制,然后对同内容不同名的文件进行md5,md5值一样
[root@master lianxi]# cp data data.bak [root@master lianxi]# ls data data.bak [root@master lianxi]# md5sum * 0a6de444981b68d6a049053296491e49 data 0a6de444981b68d6a049053296491e49 data.bak
以文本模式或二进制模式读入文件并对其进行校验
-b 以二进制模式读入内容
-t 以文本模式读入文件内容进行校验
虽然是不同的读入模式,但是在进行求md5的时候,是一样的,因为是逐位校验的。
如下文本文件,无论通过哪种模式读取md5都一致。
[root@master lianxi]# file data data: ASCII text [root@master lianxi]# md5sum data 0a6de444981b68d6a049053296491e49 data [root@master lianxi]# md5sum -b data 0a6de444981b68d6a049053296491e49 *data [root@master lianxi]# md5sum -t data 0a6de444981b68d6a049053296491e49 data
md5值重定向
将生成md5值重定向到指定的文件,通常文件的扩展名我们会命为.md5
[root@master lianxi]# md5sum data > data.md5 [root@master lianxi]# md5sum data 0a6de444981b68d6a049053296491e49 data [root@master lianxi]# cat data.md5 0a6de444981b68d6a049053296491e49 data
将多个文件的md5重定向到指定的文件
每个文件的md5生成为一行
[root@master lianxi]# ls data data.bak data.md5 d.md5 [root@master lianxi]# md5sum data* > d.md5 [root@master lianxi]# cat d.md5 0a6de444981b68d6a049053296491e49 data 0a6de444981b68d6a049053296491e49 data.bak 7: 0bd94658869c53cdcdf35a0f7de93e01 data.md5
重定向追加
这里新增文件ls,单独求其md5,将其md5追加到文件中
[root@master lianxi]# cp /bin/ls . [root@master lianxi]# ls data data.bak data.md5 d.md5 ls [root@master lianxi]# md5sum ls >> d.md5 [root@master lianxi]# cat d.md5 0a6de444981b68d6a049053296491e49 data 0a6de444981b68d6a049053296491e49 data.bak 0bd94658869c53cdcdf35a0f7de93e01 data.md5 c6337b20f3c159544bff5cf622391f9e ls
md5校验
-c选项来对文件md5进行校验。校验时,根据已生成的md5来进行校验。生成当前文件的md5,并和之前已经生成的md5进行对比,如果一致,则返回OK,否则返回错误信息
md5sum –c d.md5
1: [root@master lianxi]# md5sum -c d.md5 2: data: OK 3: data.bak: OK 4: data.md5: OK 5: ls: OK
修改文件后,文件md5变化
1: [root@master lianxi]# ls 2: data 3: [root@master lianxi]# md5sum data 4: 2360752c3368ca4f89169f5ecc06e383 data 5: [root@master lianxi]# md5sum data > data.md5 6: [root@master lianxi]# echo "lwg" >> data 7: [root@master lianxi]# md5sum data 8: 287d237083a42f09785daa46a5fa3afe data 9: [root@master lianxi]# md5sum -c data.md5 10: data: FAILED 11: md5sum: WARNING: 1 of 1 computed checksum did NOT match
--status,不显示校验信息,以命令返回值来判断
校验一致返回0,不一致返回1
1: [root@master lianxi]# md5sum -c data.md5 2: data: FAILED 3: md5sum: WARNING: 1 of 1 computed checksum did NOT match 4: [root@master lianxi]# md5sum -c --status data.md5 5: [root@master lianxi]# echo $? 6: 1
多个文件文件校验和grep连用
通过grep将正确的信息过滤掉
1: [root@master lianxi]# md5sum -c ../value.md5 2: acpid: OK 3: acpid.1: OK 4: anaconda.log: OK 5: anaconda.syslog: OK 6: anaconda.xlog: OK 7: boot.log: OK 8: boot.log.1: OK 9: ... 10: ... 11: 省略中间部分 12: ... 13: ... 14: yum.log.2: OK 15: md5sum: WARNING: 1 of 56 computed checksums did NOT match 1: [root@master lianxi]# md5sum -c ../value.md5 | grep -v OK 2: md5sum: WARNING: 1 of 56 computed checksums did NOT match 3: cron.1: FAILED
特殊说明
1)md5sum 是校验文件内容,与文件名是否相同无关
2)md5sum值逐位校验,所以文件越大,校验时间越长。
总结
通过md5sum来校验生成文件校验码,来发现文件传输(网络传输、复制、本地不同设备间的传输)异常造成的文件内容不一致的情况。
md5sum命令详解的更多相关文章
- linux命令学习笔记-md5sum 命令详解
前言 在网络传输.设备之间转存.复制大文件等时,可能会出现传输前后数据不一致的情况.这种情况在网络这种相对更 不稳定的环境中,容易出现.那么校验文件的完整性,也是势在必行的. 使用说明 md5sum命 ...
- 【转】linux命令详解:md5sum命令
[转]linux命令详解:md5sum命令 转自:http://blog.itpub.net/29320885/viewspace-1710218/ 前言 在网络传输.设备之间转存.复制大文件等时,可 ...
- linux shell 脚本攻略学习13--file命令详解,diff命令详解
一.file命令详解 find命令可以通过查看文件内容来找出特定类型的文件,在UNIX/ Linux系统中,文件类型并不是由文件扩展名来决定的(windows中却正是这么做的),file命令的目的是从 ...
- linux shell 脚本攻略学习8---md5校验,sort排序,uniq命令详解
一.校验与核实 目前最为出名的校验技术是md5sum和sha1sum,它们对文件内容使用相应的算法来生成校验和. 举例: amosli@amosli-pc:~/learn$ md5sum text.t ...
- linux shell 脚本攻略学习5---find命令详解
1.find命令详解 语法: find base_path#base_path可以是任何位置,find会从该位置向下找 实例: amosli@amosli-pc:~$ find /home/amosl ...
- 【转帖】linux sort,uniq,cut,wc,tr,xargs命令详解
linux sort,uniq,cut,wc,tr,xargs命令详解 http://embeddedlinux.org.cn/emb-linux/entry-level/201607/21-5550 ...
- Git初探--笔记整理和Git命令详解
几个重要的概念 首先先明确几个概念: WorkPlace : 工作区 Index: 暂存区 Repository: 本地仓库/版本库 Remote: 远程仓库 当在Remote(如Github)上面c ...
- linux yum命令详解
yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器.基於RPM包管理,能够从指定的服务器自动下载RP ...
- Linux下ps命令详解 Linux下ps命令的详细使用方法
http://www.jb51.net/LINUXjishu/56578.html Linux下的ps命令比较常用 Linux下ps命令详解Linux上进程有5种状态:1. 运行(正在运行或在运行队列 ...
随机推荐
- [XML123] XSLT
XSLT简介 http://www.w3school.com.cn/xsl/index.asp XSLT测试 http://www.veryhuo.com/down/html/54703.html
- mac 安装secureCRT
下载 http://www.xue51.com/mac/1632.html 会得到下面的文件: 打开dmg文件: 将SecureCRT移到Applications中,然后点击打开一次(重要): 然后打 ...
- ruby安装及webStorm配置SCSS
sass安装: 步骤:(window系统) 1.下载RubyInstaller(v2.4.3),运行安装,基本直接next安装,不过有个add to PATH的选项一定要勾选,这样就不用配置环境变量. ...
- Jmeter不同线程组之间的变量引用
用过LoadRunner的小伙伴应该知道,它的脚本主要分为三个部分,即Login,Action,End三个模块.Login中一般是“初始化”环境所用,而Action模块主要做一些诸如压测的动作.举个例 ...
- 笔记:iOS随机数与随机数据集
//0 到 N - 1 之间的随机整数 NSUInteger r = arc4random_uniform(N); //1 到 N 之间的随机整数 NSUInteger r = arc4random_ ...
- GCD死锁,及同步、异步、串行和并行队列组合情形
一.概述 1)队列用来存储代码任务,线程用来运行代码任务: 2)main()函数作为程序入口,整个程序默认运行在主线程中,程序代码任务默认存放在主队列中: 3)以下所谓阻塞线程是针对主线程而言(子 ...
- ThreadLocal理解
ThreadLocal 概述 ThreadLocal实例仅作为线程局部变量的==操作类==,以及==线程存储局部变量时的Key==.真正的线程局部变量是存储在各自线程的本地,通过Thread类中的Th ...
- #leetcode刷题之路36-有效的数独
判断一个 9x9 的数独是否有效.只需要根据以下规则,验证已经填入的数字是否有效即可.数字 1-9 在每一行只能出现一次.数字 1-9 在每一列只能出现一次.数字 1-9 在每一个以粗实线分隔的 3x ...
- MariaDB中文乱码之解决思路
首先出现乱码的原因就是编码不一致问题引起的,那么就从以下2个方面入手: 1.应用层:前提条件数据库服务端存储的中文数据是对的,但是页面上显示乱码,这里只需要检查你的项目的编码格式,设置成一致就行. 2 ...
- 文本处理三剑客之 awk
GAWK:报告生成器,格式化文本输出 awk [options] ‘program’ var=value file… awk [options] -f programfile var=value fi ...