AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1067160
Accepted
user10489
user10489
Asked: 2021-06-19 17:48:19 +0800 CST2021-06-19 17:48:19 +0800 CST 2021-06-19 17:48:19 +0800 CST

需要一个简单的高可用性文件共享

  • 772

我正在寻找在一对 linux 服务器之间以高可用性方式共享单个文件的最简单方法。(版本和发行版并不重要,我正在寻找一个通用的解决方案。)

我有两台服务器,每台都有自己的本地磁盘和 NFS 共享以及它们之间的其他服务。我有一个两个服务器都需要访问的文件,但除了这些服务器之外没有其他需要访问它的文件。

如果任一服务器崩溃,我希望该文件的最新可能内容可用于其余服务器。(显然,其他服务器应该在恢复时获取更改。)

该文件是一个状态文件,一次可能只有一个服务器会写入它。状态文件大小未知,但很小。大概在1块到2M之间。状态文件的大小可能会根据停机时间的长短而增长。

在不添加外部硬件的情况下,像这样的高可用性文件共享有哪些选择?

linux network-share high-availability
  • 2 2 个回答
  • 291 Views

2 个回答

  • Voted
  1. Best Answer
    Kszysiu
    2021-07-01T08:00:20+08:002021-07-01T08:00:20+08:00

    有很多解决方案——对于一个文件,我可能会使用 GlusterFS——但我认为你应该有 3 台服务器用于仲裁,否则你将不得不在恢复时解决脑裂问题。您应该能够在每个流行的发行版上轻松安装它,并且配置它不超过一小时。

    • 1
  2. chutz
    2021-07-01T16:29:32+08:002021-07-01T16:29:32+08:00

    如果这对服务器以冷热方式运行(即,一次只有一个服务器访问文件),DRBD是一种快速而稳定的方式来实现您的目标。DRBD 的设计具有脑裂保护,因此它应该“足够好”。

    来自 DRBD 网站的简短介绍:

    分布式复制块设备 (DRBD) 是一种基于软件的、无共享的复制存储解决方案,可在主机之间镜像块设备(硬盘、分区、逻辑卷等)的内容。

    DRBD 镜像数据

    • 实时。当应用程序修改设备上的数据时,复制会不断发生。
    • 透明地。应用程序不需要知道数据存储在多个主机上。
    • 同步或异步。使用同步镜像,在所有主机上执行写入后,应用程序会收到写入完成的通知。使用异步镜像,当本地写入完成时,应用程序会收到写入完成的通知,这通常是在它们传播到其他主机之前。

    由于这是块级复制,因此您需要一些额外的配置。例如,您必须在复制的设备上创建一个文件系统,并且您需要挂载该文​​件系统。默认的推荐配置只允许一台主机挂载文件系统(以避免出现脑裂情况),因此您一次只能访问一个节点上的数据。

    整个过程都有很好的记录,并且还有一些简单的指南可用。

    如果您更喜欢自动化,Pacemaker + DRBD是一个非常常见的组合,它甚至记录在Pacemaker 指南中,这也是 DRBD 本身的一个很好的介绍。

    PS 有趣的是,我在上面链接的 DRBD 起搏器指南几乎完美地描述了您的问题。

    即使您提供静态网站,必须手动将该网站的内容同步到集群中的所有机器也不是理想的选择。对于动态网站,例如 wiki,它甚至不是一个选项。不是每个人都能负担得起网络附加存储,但不知何故,数据需要保持同步。

    进入 DRBD,它可以被认为是基于网络的 RAID-1。

    • 1

相关问题

  • 多操作系统环境的首选电子邮件客户端

  • 你最喜欢的 Linux 发行版是什么?[关闭]

  • 更改 PHP 的默认配置设置?

  • 保护新的 Ubuntu 服务器 [关闭]

  • (软)Ubuntu 7.10 上的 RAID 6,我应该迁移到 8.10 吗?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve