首页 > 数据库 >Redis 持久化机制详解

Redis 持久化机制详解

时间:2024-12-23 11:56:45浏览次数:5  
标签:AOF 文件 重写 Redis 详解 RDB 数据 化机制

一、Redis 持久化机制之基石:引言

在当今数据驱动的时代,数据的安全性与可靠性犹如基石之于高楼,其重要性不言而喻。Redis,这款广受欢迎的内存数据库,以其卓越的性能在众多应用场景中大放异彩。然而,内存数据的易失性始终是一把悬于头顶的达摩克利斯之剑,一旦服务器遭遇意外,如宕机、断电等情况,数据可能瞬间化为乌有。为了化解这一困境,Redis 精心打造了两种强大的持久化机制 ——RDB(Redis Database)和 AOF(Append Only File),它们如同数据的守护天使,确保数据在关键时刻得以保全,为 Redis 在数据存储领域的稳健运行保驾护航。

二、RDB 持久化机制:Redis 数据的周期性快照

2.1 RDB 工作原理:从内存到磁盘的快照生成

RDB 持久化机制的核心在于在特定的时间点对 Redis 内存中的数据进行快照,并将其保存为 RDB 文件。这个过程犹如相机拍照,瞬间定格数据的状态。当满足触发条件时,Redis 会巧妙地使用 fork 系统调用创建一个子进程。这一子进程的创建方式极为高效,它几乎在瞬间就拥有了父进程内存数据的副本,就像是克隆了一个一模一样的 “数据世界”。随后,子进程会不辞辛劳地遍历数据库中的所有键值对,将这些数据以特定的二进制格式精心写入到 RDB 文件中。在这个过程中,为了最大程度地减少对性能的影响,子进程采用了写时复制(Copy-on-Write)技术。这意味着,在数据没有发生变化时,父子进程共享同一块内存数据,只有当父进程中的数据被修改时,才会将需要修改的数据页复制一份,从而保证子进程所使用的数据不受任何干扰,确保了快照的一致性和完整性。

2.2 RDB 的触发方式:手动与自动的结合

RDB 的触发方式灵活多样,分为手动触发和自动触发,以满足不同场景下的需求。

  • 手动触发
    • save 命令:这是一种最为直接的方式,当执行 save 命令时,Redis 服务器会毅然决然地阻塞所有其他操作,全心全意地将当前数据集转储到 RDB 文件中。在这个过程中,Redis 如同一位专注的艺术家,心无旁骛地进行数据的持久化工作,不再处理任何新的命令。然而,这种方式在数据量较大时会显得力不从心,因为它会导致长时间的阻塞,就像一条单行道上的交通堵塞,会严重影响 Redis 的正常运行。因此,在生产环境中,尤其是对于内存较大的实例,save 命令就像一把双刃剑,使用时需要格外谨慎,一般不建议轻易使用。
    • bgsave 命令:这是一种更为智能和高效的手动触发方式。当执行 bgsave 命令时,Redis 进程会像一位经验丰富的指挥家,有条不紊地执行 fork 操作,创建一个子进程。这个子进程就像是一个忠诚的助手,专门负责 RDB 持久化的具体工作,而父进程则可以继续轻松地响应客户端的请求,就像指挥家在指挥乐队演奏的同时,还能处理其他事务一样。阻塞仅仅发生在 fork 阶段,而这个阶段通常非常短暂,如同夜空中的流星一闪而过。一旦子进程创建成功,父进程就会迅速恢复活力,继续处理其他任务。因此,bgsave 命令成为了 Redis 内部进行 RDB 操作的首选方式,它在保证数据持久化的同时,最大程度地减少了对 Redis 性能的影响。
  • 自动触发:Redis 还提供了自动触发 RDB 持久化的机制,这使得数据的持久化工作更加智能化和自动化。例如,在配置文件 redis.conf 中,可以通过设置 save 规则来实现自动触发。常见的配置如 “save m n”,它表示在 m 秒内数据集存在 n 次修改时,Redis 会自动触发 bgsave 命令,就像一个精准的闹钟,在满足特定条件时自动启动数据持久化工作。此外,在一些特殊场景下,如从节点执行全量复制操作时,主节点会自动执行 bgsave 生成 RDB 文件并发送给从节点,以确保数据的一致性和完整性。在执行 debug reload 命令重新加载 Redis 时,以及默认情况下执行 shutdown 命令且没有开启 AOF 持久化功能时,也会自动触发 save 操作。

