데이터 베이스 MySQL 튜토리얼 SQL Server 数据库备份和还原认识和总结(一)

SQL Server 数据库备份和还原认识和总结(一)

Jun 07, 2016 pm 05:49 PM
데이터베이스 백업

SQL Server 数据库备份和还原认识和总结(一) ,SQL Server 2012对数据库备份和还原与SQL Server 2008基本没有太大变化,仅对还原时间点选择UI和相关还原选项做了小改动,备份和还原核心没有做变化,这只是个人的掌握和了解,

可能许多同学对SQL Server的备份和还原有一些了解,也可能经常使用备份和还原功能,我相信除DBA之外我们大部分开发员队伍对备份和还原只使用最基础的功能,对它也只有一个大概的认识,如果对它有更深入的认识,了解它更全面的功能岂不是更好,到用时会得心应手。因为经常有中小型客户公司管理人员对数据库不了解或掌握不牢,会请我们技术人员出马找回丢失的数据或硬件损坏移动数据的现象,或其它情况的发生。

    首先从数据库【恢复模式】说起,因为数据库如果恢复模式设置不正确,会导致数据无法还原。

    SQL Server 2012对数据库备份和还原与SQL Server 2008基本没有太大变化,仅对还原时间点选择UI和相关还原选项做了小改动,备份和还原核心没有做变化,这只是个人的掌握和了解,仅供参考,具体还请以官方文档为依据。以下利用SQL Server 2012 SSMS(SQL Server Management Studio)做图例演示。

    SQL Server 2008数据库恢复模式分为三种:完整恢复模式、大容量日志恢复模式、简单恢复模式。

    ◆ 完整恢复模式。为默认恢复模式。它会完整记录下操作数据库的每一个步骤。使用完整恢复模式可以将整个数据库恢复到一个特定的时间点,这个时间点可以是最近一次可用的备份、一个特定的日期和时间或标记的事务。

    ◆ 大容量日志恢复模式。它是对完整恢复模式的补充。简单地说就是要对大容量操作进行最小日志记录,节省日志文件的空间(如导入数据、批量更新、SELECT INTO等操作时)。比如一次在数据库中插入数十万条记录时,在完整恢复模式下每一个插入记录的动作都会记录在日志中,使日志文件变得非常大,在大容量日志恢复模式下,只记录必要的操作,不记录所有日志,这样一来,可以大大提高数据库的性能,但是由于日志不完整,一旦出现问题,数据将可能无法恢复。因此,一般只有在需要进行大量数据操作时才将恢复模式改为大容量日志恢复模式,数据处理完毕之后,马上将恢复模式改回完整恢复模式。

    ◆ 简单恢复模式。在该模式下,数据库会自动把不活动的日志删除,因此简化了备份的还原,但因为没有事务日志备份,所以不能恢复到失败的时间点。通常,此模式只用于对数据库数据安全要求不太高的数据库。并且在该模式下,数据库只能做完整和差异备份。

    了解了以上数据库还原模式后,一般就应该知道将自己的数据库设置为何种模式了。备份数据库,SQL Server 2008提供了四种备份方式:完整备份、差异备份、事务日志备份、文件和文件组备份。

    ◆ 完整备份:备份整个数据库的所有内容,包括事务日志。该备份类型需要比较大的存储空间来存储备份文件,备份时间也比较长,在还原数据时,也只要还原一个备份文件。

    ◆ 差异备份:差异备份是完整备份的补充,只备份上次完整备份后更改的数据。相对于完整备份分来说,差异备份的数据量比完整数据备份小,备份的速度也比完整备份要快。因此,差异备份通常作为常用的备份方式。在还原数据时,要先还原前一次做的完整备份,然后还原最后一次所做的差异备份,这样才能让数据库里的数据恢复到与最后一次差异备份时的内容相同。

    ◆ 事务日志备份:事务日志备份只备份事务日志里的内容。事务日志记录了上一次完整备份或事务日志备份后数据库的所有变动过程。事务日志记录的是某一段时间内的数据库变动情况,因此在进行事务日志备份之前,必须要进行完整备份。与差异备份类似,事务日志备份生成的文件较小、占用时间较短,但是在还原数据时,除了先要还原完整备份之外,还要依次还原每个事务日志备份,而不是只还原最后一个事务日志备份(这是与差异备份的区别)。

    ◆ 文件和文件组备份。如果在创建数据库时,为数据库创建了多个数据库文件或文件组,可以使用该备份方式。使用文件和文件组备份方式可以只备份数据库中的某些文件,该备份方式在数据库文件非常庞大时十分有效,由于每次只备份一个或几个文件或文件组,可以分多次来备份数据库,避免大型数据库备份的时间过长。另外,由于文件和文件组备份只备份其中一个或多个数据文件,当数据库里的某个或某些文件损坏时,可能只还原损坏的文件或文件组备份。

    完整备份可能比较好理解。例如,在2012年1月1日早上8点进行了完整备份,那么将来在还原时,就可以恢复到2012年1月有1日早上8点时的数据库状态。

    差异备份是备份完整备份后的数据变动情况。例如,在2012年1月1日早上8点进行了完整备份后,在1月2日和1月3日又分别进行了差异备份,那么在1月2日的差异备份里记录的是从1月1日到1月2日这一段时间里的数据变动情况,而在1月3日的差异备份里记录的是从1月1日到1月3日这一段时间里的数据变动情况。因此,如果要还原到1月3日的状态,只要先还原1月1日做的完整备份,再还原1月3日做的差异备份就可以了。

    事务日志备份是以事务日志文件作为备份对象,相当于将数据库里的每一个操作都记录下来了。假设在2012年1月1日早上8点进行了完整备份后,到1月2日早上8点为止,数据库里的数据变动了100次,如果此时做了差异备份,那么差异备份记录的是第100次数据变动后的数据库状态,而如果此时做了事务日志备份,备份的将是这100次的数据变动情况。

    再举一个例子,例如在2012年1月1日早上8点进行了完整备份后,在1月2日和1月3日又进行了事务日志备份,那么在1月2日的事务日志备份里记录的是从1月1日到1月2日这一段时间里的数据变动情况,而在1月3日的事务日志备份里记录的是从1月2日到1月3日这一段时间里的数据变动情况。因此,如果要还原到1月3日的数据,需要先还原1月1日做的完整备份,再还原1月2日做的事务日志备份,最后还要还原1月3日所做的事务日志备份。

    了解了以上数据库备份方式后,便可以针对自己的数据库利用以上方式来备份数据库了。合理备份数据库需要考虑几方面,首先是数据安全,其次是备份文件大小,最后是做备份和还原能承受的时间范围。

    例如,如果数据库里每天变动的数据量很小,可以每周(周日)做一次完整备份,以后的每天(下班前)做一次事务日志备份,那么一旦数据库发生问题,可以将数据恢复到前一天(下班时)的状态。

    当然,也可以在周日时做一次完整备份,周一到周六每天下班前做一次差异备份,这样一旦数据库发生问题,同样可以将数据恢复到前一天下班时的状态。只是一周的后几天做差异备份时,备份的时间和备份的文件都会跟着增加。但这也有一个好处,在数据损坏时,只要恢复完整备份的数据和前一天差异备份的数据即可,不需要去恢复每一天的事务日志备份,恢复的时间会比较短。

    如果数据库里的数据变动得比较频繁,损失一个小时的数据都是十分严重的损失时,用上面的办法备份数据就不可行了,此时可以交替使用三种备份方式来备份数据库。

    例如,每天下班时做一次完整备份,在两次完整备份之间每隔八小时做一次差异备份,在两次差异备份之间每隔一小时做一次事务日志备份。如此一来,一旦数据损坏可以将数据恢复到最近一个小时以内的状态,同时又能减少数据库备份数据的时间和备份数据文件的大小。

    在前面还提到过当数据库文件过大不易备份时,可以分别备份数据库文件或文件组,将一个数据库分多次备份。在现实操作中,还有一种情况可以使用到数据库文件的备份。例如在一个数据库中,某些表里的数据变动得很少,而某些表里的数据却经常改变,那么可以考虑将这些数据表分别存储在不同的文件或文件组里,然后通过不同的备份频率来备份这些文件和文件组。但使用文件和文件组来进行备份,还原数据时也要分多次才能将整个数据库还原完毕,所以除非数据库文件大到备份困难,否则不要使用该备份方式。

    针对以上备份方案,能看出数据还是不完整吗?比如昨天夜间12点做了完整备份,每隔一小时做了一次事务日志备份,最后一次事务日志备份是今天中午12点,现在是今天中午12点10分,发现数据库数据遭到丢失或破坏,可最后一次事务日志备份是今天中午12点,如果我此时将数据库恢复到12点,那么12点后至12点10分前没遭到破坏的操作数据将丢失(比如数据库有三个表,一个表的数据遭到破坏,其它两个表的数据被其它用户变动)。此时就要用到【尾部日志备份】,尾部日志备份原理是从最后一次事务日志备份的时间点开始,将之后的所有操作进行备份,还原时便可以找到12点后操作的正确数据了。

    注:进行尾部日志备份时,数据库将强制停止数据库,此时如果不停止数据库,还有用户继续操作,尾部日志备份将失去意义。SQL Server 2012如果你最后一次备份事务日志后,对数据进行过改动,即发生过事务日志(也就是当前日志文件记录的LSN(日志序列号)大于最后一次事务日志备份里记录的最大LSN,SQL Server通过LSN来区分日志的记录),并尚未对尾部日志备份,它会提示并要求你必须先做尾部备份。

    实例部分

    ◆ 首先进行完整备份【MyTest.bak】,然后再基于此备份文件进行两次事务日志备份,最后一次事务日志备份时间为【2012-8-4 23:07】

