AD的备份与标准还原
大家常常听说过数据库的 备份 和 还原 ,比如 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.log是Active 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.log和res2.log是两个预留的事务日志文件,每个大小为10MB。当磁盘空间不够时或耗尽时,变是这2个文件的应用场景。
我们要备份什么?
备份Active Directory数据库,其实就是要备份Active Directory数据库文件和SYSVOL文件夹,而Active Directory数据库文件和SYSVOL文件夹都属于系统状态文件(system state),所以我们通过备份系统状态文件来备份Active Directory数据库。
二,备份Active Directory数据库
备份前首先在域控制器上创建一个北京分公司OU和在北京分公司OU下的2个用户账户bob和terry,同时在客户端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和它下面的bob和terry用户账户已经被还原了。
李涛的技术专栏

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

在PHP中备份和还原MySQL数据库可通过以下步骤实现:备份数据库:使用mysqldump命令转储数据库为SQL文件。还原数据库:使用mysql命令从SQL文件还原数据库。

Go语言是一种高效、简洁且易于学习的编程语言,因其在并发编程和网络编程方面的优势而备受开发者青睐。在实际开发中,数据库操作是不可或缺的一部分,本文将介绍如何使用Go语言实现数据库的增删改查操作。在Go语言中,我们通常使用第三方库来操作数据库,比如常用的sql包、gorm等。这里以sql包为例介绍如何实现数据库的增删改查操作。假设我们使用的是MySQL数据库。

Hibernate多态映射可映射继承类到数据库,提供以下映射类型:joined-subclass:为子类创建单独表,包含父类所有列。table-per-class:为子类创建单独表,仅包含子类特有列。union-subclass:类似joined-subclass,但父类表联合所有子类列。

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

HTML无法直接读取数据库,但可以通过JavaScript和AJAX实现。其步骤包括建立数据库连接、发送查询、处理响应和更新页面。本文提供了利用JavaScript、AJAX和PHP来从MySQL数据库读取数据的实战示例,展示了如何在HTML页面中动态显示查询结果。该示例使用XMLHttpRequest建立数据库连接,发送查询并处理响应,从而将数据填充到页面元素中,实现了HTML读取数据库的功能。

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

PHP是一种广泛应用于网站开发的后端编程语言,它具有强大的数据库操作功能,常用于与MySQL等数据库进行交互。然而,由于中文字符编码的复杂性,在处理数据库中文乱码时常常会出现问题。本文将介绍PHP处理数据库中文乱码的技巧与实践,包括常见的乱码原因、解决方法和具体的代码示例。常见的乱码原因数据库字符集设置不正确:数据库在创建时需选择正确的字符集,如utf8或u
