热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

AD的备份与标准还原-mysql教程

大家常常听说过数据库的备份和还原,比如SqlServer,Oracel等数据库的备份和还原。OK,我们这一节讨论ActiveDirectory数据库的备份和还原。ActiveDirectory数据库的备份在企业应用环境中是个非常重要的工作,无论是单域单域控的

大家常常听说过数据库的 备份 和 还原 ,比如 Sql Server , Oracel 等数据库的 备份 和 还原 。 OK ,我们这一节讨论 Active Directory 数据库的 备份 和 还原 。 Active Directory 数据库的 备份 在企业应用环境中是个非常重要的工作,无论是单域单域控的

大家常常听说过数据库的备份还原,比如Sql Server Oracel等数据库的备份还原OK,我们这一节讨论Active Directory数据库的备份还原

Active Directory数据库的备份在企业应用环境中是个非常重要的工作,无论是单域单域控的,单域多域控的,还是多域多域控的环境,Active Directory数据库的备份都是要经常做的工作。备份的好处如下:

1, 灾难恢复对于单域单域控的企业环境,如果Active Directory生病了,比如误操作,磁盘等的原因,如果我们备份Active Directory数据库,恢复起来非常的容易。当然对于单域多域控的环境和多域多域控的环境是同样的道理,步骤相对麻烦而已。

2, 转移数据。如果我们要在当前域搭建一台额外域控制器,无论这台新的额外域控制器是和主域控制器在一个地理位置,还是在不同的地理位置。通过备份来转移数据是非常时效的方法。

本节的实验环境,如下图

一,备份前的准备

了解Active Directory的工作过程

我们与活动目录交互时,比如在活动目录中添加、更新、删除和移除对象等修改操作,在业务逻辑上其实是采用了事务的机制来完成的。而事务我们知道遵从ACID原则,脱离ACID原则的事务是不存在的。事务在关系数据库中处处可见,当然在企业应用系统中也很常见。一个事务中的一系列操作要么全部都做成功,要么全部都不做。

活动目录中的数据修改时,会按照下面这个过程完成:

步骤如下:

1, 我们向活动目录提交一个写请求

2, AD根据写请求初始化一个事务

3, 接着AD在内存中缓存该事务,

4, 同时AD把该事务操作写到事务日志文件edb.log

5, 接着AD把事务操作结果写到磁盘上的数据库文件ntds.dit

6, 接着AD对比数据库文件和日志文件以确保事务被提交

7, 最后AD更新检查点文件edb.chk

了解Active Directory数据库文件的作用

1, ntds.dit文件就是传说中的Active Directory数据库文件。它存储了该DC中所有的AD对象数据。扩展名dit的意思是directory information tree,意思是目录信息树。

2, edb.log是一个事务日志文件。它保存着Active Directory的变动记录。也就是说edb.logActive Directory变动的记录文件。默认的事务日志名是edb.log,每个事务日志的文件大小为10MB,当文件edb.log被写满时它被重命名为edbxxxx.log,从重新建立一个变动记录文件,同时不需要的旧记录文件会被自动删除。其中xxxx是文件编号,从0001开始,逐渐递增。AD在将变动数据写入到内存的同时,AD也会将变动数据写到变动记录文件内(edb.log)。如果系统不正常关机,导致内存尚未写入到Active Directory的数据丢失时,当再开机后,系统便可以根据检查点文件edb.chk来得知要从变动记录文件edb.log内的哪个数据开始,利用变动记录文件edb.log内的变动记录,将关机前尚未写入Active Directory数据库的变动记录继续写入。

3, edb.chk是“检查点文件,每次AD将内存中的数据写到AD时,都会更新deb.chk文件。以便记录与内存相对用的变动记录文件edb.log内有哪一些数据已经写入到Active Director数据库内。该文件用来维护内存和磁盘上的Active Directory数据库之间的数据的指针。该文件的指针指出了日志文件edb.log的起始点,如果修改有错误,就从该起始点开始覆盖信息。

4, res1.logres2.log是两个预留的事务日志文件,每个大小为10MB。当磁盘空间不够时或耗尽时,变是这2个文件的应用场景。

我们要备份什么?