图1-1:备份文件名为【MyTest.bak】,最后一次事务日志备份时间为【2012-8-4 23:07】

图1-2:选择备份文件“MyTest.bak”后,此时能看到“要还原的备份集”列表里显示有备份文件,分别列出了完整备份文件和两次事务日志备份。

    以上备份文件最后一次事务日志备份时间为【2012-8-4 23:07】,那么,您可以还原到自首次完整备份开始后,至最后一次事务日志备份时间期间的任何一个时间点,这就充分验证上上文讲到的事务日志备份方式(如果后期进行过尾部日志备份,还原时在“要还原的备份集”列表里的最后一行会列出尾部日志记录)。

    如果事务日志备份有两次,分别是“事务日志1”、“事务日志2”,那么在还原时去掉“事务日志1”复选框,“事务日志2”也会自动去掉,但只去掉“事务日志2”是允许的,这也充分验证了上文讲到的:“在还原数据时,除了先要还原完整备份之外,还要依次还原每个事务日志备份,而不是只还原最后一个事务日志备份”,不比差异备份可以基于完整备份,只还原最后一次差异备份即可

图1-3:我【2012-08-04 23:36:53】插入一条数据,【2012-08-04 23:37:44】又做了一次事务日志备份3,然后再将时间点还原到【2012-08-04 23:36:00】,还原后,此时间点后的数据就没有了。