2.3 RDB 文件的结构与特点:紧凑高效的存储形式

RDB 文件具有一种精巧而紧凑的结构,这种结构就像是一个精心设计的储物箱,能够高效地存储 Redis 的数据。它以 “REDIS” 字符串作为开头,这个字符串就像是储物箱的标签,长度为 5 字节,通过它可以快速识别文件是否为 RDB 文件。紧接着是 db_version 部分,它的长度为 4 字节,记录了 RDB 文件的版本号,就像是储物箱的规格说明,标识了这个 “箱子” 所遵循的版本标准。随后是 databases 部分,这里面依次存储了各个数据库的键值对数据,每个键值对都按照特定的格式进行排列,如同储物箱中的物品被整齐地摆放。在键值对的存储中,包含了键的类型、长度、数据以及值的类型、长度和数据等信息,这种结构使得 RDB 文件能够准确无误地还原数据。此外,RDB 文件还包含了一些元数据信息,如保存数据库的数量、数据库的各种属性等,这些信息就像是储物箱中的清单,记录了箱子里的物品详情。最后,文件以 EOF(End of File)标记作为结尾,标志着文件的结束。这种紧凑的结构使得 RDB 文件在存储和传输过程中具有极高的效率,尤其是在进行数据备份和恢复时,能够以更快的速度完成操作。就像一个小巧而高效的快递包裹,能够快速地将数据送达目的地并进行还原。

三、AOF 持久化机制:Redis 操作的日志记录

3.1 AOF 工作原理:写命令的追加与持久化

AOF 持久化机制的核心在于将 Redis 执行的每一个写命令以协议文本的形式追加到 AOF 文件的末尾,就像是一位严谨的史官,将 Redis 数据库的每一次变动都详细地记录下来。当 Redis 服务器需要恢复数据时,它会像一位忠诚的读者,重新读取 AOF 文件中的命令,并按照顺序依次执行这些命令,从而将数据恢复到之前的状态。这个过程就像是时光倒流,能够精准地还原出数据的历史变迁。例如,当执行 “SET key value” 命令时,AOF 文件中会追加类似 “*3\r\n 3\r\nkey\r\n 3” 表示参数的长度为 3 字节,以此类推。这种以协议文本形式记录命令的方式,不仅保证了数据的完整性,还使得 AOF 文件具有极高的可读性,方便开发者进行调试和分析。在 AOF 持久化的过程中,Redis 会先将写命令追加到 aof_buf 缓冲区中,然后再根据配置的同步策略将缓冲区中的内容写入到 AOF 文件并进行同步。

3.2 AOF 同步策略:性能与数据安全的权衡

AOF 提供了三种同步策略,分别是 always、everysec 和 no,它们就像是三把不同的钥匙,用来控制数据从缓冲区写入磁盘的时机,每种策略在性能和数据完整性方面都有着不同的权衡。

  • always 策略:这是一种最为严格的同步策略,就像是一位一丝不苟的守卫,每当有写命令执行完毕,它都会立即将命令从 aof_buf 缓冲区写入到 AOF 文件,并同步到磁盘中。这种策略能够最大程度地保证数据的完整性,即使在服务器突然宕机的情况下,也只会丢失正在执行的那个命令的数据,而不会影响到之前已经执行的命令。例如,在一些对数据安全性要求极高的金融交易系统中,每一笔交易都必须确保万无一失,此时 always 策略就能发挥出它的优势。然而,这种策略的性能开销也是最大的,因为频繁地进行磁盘 I/O 操作会严重影响 Redis 的写入性能,就像是一条狭窄的道路上频繁地有车辆进出,会导致交通拥堵,使整个系统的响应速度变慢。
  • everysec 策略:这是 Redis 的默认策略,它像是一位聪明的管家,每隔一秒将 aof_buf 缓冲区中的命令写入到 AOF 文件,并同步到磁盘中。这种策略在性能和数据完整性之间找到了一个较好的平衡点。它既能保证在一秒内发生的宕机情况只会丢失最多一秒的数据,又不会像 always 策略那样对性能产生过大的影响。在大多数生产环境中,这种策略都能满足数据安全和性能的双重要求,就像是一件既实用又美观的衣服,能够适应多种场合的需求。例如,在一个普通的电商网站中,偶尔丢失一秒的数据可能并不会对业务产生重大影响,而 everysec 策略能够在保证数据相对安全的前提下,提供较好的性能表现。
  • no 策略:这种策略就像是一位宽松的监管者,它只是将写命令追加到 aof_buf 缓冲区中,然后由操作系统根据自身的调度机制来决定何时将缓冲区中的数据写入到磁盘中。这种策略的性能最好,因为它将磁盘 I/O 操作的控制权完全交给了操作系统,减少了 Redis 自身的负担,就像是把货物交给了专业的运输公司,自己可以专注于其他事务。但是,这也意味着数据的安全性最低,如果操作系统在将缓冲区数据写入磁盘之前发生宕机,那么将会丢失大量的数据。例如,在一些对数据丢失不太敏感的测试环境或者数据可以通过其他方式恢复的场景中,可以考虑使用 no 策略来提高 Redis 的性能。

