为什么etcd禁用nfs挂载

在生产环境中,Etcd 禁用 NFS 挂载磁盘主要是因为 NFS 的特性与 Etcd 的高性能和一致性要求不兼容。以下是具体原因:

为什么etcd禁用nfs挂载

1. 一致性问题

Etcd 依赖于高性能和强一致性的存储来保证数据的可靠性和一致性。NFS 由于其分布式文件系统的特性,可能会导致以下一致性问题:

  • 属性缓存(Attribute Caching):NFS 客户端缓存文件属性,这可能导致不同节点看到的文件状态不一致。
  • 写入延迟(Write Latency):NFS 的写操作通常是异步的,这可能导致数据在不同节点之间不一致。

2. 性能问题

Etcd 需要快速的读写性能,以支持高效的共识算法(Raft 算法)和数据存储操作。NFS 由于网络传输和远程存储的特性,存在以下性能问题:

  • 高延迟:每次读写操作都需要通过网络传输,导致延迟较高。这对于 Etcd 的性能至关重要,因为 Etcd 需要频繁地进行磁盘 I/O 操作。
  • 不稳定的吞吐量:NFS 性能受网络状况和服务器负载影响较大,可能导致吞吐量不稳定,这对于依赖稳定性能的 Etcd 是不可接受的。

3. 故障恢复和高可用性

Etcd 依赖于稳定可靠的存储来实现高可用性和快速故障恢复。NFS 存储在以下方面存在局限:

  • 单点故障:NFS 服务器本身可能成为单点故障,影响 Etcd 集群的高可用性。
  • 数据持久性:NFS 的数据持久性和一致性依赖于网络和远程服务器的稳定性,任何网络故障或服务器问题都可能影响 Etcd 的数据持久性。

4. 文件锁定和并发控制

Etcd 需要高效的文件锁定和并发控制机制,以确保数据的一致性和正确性。NFS 在这方面存在以下问题:

  • 文件锁定机制不可靠:NFS 的文件锁定机制可能在高并发环境中表现不稳定,导致数据一致性问题。
  • 并发写入问题:多个客户端同时访问和写入 NFS 文件系统时,可能会导致数据损坏或一致性问题。

基于同样的道理,etcd也不使用san存储(存储区域网络)。

etcd在官网也写的很明白,对于etcd最好的选择就是CPU直连nvme SSD。

NFS的ac和noac是干什么用的

在 NFS(Network File System)挂载过程中,noacac 选项控制客户端缓存行为。以下是它们的区别和具体作用:

ac(Attribute Caching)

  • 默认行为ac 是 NFS 挂载的默认选项,代表启用属性缓存(Attribute Caching)。
  • 缓存机制:客户端会缓存文件属性(如文件大小、时间戳等),以减少与服务器的交互,从而提高性能。
  • 一致性:由于客户端缓存了文件属性信息,文件属性的变更在短时间内可能不会立即反映到其他客户端。这种缓存行为可能导致多个客户端访问同一文件时出现一致性问题。
  • 适用场景:适用于读多写少的场景,如大多数的文件访问操作,能显著提升性能。

noac(No Attribute Caching)

  • 禁用缓存noac 禁用了属性缓存,每次文件操作都会直接与服务器交互,以确保文件属性的最新状态。
  • 一致性:保证文件属性在所有客户端之间的一致性,因为每次操作都会获取最新的文件属性数据。
  • 性能影响:由于禁用了缓存,每次操作都需要与服务器通信,这会显著增加网络流量和延迟,影响性能。
  • 适用场景:适用于要求严格一致性的场景,如多个客户端频繁读写同一文件的情况下,能确保数据一致性。

使用场景示例

启用 ac 的示例(默认)

适用于性能敏感的应用,读多写少的场景:

mount -t nfs -o ac server:/path/to/export /mnt
 

启用 noac 的示例

适用于需要数据一致性的应用,多个客户端频繁读写同一文件:

mount -t nfs -o noac server:/path/to/export /mnt

在mpi并行环境中必需使用noac ,极少会带来不一致的问题,但是如果不使用,则nfs磁盘性能巨降,大量进程会处于IO等待状态。

  • 10
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在开发板上使用 NFS 挂载,需要进行以下步骤: 1. 在开发板上安装 NFS 客户端软件。 2. 在开发板上创建一个本地目录,用于挂载远程 NFS 服务器的共享目录。 3. 在 NFS 服务器上设置共享目录,并配置允许开发板的 IP 地址访问该目录。 4. 在开发板上使用 mount 命令,将远程共享目录挂载到本地目录。 具体的步骤如下: 1. 安装 NFS 客户端软件。 在 Ubuntu 系统上,可以使用以下命令安装 NFS 客户端软件: ``` sudo apt-get update sudo apt-get install nfs-common ``` 2. 创建本地目录。 可以使用 mkdir 命令创建一个本地目录,用于挂载远程共享目录。例如: ``` sudo mkdir /mnt/nfs ``` 3. 设置共享目录。 在 NFS 服务器上,需要设置共享目录,并允许开发板的 IP 地址访问该目录。 假设 NFS 服务器的 IP 地址为 192.168.1.100,共享目录为 /nfs_share,可以在 NFS 服务器上使用以下命令设置共享目录: ``` sudo vi /etc/exports ``` 在文件末尾添加以下内容: ``` /nfs_share 192.168.1.0/24(rw,sync,no_subtree_check) ``` 其中,rw 表示允许读写访问,sync 表示同步写入,no_subtree_check 表示禁用子树检查。 4. 挂载远程共享目录。 在开发板上,使用 mount 命令将远程共享目录挂载到本地目录。例如: ``` sudo mount 192.168.1.100:/nfs_share /mnt/nfs ``` 其中,192.168.1.100 是 NFS 服务器的 IP 地址,/nfs_share 是共享目录的路径,/mnt/nfs 是本地目录的路径。 完成以上步骤后,就可以在开发板上访问远程共享目录了。可以使用 ls 命令查看挂载的目录内容,使用 umount 命令卸载挂载的目录。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值