【注意:在还原时会提示数据库正在使用,一般要断开全部连接后,才能进行还原。我一般使用脚本将数据脱机再联机,所有连接将会全部断开】

alter database MyTest set offline with ROLLBACK IMMEDIATE--脱机
alter database MyTest set online with ROLLBACK IMMEDIATE--联机

   

    ◆ 如果你最后一次是做的完整备份,基于完整备份想还原到某个时间点是不允许的。

图2-1:备份文件名为【MyTestA.bak】,备份时间为【2012-8-4 22:33】

图2-2:先选择最后一次完整备份文件MyTestA,此时能看到“要还原的备份集”列表里显示有备份文件,然后再点“时间线”按钮进入“备份时间线”界面,将最后一次完整备份时间由“22:33:41”改为它之前任何一个时间点,如改为“22:32:41”,然后再确定,会看到图2-3的效果。

图2-3:只要基于完整备份再还原到某个时间点是不允许的,因为完整备份后没做过任何差异备份或事务日志备份。此时能看到“要还原的备份集”列表里显示为空,无法进行还原。

 

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP 및 PDO: 데이터베이스 백업 및 복원 작업을 수행하는 방법 PHP 및 PDO: 데이터베이스 백업 및 복원 작업을 수행하는 방법 Jul 29, 2023 pm 06:54 PM

PHP 및 PDO: 데이터베이스 백업 및 복원 작업을 수행하는 방법 웹 애플리케이션을 개발할 때 데이터베이스 백업 및 복원은 매우 중요한 작업입니다. 널리 사용되는 서버 측 스크립팅 언어인 PHP는 풍부한 라이브러리와 확장 기능을 제공하며, 그 중 PDO(PHP 데이터 개체)는 강력한 데이터베이스 액세스 추상화 계층입니다. 이 기사에서는 PHP와 PDO를 사용하여 데이터베이스 백업 및 복원 작업을 수행하는 방법을 소개합니다. 1단계: 데이터베이스에 연결 실제 작업을 수행하기 전에 데이터베이스에 대한 연결을 설정해야 합니다. PDO 쌍 사용

MySQL 데이터베이스 백업 및 복구 성능 최적화에 대한 프로젝트 경험 분석 MySQL 데이터베이스 백업 및 복구 성능 최적화에 대한 프로젝트 경험 분석 Nov 02, 2023 am 08:53 AM

현 인터넷 시대에 데이터의 중요성은 자명합니다. 인터넷 애플리케이션의 핵심 구성 요소 중 하나인 데이터베이스 백업 및 복구 작업은 특히 중요합니다. 그러나 데이터 양이 계속 증가하고 비즈니스 요구 사항이 점점 더 복잡해짐에 따라 기존 데이터베이스 백업 및 복구 솔루션은 더 이상 최신 애플리케이션의 고가용성 및 고성능 요구 사항을 충족할 수 없습니다. 따라서 MySQL 데이터베이스의 백업 및 복구 성능을 최적화하는 것이 해결해야 할 시급한 문제가 되었습니다. 실제로 우리는 MySQL 데이터를 효과적으로 개선하기 위해 일련의 프로젝트 경험을 채택했습니다.

ThinkPHP6을 사용하여 데이터베이스 백업 및 복구를 구현하는 방법 ThinkPHP6을 사용하여 데이터베이스 백업 및 복구를 구현하는 방법 Jun 20, 2023 pm 07:25 PM

비즈니스 시스템을 개발하는 과정에서 데이터베이스는 매우 중요한 부분입니다. 따라서 데이터베이스를 백업하고 복원하는 것은 매우 필요한 작업입니다. 이 기사에서는 ThinkPHP6 프레임워크의 예를 결합하여 ThinkPHP6을 사용하여 데이터베이스 백업 및 복구를 구현하는 방법을 소개합니다. 1. 데이터베이스 백업 1.1 환경 준비 데이터베이스 백업을 수행하기 전에 다음 사항을 확인해야 합니다. 1. mysql 데이터베이스의 bin 디렉터리 주소를 설정하고 해당 경로를 시스템 경로 변수에 추가해야 합니다. mysqld

Pagoda Panel의 데이터베이스 백업, 최적화 및 복구 Pagoda Panel의 데이터베이스 백업, 최적화 및 복구 Jun 21, 2023 am 09:45 AM