综合考虑,在大多数情况下,推荐使用 everysec 策略。它能够在保证数据安全性的前提下,提供相对较好的性能表现,就像是一位可靠的伙伴,在关键时刻不会掉链子,又能在平时高效地完成工作。

3.3 AOF 重写机制:文件体积的优化与控制

随着 Redis 的运行,AOF 文件会像一个不断膨胀的气球,因为它会记录所有的写命令,导致文件体积越来越大。为了解决这个问题,Redis 引入了 AOF 重写机制,就像是一位技艺高超的裁缝,能够对 AOF 文件进行裁剪和优化,使其体积得到有效控制。

AOF 重写的原理是基于数据库当前的键值对状态,生成一个最小的指令集。它并不需要读取和分析原有的 AOF 文件,而是直接从数据库中获取数据,就像是直接从源头获取信息,避免了对大量历史命令的处理。例如,对于一个字符串键 “key”,如果它被多次修改,AOF 文件中可能会记录多个修改命令,但在重写时,会根据当前 “key” 的最终值,生成一个简单的 “SET key value” 命令,从而大大减少了命令的数量。这样生成的新 AOF 文件包含了恢复当前数据集所需的最小命令集合,既保证了数据的完整性,又有效地压缩了文件体积。

AOF 重写的触发条件可以通过配置文件中的 auto-aof-rewrite-percentage 和 auto-aof-rewrite-min-size 参数来控制。auto-aof-rewrite-percentage 参数表示当当前 AOF 文件大小超过上次重写后 AOF 文件大小的百分比时触发重写,默认值为 100%,就像是当衣服的尺寸比上次修改后增大了一倍时,就需要进行重新裁剪。auto-aof-rewrite-min-size 参数表示当当前 AOF 文件大小超过指定值时才可能触发重写,默认值为 64MB,这就像是设定了一个最小的衣服尺码,只有当衣服大到一定程度时才值得进行修改。例如,如果上次重写后 AOF 文件大小为 32MB,当 AOF 文件增长到 64MB(即增长了 100%)且超过了 64MB 的最小限制时,就会触发 AOF 重写。

AOF 重写是在后台进行的,这就像是在店铺后台有一位裁缝在默默地工作,不会影响到前台的正常营业。当触发重写时,Redis 会使用 fork 系统调用创建一个子进程,这个子进程就像是裁缝的助手,专门负责 AOF 重写的工作。子进程会遍历数据库中的所有键值对,根据键的类型和值生成相应的写入命令,并将这些命令写入到一个新的临时 AOF 文件中。在这个过程中,主进程仍然可以继续处理客户端的请求,就像店铺前台仍然可以正常接待顾客一样。但是,为了保证数据的一致性,主进程在执行写命令时,会将命令同时追加到现有的 AOF 文件和一个 AOF 重写缓冲区中。当子进程完成重写后,主进程会将 AOF 重写缓冲区中的命令追加到新的 AOF 文件中,然后用新的 AOF 文件替换旧的 AOF 文件,就像是裁缝完成修改后,将新衣服替换旧衣服一样,从而完成 AOF 文件的重写和更新。

四、RDB 与 AOF 的对比:差异、适用场景与选择建议

持久化机制

优点

缺点

适用场景

RDB

- 数据恢复速度快,因为是数据快照,直接加载即可。 - 文件紧凑,体积小,便于备份和传输。 - 对 Redis 性能影响较小,通过 fork 子进程进行持久化,主进程无需进行大量 IO 操作。

- 数据安全性相对较低,可能丢失上次快照之后的数据。 - fork 子进程时可能会导致服务器短暂停止服务,尤其是数据集较大时。

- 对数据恢复速度要求较高,且对数据丢失有一定容忍度的场景,如缓存数据。 - 大规模数据的备份和恢复场景,例如定期进行数据归档。

AOF

- 数据安全性高,可通过配置不同的同步策略来控制数据丢失的风险,如默认的 everysec 策略最多丢失一秒数据。 - 以日志形式记录写命令,文件具有可读性,便于调试和分析。 - AOF 重写机制可有效控制文件体积,避免文件过大。

- 相同数据集下,文件通常比 RDB 文件大。 - 数据恢复速度相对较慢,需要重新执行 AOF 文件中的命令。 - 根据同步策略的不同,性能可能会受到一定影响,尤其是 always 策略会显著降低写入性能。

- 对数据安全性要求极高,不允许大量数据丢失的场景,如金融交易系统。 - 需要对数据操作进行详细记录以便审计或故障排查的场景。

在实际应用中,需要根据具体的业务需求来选择合适的持久化机制。如果对数据恢复速度要求较高,且数据丢失的风险可以接受,那么 RDB 可能是一个较好的选择。例如,在缓存场景中,数据的一致性要求相对较低,即使丢失一部分数据,也可以通过重新加载来恢复。而对于数据安全性要求极高的场景,如金融领域的交易数据存储,AOF 则更为合适,它能够提供更高的数据持久性和完整性保障。在一些情况下,也可以同时开启 RDB 和 AOF,充分利用它们的优势,实现数据的双重保护。例如,在生产环境中,可以使用 RDB 进行定期的全量备份,而 AOF 则用于实时的数据持久化,这样在发生故障时,可以先通过 RDB 快速恢复数据,再利用 AOF 进行数据的完整性修复。

五、Redis 持久化的实际应用:配置、优化与故障处理

5.1 持久化机制的配置:根据需求定制

在 Redis 的配置文件 redis.conf 中,可以对 RDB 和 AOF 的相关参数进行详细配置,以满足不同场景下的需求。

  • RDB 配置
    • 保存路径与文件名:通过dbfilename参数可以指定 RDB 文件的文件名,默认值为dump.rdb。dir参数则用于设置文件的保存路径,例如dir /var/lib/redis/表示将 RDB 文件保存到/var/lib/redis/目录下。在配置时,需要确保所指定的路径具有足够的存储空间,并且 Redis 进程具有相应的读写权限。
    • 触发条件:如前所述,save参数用于设置自动触发 RDB 持久化的条件。可以根据数据的更新频率和重要性,合理设置save m n中的m和n值。例如,对于数据更新较为频繁的场景,可以设置save 60 1000,表示在 60 秒内数据发生了 1000 次修改时就自动触发 bgsave 操作。这样可以在一定程度上平衡数据的安全性和性能影响。
    • 其他配置:还可以配置rdbcompression参数来决定是否对 RDB 文件进行压缩,默认值为yes,压缩可以减小文件体积,但会消耗一定的 CPU 资源。rdbchecksum参数用于设置是否开启 RDB 文件的校验和验证,默认值也为yes,这有助于检测文件是否损坏。
  • AOF 配置
    • 开启与文件名:将appendonly参数设置为yes,即可开启 AOF 持久化功能。appendfilename参数用于指定 AOF 文件的名称,默认值为appendonly.aof。
    • 同步策略:appendfsync参数用于设置 AOF 的同步策略,可选值为always、everysec和no。如前文所述,always能提供最高的数据安全性,但性能最差;everysec是默认策略,在性能和数据安全之间取得了较好的平衡;no则将同步操作交给操作系统,性能最好但数据安全性最低。在大多数生产环境中,推荐使用everysec策略。
    • 重写参数:auto-aof-rewrite-percentage和auto-aof-rewrite-min-size参数用于控制 AOF 重写的触发条件。例如,设置auto-aof-rewrite-percentage 100和auto-aof-rewrite-min-size 64mb,表示当 AOF 文件大小超过上次重写后文件大小的 100% 且当前文件大小超过 64MB 时,就会触发 AOF 重写操作。通过合理设置这些参数,可以有效地控制 AOF 文件的体积,避免其过大影响系统性能。

5.2 性能优化与问题解决:提升效率与稳定性

  • 性能优化
    • 合理设置重写参数:对于 AOF 重写机制,要根据实际数据量和数据变化频率,合理调整auto-aof-rewrite-percentage和auto-aof-rewrite-min-size参数。如果数据量增长较快,可以适当降低auto-aof-rewrite-percentage的值,以便更频繁地触发重写,避免 AOF 文件过大。但也要注意不要过于频繁地重写,以免影响系统性能,因为重写过程中会消耗一定的 CPU 和磁盘 I/O 资源。
    • 调整同步策略:在对数据安全性要求不是极高的场景下,可以考虑将 AOF 的同步策略从always调整为everysec,这样可以显著提高 Redis 的写入性能。但需要注意的是,使用everysec策略时,在服务器发生宕机等异常情况时,可能会丢失最多一秒的数据。如果业务能够接受这种程度的数据丢失风险,那么这种调整是一种有效的性能优化手段。
    • 使用物理机与高速磁盘:Redis 的性能在很大程度上依赖于底层硬件。使用物理机而非虚拟机部署 Redis 服务,可以避免虚拟机带来的性能开销和资源限制。同时,使用高速固态盘作为 AOF 日志的写入盘,可以大大提高磁盘 I/O 的速度,从而提升持久化的性能。因为 AOF 持久化需要频繁地将数据写入磁盘,高速磁盘能够更快地完成写入操作,减少数据在缓冲区的停留时间,降低数据丢失的风险。
  • 问题解决
    • 文件损坏处理:如果 RDB 或 AOF 文件损坏,Redis 在启动时会报错并无法正常加载数据。对于 RDB 文件,可以使用redis-check-rdb命令来检查文件的完整性,并尝试修复。例如,redis-check-rdb dump.rdb会对dump.rdb文件进行检查,如果发现问题会尝试修复。对于 AOF 文件,可以使用redis-check-aof命令,如redis-check-aof appendonly.aof。如果文件损坏不严重,这些命令可能会自动修复文件。如果损坏严重,可能需要从备份中恢复数据,或者根据数据的重要性和可恢复性,采取其他措施,如使用数据恢复工具或手动重建部分数据。
    • 数据丢失解决:当出现数据丢失情况时,首先要分析丢失的原因。如果是因为 RDB 快照间隔过长导致的数据丢失,可以考虑缩短快照间隔或增加 AOF 持久化作为补充。如果是 AOF 同步策略设置不当导致的数据丢失,如使用了no策略且操作系统在将缓冲区数据写入磁盘之前宕机,可以调整为everysec或always策略,并评估对性能的影响。在一些情况下,如果有其他备份数据来源,如定期的数据备份文件或从节点的数据,可以利用这些数据来恢复丢失的数据。同时,为了避免数据丢失,建议在生产环境中采用主从复制和哨兵机制,实现数据的冗余备份和自动故障切换,提高系统的可靠性和数据安全性。

六、总结:Redis 持久化机制的核心要点与未来展望

在本文中,我们深入探讨了 Redis 的两种持久化机制 ——RDB 和 AOF。RDB 通过在特定时间点生成内存数据的快照来实现持久化,其优势在于数据恢复速度快、文件紧凑、对性能影响较小,适用于对数据恢复速度有要求且能容忍一定数据丢失的场景,如缓存数据或大规模数据的备份与恢复。AOF 则是将 Redis 执行的每一个写命令追加到文件中,数据安全性高、文件具有可读性且可通过重写机制控制文件体积,特别适合对数据安全性要求极高的场景,如金融交易系统,或需要详细记录数据操作以便审计和故障排查的情况。

在实际应用中,我们需根据业务的具体需求,精心选择合适的持久化机制,或巧妙结合两者,以实现数据的高效持久化与安全保护。通过合理配置相关参数,如 RDB 的保存路径、触发条件、压缩与校验设置,以及 AOF 的开启与否、同步策略、重写参数等,可以进一步优化 Redis 的持久化性能,确保数据在各种情况下的完整性和可用性。

展望未来,随着技术的不断演进,Redis 的持久化机制有望迎来更多的创新与优化。一方面,性能方面可能会得到进一步提升,例如在数据写入磁盘的速度、内存使用效率等方面。另一方面,数据安全性和可靠性也将持续增强,以应对日益复杂的数据存储挑战。同时,随着云计算、容器化等技术的普及,Redis 的持久化机制可能会更好地与这些技术融合,提供更加灵活、高效的部署方案,满足不同应用场景下的多样化需求,为数据存储领域带来更多的可能性和机遇。

