Linux下 数据文件 效验问题

2024-04-04 03:32

本文主要是介绍Linux下 数据文件 效验问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

       Linux 下,不同服务器之前的数据copy是很常见的操作。 常见的copy命令有scp cp 但是对于一些重要的文件,如数据库的备份文件,在copy之后,我们还需要对copy之后的文件进行一下效验, 以免在copy过程中的丢失。 造成无法恢复数据。

 

常见的效验有如下2种方式:

 

1. 比较文件大小

ll或者ls 命令分别查看一下copy之前和copy之后的文件大小。

[root@singledb backup]# ll

total 639820

-rw-r----- 1 oracle oinstall  18150400 Dec  7 19:50 arch_0hluu1q6_1_1_20101207

-rw-r----- 1 oracle oinstall   9810432 Dec  7 19:50 arch_0iluu1q7_1_1_20101207

-rw-r----- 1 oracle oinstall     32256 Dec  7 19:50 arch_0jluu1qu_1_1_20101207

-rw-r----- 1 oracle oinstall  15335424 Dec  7 19:50 ctl_file_0kluu1sf_1_1_20101207

-rw-r----- 1 oracle oinstall 371933184 Dec  7 19:54 orcl_0eluu1aa_1_1_20101207

-rw-r----- 1 oracle oinstall 223895552 Dec  7 19:56 orcl_0fluu1ac_1_1_20101207

-rw-r----- 1 oracle oinstall  15335424 Dec  7 19:56 orcl_0gluu1ks_1_1_20101207

[root@singledb backup]# ls -lrt

total 639820

-rw-r----- 1 oracle oinstall  18150400 Dec  7 19:50 arch_0hluu1q6_1_1_20101207

-rw-r----- 1 oracle oinstall     32256 Dec  7 19:50 arch_0jluu1qu_1_1_20101207

-rw-r----- 1 oracle oinstall   9810432 Dec  7 19:50 arch_0iluu1q7_1_1_20101207

-rw-r----- 1 oracle oinstall  15335424 Dec  7 19:50 ctl_file_0kluu1sf_1_1_20101207

-rw-r----- 1 oracle oinstall 371933184 Dec  7 19:54 orcl_0eluu1aa_1_1_20101207

-rw-r----- 1 oracle oinstall 223895552 Dec  7 19:56 orcl_0fluu1ac_1_1_20101207

-rw-r----- 1 oracle oinstall  15335424 Dec  7 19:56 orcl_0gluu1ks_1_1_20101207

 

 

2. 使用md5sum命令

2.1  MD5 效验介绍

  MD5的全称是Message-Digest Algorithm 5,在90年代初由MIT的计算机科学实验室和RSA Data Security Inc发明,经MD2MD3MD4发展而来。

  Message-Digest泛指字节串(Message)Hash变换,就是把一个任意长度的字节串变换成一定长的大整数。这种变换只与字节的值有关,与字符集或编码方式无关。

  MD5将任意长度的“字节串”变换成一个128bit的大整数,并且它是一个不可逆的字节串变换算法,换句话说就是,即使你看到源程序和算法描述,也无法将一个MD5的值变换回原始的字符串,从数学原理上说,是因为原始的字节串有无穷多个,这有点象不存在反函数的数学函数。

   MD5的典型应用是对一段Message(字节串)产生fingerprint(指纹),以防止被“篡改”。举个例子,你将一段话写在一个叫 readme.txt文件中,并对这个readme.txt产生一个MD5的值并记录在案,然后你可以传播这个文件给别人,别人如果修改了文件中的任何内容,你对这个文件重新计算MD5时就会发现。如果再有一个第三方的认证机构,用MD5还可以防止文件作者的“抵赖”,这就是所谓的数字签名应用。

  MD5还广泛用于加密和解密技术上,在很多操作系统中,用户的密码是以MD5值(或类似的其它算法)的方式保存的, 用户Login的时候,系统是把用户输入的密码计算成MD5值,然后再去和系统中保存的MD5值进行比较,而系统并不“知道”用户的密码是什么。

  一些黑客破获这种密码的方法是一种被称为“跑字典”的方法。有两种方法得到字典,一种是日常搜集的用做密码的字符串表,另一种是用排列组合方法生成的,先用MD5程序计算出这些字典项的MD5值,然后再用目标的MD5值在这个字典中检索。

  即使假设密码的最大长度为8,同时密码只能是字母和数字,共26+26+10=62个字符,排列组合出的字典的项数则是P(62,1)+P (62,2).+P(62,8),那也已经是一个很天文的数字了,存储这个字典就需要TB级的磁盘组,而且这种方法还有一个前提,就是能获得目标账户的密码MD5值的情况下才可以。

  

 