오늘날의 온라인 세계에서 웹사이트는 모든 기업, 조직 또는 개인이 브랜드, 서비스, 제품 등을 표시하는 중요한 매체가 되었습니다. 웹사이트의 정상적인 운영과 보안을 보장하려면 지속적인 백업과 최적화가 필요합니다. 데이터베이스 및 복구. 간단한 조작, 풍부한 기능 및 아름다운 인터페이스를 갖춘 서버 관리 소프트웨어인 Pagoda Panel은 데이터베이스 관리에도 매우 뛰어나며 백업, 최적화 및 복구와 같은 중요한 기능을 갖추고 있습니다. 이 기사에서는 Pagoda Panel의 데이터베이스 백업, 최적화 및 복구 기능과 관련 문제에 중점을 둘 것입니다.

PHP 및 Memcached 데이터베이스 백업 및 복구 PHP 및 Memcached 데이터베이스 백업 및 복구 May 15, 2023 pm 09:12 PM

인터넷의 급속한 발전으로 인해 대규모 MySQL 데이터베이스 백업 및 복구는 주요 기업과 웹사이트에 필요한 기술 중 하나가 되었습니다. Memcached가 널리 적용되면서 Memcached를 백업하고 복원하는 방법도 중요한 문제가 되었습니다. 웹 개발의 주요 언어 중 하나인 PHP는 MySQL 및 Memcached의 백업 및 복구를 처리하는 데 있어 고유한 장점과 기술을 가지고 있습니다. 이 기사에서는 PHP에서 MySQL을 처리하고 Memcached 백업 및 복구를 수행하는 방법을 자세히 소개합니다.

Golang에서 데이터베이스를 백업하는 방법은 무엇입니까? Golang에서 데이터베이스를 백업하는 방법은 무엇입니까? Jun 01, 2024 am 11:56 AM

Golang에서 데이터베이스를 백업하는 것은 데이터를 보호하는 데 중요합니다. 표준 라이브러리의 데이터베이스/sql 패키지를 사용하거나 github.com/go-sql-driver/mysql과 같은 타사 패키지를 사용할 수 있습니다. 구체적인 단계는 다음과 같습니다. 데이터베이스에 연결합니다. 백업 데이터를 저장할 파일을 생성합니다. 덤프 기능이나 내보내기를 사용하여 데이터베이스를 파일로 백업합니다.

Thinkorm을 사용하여 데이터베이스 백업 및 복원을 구현하는 방법 Thinkorm을 사용하여 데이터베이스 백업 및 복원을 구현하는 방법 Jul 28, 2023 pm 02:05 PM

제목: ThinkORM을 사용하여 데이터베이스 백업 및 복원 실현 소개: 개발 과정에서 데이터베이스 백업 및 복원은 매우 중요한 작업입니다. 이 기사에서는 ThinkORM 프레임워크를 사용하여 데이터베이스 백업 및 복원을 구현하는 방법을 소개하고 해당 코드 예제를 제공합니다. 1. 배경 소개 개발 과정에서 우리는 일반적으로 데이터를 저장하고 관리하기 위해 데이터베이스를 사용합니다. 데이터베이스 백업 및 복원의 원칙은 데이터베이스에 문제가 발생하거나 데이터가 손실되는 경우 신속하게 데이터를 복원할 수 있도록 데이터베이스를 정기적으로 백업하는 것입니다. 의 도움으로

데이터베이스 백업 및 복구 실습: PHP 프로그래밍의 응용 데이터베이스 백업 및 복구 실습: PHP 프로그래밍의 응용 Jun 22, 2023 pm 07:10 PM

인터넷의 발전과 함께 데이터베이스 백업 및 복구는 웹사이트 운영 및 개발 과정에서 매우 중요한 부분이 되었습니다. 데이터베이스는 웹사이트의 핵심이며 많은 중요한 정보를 포함하고 있습니다. 데이터가 손실되거나 손상되면 웹사이트 운영과 사용자 경험에 큰 영향을 미치게 됩니다. 따라서 웹사이트 운영자와 개발자에게 데이터베이스 백업 및 복구의 중요성은 자명합니다. 이 기사에서는 개발자가 참조할 수 있도록 PHP 프로그래밍의 데이터베이스 백업 및 복구 작업에 중점을 둘 것입니다. 1. 번호

See all articles