标签:AOF,文件,重写,Redis,详解,RDB,数据,化机制
From: https://blog.csdn.net/qq_42190530/article/details/144662622

相关文章

  • 计算机电源管理模式详解:从待机到休眠的五种状态
    计算机电源管理模式详解:从待机到休眠的五种状态计算机状态S1Standby。即指说系统处于低电源供应状态,在windowsorBIOS中可设定屏幕信号输出关闭、硬盘停止运转进入待机状态、电源灯处于闪烁状态。此时动一动鼠标、按键盘任一键均可叫醒电脑。S2PowerStandby。......
  • 十大排序(详解)---上
    文章目录前言一、冒泡排序   二、插入排序     三、堆排序       四、希尔排序          五、选择排序总结前言   排序算法是计算机科学中用于对元素进行排序的算法。根据不同的需求和数据......
  • Java 项目实战:基于 Spring Boot、MySQL、MyBatis、Redis、Nginx 与 Vue 的电力企业业
    1.项目概述1.1项目背景在电力企业中,员工需要不断提升专业知识和技能,以确保电力系统的安全、稳定运行。传统的培训和考核方式存在效率低、资源浪费等问题。为了满足电力企业对员工培训和考核的需求,提高培训效果和考核效率,降低成本,开发一个功能完善、易于使用的电力企业业务考试......
  • 天地图接口Python代码详解
    天地图是中国国家测绘地理信息局推出的一款权威、全面的在线地理信息系统,提供了丰富的卫星影像、地形、矢量图等地图资源。开发者可以通过天地图提供的API接口,实现地图的展示、搜索、定位等功能。本文将详细介绍如何使用Python调用天地图接口,包括理论概述和详细的代码示例。一、......
  • Linux系统常用命令详解
    文章目录一、Linux概述1、常见的操作系统2、Linux发展史3、Linux目录结构4、终端操作快捷键二、文件和目录操作1、pwd-显示当前目录2、cd-切换目录3、ls-列出目录内容4、mkdir-创建目录5、touch-创建空文件6、cp-复制文件或目录7、mv-移动或重命名文件8、......
  • 精选2025年最新97道Java面试题:spring+Redis+JVM+mysql全在这里了
    一、Java面试题之spring系列(23道)完整版:si我,"666",我一个个发!1、为什么要使用spring?2、解释一下什么是aop?3、解释一下什么是ioc?4、spring有哪些主要模块?5、spring常用的注入方式有哪些?6、spring中的bean是线程安全的吗?7、spring支持几种bean的作用域?8、s......
  • 读书笔记:Redis5设计与源码分析
    Redis5设计与源码分析,陈雷本书赞誉序前言第1章引言11.1Redis简介1Redis由SalvatoreSanfilippo在2009年发布初始版本,开源后不断发展壮大。Redis优点:Redis的工作模式为单线程,不需要线程间的同步操作。Redis采用单线程主要因为其瓶颈在内存和带宽上,而不是CPU。1.2Re......
  • Redis 数据库(上)
    1.Redis入门1.1.Redis概述Redis:是高性能的(Key-Value)分布式内存数据库,基于内存运行,并支持持久化的NoSQL数据库特点:支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用不仅支持简单的key-value类型的数据,同时还提供list、set、zset、ha......
  • Transformers 框架 Pipeline 任务详解(五):表格问答(table-question-answering)
    在自然语言处理领域,表格问答是一项能够从结构化数据中提取信息的关键技术。它结合了自然语言理解和表格数据处理的能力,使得用户可以通过自然语言提问来获取表格中的特定信息。HuggingFace的Transformers框架通过其PipelineAPI提供了强大的table-question-answering功能,允许......
  • DC-1靶场渗透过程详解
    主机发现与端口扫描打开DC-1,确认与主机在同一网段,查看mac地址查看DC-1靶机ip地址sudoarp-scan-l  扫描具体端口信息sudonmap-A-p--sS-sC-T4192.168.100.129端口信息22/tcpopensshOpenSSH6.0p1Debian4+deb7u7(protocol2.0)80/tcpopenhttpApache......