2.2 一个简单的演示:

 

[root@singledb backup]# which md5sum

/usr/bin/md5sum

 

创建一个文件

[root@singledb backup]# touch tianlesoftware.dba

 

查看MD5

[root@singledb backup]# md5sum tianlesoftware.dba                

d41d8cd98f00b204e9800998ecf8427e  tianlesoftware.dba

 

MD5值保存到某个文件

[root@singledb backup]# md5sum tianlesoftware.dba  > tianlesoftware.md5

 

修改tianlesoftware.dba 文件

[root@singledb backup]# cat tianlesoftware.dba

I AM DBA!

 

查看修改之后的MD5

[root@singledb backup]# md5sum tianlesoftware.dba

f040ad46d094e8295533585474d33b50  tianlesoftware.dba

 

他们的值不一样了,从这个值,可以判断文件有没有变化。

 

关于MD5SUM命令的更多用法,参考帮助:

[root@singledb backup]# man md5sum

MD5SUM(1)                        User Commands                       MD5SUM(1)

 

NAME

       md5sum - compute and check MD5 message digest

 

SYNOPSIS

       md5sum [OPTION] [FILE]...

 

DESCRIPTION

       Print  or  check  MD5  (128-bit)  checksums.  With no FILE, or when FILE is -, read

       standard input.

 

       -b, --binary

              read in binary mode

 

       -c, --check

              read MD5 sums from the FILEs and check them

 

       -t, --text

              read in text mode (default)

 

   The following two options are useful only when verifying checksums:

       --status

              don’t output anything, status code shows success

 

       -w, --warn

              warn about improperly formatted checksum lines

 

       --help display this help and exit

 

       --version

              output version information and exit

 

       The sums are computed as described in RFC 1321.  When checking, the input should be

       a  former  output of this program.  The default mode is to print a line with check-

       sum, a character indicating type (‘*’ for binary, ‘ ’ for text), and name for  each

       FILE.

 

AUTHOR

       Written by Ulrich Drepper, Scott Miller, and David Madore.

 

REPORTING BUGS

       Report bugs to <bug-coreutils@gnu.org>.

 

COPYRIGHT

       Copyright © 2006 Free Software Foundation, Inc.

       This  is  free  software.  You may redistribute copies of it under the terms of the

       GNU General Public License  <http://www.gnu.org/licenses/gpl.html>.   There  is  NO

       WARRANTY, to the extent permitted by law.

 

SEE ALSO

       The  full  documentation for md5sum is maintained as a Texinfo manual.  If the info

       and md5sum programs are properly installed at your site, the command

 

              info md5sum

 

       should give you access to the complete manual.

 

md5sum 5.97                        July 2009                         MD5SUM(1)

[root@singledb backup]#

 

 

 

 

 

------------------------------------------------------------------------------

QQ:492913789

Email:ahdba@qq.com

Blog: http://www.cndba.cn/dave 


网上资源: http://tianlesoftware.download.csdn.net

相关视频:http://blog.csdn.net/tianlesoftware/archive/2009/11/27/4886500.aspx

DBA1 群:62697716(); DBA2 群:62697977()

DBA3 群:62697850   DBA 超级群:63306533;    

聊天 群:40132017

--加群需要在备注说明Oracle表空间和数据文件的关系,否则拒绝申请

这篇关于Linux下 数据文件 效验问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/874690

相关文章

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

在Linux终端中统计非二进制文件行数的实现方法

《在Linux终端中统计非二进制文件行数的实现方法》在Linux系统中,有时需要统计非二进制文件(如CSV、TXT文件)的行数,而不希望手动打开文件进行查看,例如,在处理大型日志文件、数据文件时,了解... 目录在linux终端中统计非二进制文件的行数技术背景实现步骤1. 使用wc命令2. 使用grep命令

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM