85 lines
3.1 KiB
Diff
85 lines
3.1 KiB
Diff
From e2174244067b02d798e0f12437f0f499c80f91fe Mon Sep 17 00:00:00 2001
|
|
From: Reid Wahl <nrwahl@protonmail.com>
|
|
Date: Tue, 1 Feb 2022 18:55:47 -0800
|
|
Subject: [PATCH] Filesystem: Add support for Amazon EFS mount helper
|
|
|
|
mount.efs, the mount helper for Amazon Elastic File System (EFS)
|
|
provided by amazon-efs-utils [1], is a wrapper for mount.nfs4. It offers
|
|
a number of AWS-specific mount options and some security improvements
|
|
like encryption of data in transit.
|
|
|
|
This commit adds support by treating an fstype=efs like fstype=nfs4 for
|
|
the most part.
|
|
|
|
Resolves: RHBZ#2049319
|
|
|
|
[1] https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html
|
|
|
|
Signed-off-by: Reid Wahl <nrwahl@protonmail.com>
|
|
---
|
|
heartbeat/Filesystem | 14 ++++++++------
|
|
1 file changed, 8 insertions(+), 6 deletions(-)
|
|
|
|
diff --git a/heartbeat/Filesystem b/heartbeat/Filesystem
|
|
index 4d84846c1..1a90d6a42 100755
|
|
--- a/heartbeat/Filesystem
|
|
+++ b/heartbeat/Filesystem
|
|
@@ -341,7 +341,7 @@ determine_blockdevice() {
|
|
# Get the current real device name, if possible.
|
|
# (specified devname could be -L or -U...)
|
|
case "$FSTYPE" in
|
|
- nfs4|nfs|smbfs|cifs|glusterfs|ceph|tmpfs|overlay|overlayfs|rozofs|zfs|cvfs|none|lustre)
|
|
+ nfs4|nfs|efs|smbfs|cifs|glusterfs|ceph|tmpfs|overlay|overlayfs|rozofs|zfs|cvfs|none|lustre)
|
|
: ;;
|
|
*)
|
|
match_string="${TAB}${CANONICALIZED_MOUNTPOINT}${TAB}"
|
|
@@ -423,7 +423,7 @@ is_fsck_needed() {
|
|
no) false;;
|
|
""|auto)
|
|
case "$FSTYPE" in
|
|
- ext4|ext4dev|ext3|reiserfs|reiser4|nss|xfs|jfs|vfat|fat|nfs4|nfs|cifs|smbfs|ocfs2|gfs2|none|lustre|glusterfs|ceph|tmpfs|overlay|overlayfs|rozofs|zfs|cvfs)
|
|
+ ext4|ext4dev|ext3|reiserfs|reiser4|nss|xfs|jfs|vfat|fat|nfs4|nfs|efs|cifs|smbfs|ocfs2|gfs2|none|lustre|glusterfs|ceph|tmpfs|overlay|overlayfs|rozofs|zfs|cvfs)
|
|
false;;
|
|
*)
|
|
true;;
|
|
@@ -450,9 +450,11 @@ fstype_supported()
|
|
return $OCF_SUCCESS
|
|
fi
|
|
|
|
- # support fuse-filesystems (e.g. GlusterFS)
|
|
+ # support fuse-filesystems (e.g. GlusterFS) and Amazon Elastic File
|
|
+ # System (EFS)
|
|
case "$FSTYPE" in
|
|
fuse.*|glusterfs|rozofs) support="fuse";;
|
|
+ efs) support="nfs4";;
|
|
esac
|
|
|
|
if [ "$support" != "$FSTYPE" ]; then
|
|
@@ -701,7 +703,7 @@ Filesystem_stop()
|
|
|
|
# For networked filesystems, there's merit in trying -f:
|
|
case "$FSTYPE" in
|
|
- nfs4|nfs|cifs|smbfs) umount_force="-f" ;;
|
|
+ nfs4|nfs|efs|cifs|smbfs) umount_force="-f" ;;
|
|
esac
|
|
|
|
# Umount all sub-filesystems mounted under $MOUNTPOINT/ too.
|
|
@@ -892,7 +894,7 @@ set_blockdevice_var() {
|
|
|
|
# these are definitely not block devices
|
|
case "$FSTYPE" in
|
|
- nfs4|nfs|smbfs|cifs|none|glusterfs|ceph|tmpfs|overlay|overlayfs|rozofs|zfs|cvfs|lustre) return;;
|
|
+ nfs4|nfs|efs|smbfs|cifs|none|glusterfs|ceph|tmpfs|overlay|overlayfs|rozofs|zfs|cvfs|lustre) return;;
|
|
esac
|
|
|
|
if $(is_option "loop"); then
|
|
@@ -1013,7 +1015,7 @@ is_option "ro" &&
|
|
CLUSTERSAFE=2
|
|
|
|
case "$FSTYPE" in
|
|
-nfs4|nfs|smbfs|cifs|none|gfs2|glusterfs|ceph|ocfs2|overlay|overlayfs|tmpfs|cvfs|lustre)
|
|
+nfs4|nfs|efs|smbfs|cifs|none|gfs2|glusterfs|ceph|ocfs2|overlay|overlayfs|tmpfs|cvfs|lustre)
|
|
CLUSTERSAFE=1 # this is kind of safe too
|
|
;;
|
|
# add here CLUSTERSAFE=0 for all filesystems which are not
|