备份Active Directory数据库,其实就是要备份Active Directory数据库文件和SYSVOL文件夹,而Active Directory数据库文件和SYSVOL文件夹都属于系统状态文件(system state),所以我们通过备份系统状态文件来备份Active Directory数据库。

二,备份Active Directory数据库

备份前首先在域控制器上创建一个北京分公司OU和在北京分公司OU下的2个用户账户bobterry,同时在客户端client1利用bob登录域。如下图

然后我们开始备份

步骤1:在server1上,单击开始->运行,输入ntbcakup,回车。如下图

步骤2:在“备份还原向导”对话框中选择“高级模式”,然后单击“下一步”按钮。我个人比较喜欢这种模式,其实和向导模式是一样的,根据你自己的情况选择。如下图

步骤3:选择“备份”标签,如下图

步骤4:选择System State,单击“浏览”按钮选择备份文件存放的文件夹,其中ADbak文件夹是我们自己创建的,而Backup.bkf备份文件的默认名,当然也可以改名。然后单击“开始备份”按钮,如下图。

步骤5:这里可以选择计划和高级,根据自身企业的情况而定。计划其实就是要创建计划作业,而高级可以选择正常,增量,差异,副本,每日五种备份类型。然后单击“开始备份”按钮,如下图

步骤6:正在备份System State(系统状态)。如下图

步骤7备份完成,显示了一些备份信息。单击“关闭”按钮,如下图

步骤8:此时我们切换到“还原和管理媒体”标签,就会看到我们刚刚备份System State。方法是副本备份,如下图

三,Active Directory数据库的还原

我们这里用标准还原还原Active Directory数据库。标准还原(normal restore)又称为非强制还原(nonauthoritative restore),也称为非验证还原。名字多多。J 标准还原只是单纯的将Active Directory数据库从备份的介质中还原,不过标准还原在单域单域控的中小企业中经常使用,另外在主辅域控当中我们常常先用标准还原再搭配强制性还原来灾难恢复,所以我们这里先演示标准还原。强制性还原和主要还原后续文章会谈。

为了演示标准还原,我们先删除contoso.com域中北京分公司OU。同时也删除这个OU下的2个用户账户bob和terry。然后我们用标准还原把他们找回来。开始吧。

步骤1:重启域控制器server1,然后按F8进入“Windows高级选项菜单”,然后我们选择“目录服务还原模式(只用于Windows域控制器)”。

步骤2:选择操作系统,如下图

步骤3:输入目录服务还原模式的账户和密码,还记我们在安装活动目录时设置那个目录服务还原模式账户密码吗?对,就是那个。

步骤4:开始à运行->输入ntbackup->选择“高级模式”->切换到还原和管理媒体->选择System State。然后单击“开始还原”,如下图。

步骤5:单击确定。如下图

步骤6:单击确定,当然我们也可以切换到高级看看和制作离线备份文件时还原的高级有什么不同。发现默认第二项这里也选择了。如下面的2副图

步骤7:正在还原,如下图。还原完成后弹出一个还原完成的报告对话框。

最后我们重新启动域控制器server1,发现被删除的北京分公司OU和它下面的bobterry用户账户已经被还原了。

李涛的技术专栏

推荐阅读
  • PHP自学必备:从零开始的准备工作与工具选择 ... [详细]
  • 初探性能优化:入门指南与实践技巧
    在编程领域,常有“尚未精通编码便急于优化”的声音。为了从性能优化的角度提升代码质量,本文将带领读者初步探索性能优化的基本概念与实践技巧。即使程序看似运行良好,数据处理效率仍有待提高,通过系统学习性能优化,能够帮助开发者编写更加高效、稳定的代码。文章不仅介绍了性能优化的基础知识,还提供了实用的调优方法和工具,帮助读者在实际项目中应用这些技术。 ... [详细]
  • 作为软件工程专业的学生,我深知课堂上教师讲解速度之快,很多时候需要课后自行消化和巩固。因此,撰写这篇Java Web开发入门教程,旨在帮助初学者更好地理解和掌握基础知识。通过详细记录学习过程,希望能为更多像我一样在基础方面还有待提升的学员提供有益的参考。 ... [详细]
  • 本文详细介绍了使用 Python 进行 MySQL 和 Redis 数据库操作的实战技巧。首先,针对 MySQL 数据库,通过 `pymysql` 模块展示了如何连接和操作数据库,包括建立连接、执行查询和更新等常见操作。接着,文章深入探讨了 Redis 的基本命令和高级功能,如键值存储、列表操作和事务处理。此外,还提供了多个实际案例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 提升 Kubernetes 集群管理效率的七大专业工具
    Kubernetes 在云原生环境中的应用日益广泛,然而集群管理的复杂性也随之增加。为了提高管理效率,本文推荐了七款专业工具,这些工具不仅能够简化日常操作,还能提升系统的稳定性和安全性。从自动化部署到监控和故障排查,这些工具覆盖了集群管理的各个方面,帮助管理员更好地应对挑战。 ... [详细]
  • 在探讨Hibernate框架的高级特性时,缓存机制和懒加载策略是提升数据操作效率的关键要素。缓存策略能够显著减少数据库访问次数,从而提高应用性能,特别是在处理频繁访问的数据时。Hibernate提供了多层次的缓存支持,包括一级缓存和二级缓存,以满足不同场景下的需求。懒加载策略则通过按需加载关联对象,进一步优化了资源利用和响应时间。本文将深入分析这些机制的实现原理及其最佳实践。 ... [详细]
  • 在探讨 MySQL 正则表达式 REGEXP 的功能与应用之前,我们先通过一个小实验来对比 REGEXP 和 LIKE 的性能。通过具体的代码示例,我们将评估这两种查询方式的效率,以确定 REGEXP 是否值得深入研究。实验结果将为后续的详细解析提供基础。 ... [详细]
  • 单链表的高效遍历及性能优化策略
    本文探讨了单链表的高效遍历方法及其性能优化策略。在单链表的数据结构中,插入操作的时间复杂度为O(n),而遍历操作的时间复杂度为O(n^2)。通过在 `LinkList.h` 和 `main.cpp` 文件中对单链表进行封装,我们实现了创建和销毁功能的优化,提高了单链表的使用效率。此外,文章还介绍了几种常见的优化技术,如缓存节点指针和批量处理,以进一步提升遍历性能。 ... [详细]
  • 如何在Windows XP和Windows 7之间实现打印机共享?探索跨系统打印解决方案 ... [详细]
  • 小王详解:内部网络中最易理解的NAT原理剖析,挑战你的认知极限
    小王详解:内部网络中最易理解的NAT原理剖析,挑战你的认知极限 ... [详细]
  • 如何实现电脑硬盘的精确整数分区:探究硬盘容量与分区技巧
    本文探讨了如何在电脑硬盘上实现精确的整数分区,详细分析了硬盘容量与分区技巧之间的关系。通过合理的规划和操作,可以确保每个分区的容量为整数值,从而提高存储管理的效率和数据的安全性。文中还介绍了常用的分区工具和方法,帮助用户更好地理解和掌握硬盘分区技术。 ... [详细]
  • ButterKnife 是一款用于 Android 开发的注解库,主要用于简化视图和事件绑定。本文详细介绍了 ButterKnife 的基础用法,包括如何通过注解实现字段和方法的绑定,以及在实际项目中的应用示例。此外,文章还提到了截至 2016 年 4 月 29 日,ButterKnife 的最新版本为 8.0.1,为开发者提供了最新的功能和性能优化。 ... [详细]
  • 安装Windows 10必须使用U盘吗?如果不使用U盘,还有哪些方法可以安装Windows 10?
    安装Windows 10必须使用U盘吗?如果不使用U盘,还有哪些方法可以安装Windows 10? ... [详细]
  • 本文深入解析了HTML框架集(FRAMESET)的使用方法及其应用场景。首先介绍了几个关键概念,如如何通过FRAMESET标签将主视图划分为多个独立的区域,每个区域可以加载不同的HTML文件。此外,还详细探讨了FRAMESET在实际开发中的优缺点,并提供了具体的实例代码,帮助开发者更好地理解和应用这一技术。 ... [详细]
  • 本文详细探讨了在ASP.NET环境中通过加密数据库连接字符串来提升数据安全性的方法。加密技术不仅能够有效防止敏感信息泄露,还能增强应用程序的整体安全性。文中介绍了多种加密手段及其实施步骤,帮助开发者在日常开发过程中更好地保护数据库连接信息,确保数据传输的安全可靠。 ... [详细]
author-avatar
手浪用户2602928711
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有