|
|
74b1de |
From 1fb89973551937f34f24b45e07072a6ce6c30ff9 Mon Sep 17 00:00:00 2001
|
|
|
d1681e |
From: Jiffin Tony Thottan <jthottan@redhat.com>
|
|
|
d1681e |
Date: Mon, 16 Oct 2017 14:18:31 +0530
|
|
|
74b1de |
Subject: [PATCH 053/124] Revert "packaging: (ganesha) remove glusterfs-ganesha
|
|
|
d1681e |
subpackage and related files)"
|
|
|
d1681e |
|
|
|
d1681e |
This reverts commit 0cf2963f12a8b540a7042605d8c79f638fdf6cee.
|
|
|
d1681e |
|
|
|
74b1de |
Label: DOWNSTREAM ONLY
|
|
|
74b1de |
|
|
|
d1681e |
Change-Id: Id6e7585021bd4dd78a59580cfa4838bdd4e539a0
|
|
|
d1681e |
Signed-off-by: Jiffin Tony Thottan <jthottan@redhat.com>
|
|
|
74b1de |
Reviewed-on: https://code.engineering.redhat.com/gerrit/167102
|
|
|
74b1de |
Reviewed-by: Soumya Koduri <skoduri@redhat.com>
|
|
|
74b1de |
Tested-by: RHGS Build Bot <nigelb@redhat.com>
|
|
|
74b1de |
Reviewed-by: Sunil Kumar Heggodu Gopala Acharya <sheggodu@redhat.com>
|
|
|
d1681e |
---
|
|
|
d1681e |
configure.ac | 3 +
|
|
|
74b1de |
extras/Makefile.am | 3 +-
|
|
|
d1681e |
extras/ganesha/Makefile.am | 2 +
|
|
|
d1681e |
extras/ganesha/config/Makefile.am | 4 +
|
|
|
d1681e |
extras/ganesha/config/ganesha-ha.conf.sample | 19 ++++
|
|
|
d1681e |
extras/ganesha/scripts/Makefile.am | 4 +
|
|
|
d1681e |
extras/ganesha/scripts/create-export-ganesha.sh | 91 +++++++++++++++
|
|
|
74b1de |
extras/ganesha/scripts/dbus-send.sh | 60 ++++++++++
|
|
|
d1681e |
extras/ganesha/scripts/generate-epoch.py | 48 ++++++++
|
|
|
d1681e |
extras/hook-scripts/start/post/Makefile.am | 2 +-
|
|
|
d1681e |
extras/hook-scripts/start/post/S31ganesha-start.sh | 122 +++++++++++++++++++++
|
|
|
74b1de |
glusterfs.spec.in | 44 +++++++-
|
|
|
74b1de |
12 files changed, 396 insertions(+), 6 deletions(-)
|
|
|
d1681e |
create mode 100644 extras/ganesha/Makefile.am
|
|
|
d1681e |
create mode 100644 extras/ganesha/config/Makefile.am
|
|
|
d1681e |
create mode 100644 extras/ganesha/config/ganesha-ha.conf.sample
|
|
|
d1681e |
create mode 100644 extras/ganesha/scripts/Makefile.am
|
|
|
d1681e |
create mode 100755 extras/ganesha/scripts/create-export-ganesha.sh
|
|
|
d1681e |
create mode 100755 extras/ganesha/scripts/dbus-send.sh
|
|
|
d1681e |
create mode 100755 extras/ganesha/scripts/generate-epoch.py
|
|
|
d1681e |
create mode 100755 extras/hook-scripts/start/post/S31ganesha-start.sh
|
|
|
d1681e |
|
|
|
d1681e |
diff --git a/configure.ac b/configure.ac
|
|
|
74b1de |
index 0d06f5a..125ae29 100644
|
|
|
d1681e |
--- a/configure.ac
|
|
|
d1681e |
+++ b/configure.ac
|
|
|
74b1de |
@@ -196,6 +196,9 @@ AC_CONFIG_FILES([Makefile
|
|
|
d1681e |
extras/init.d/glustereventsd-Debian
|
|
|
d1681e |
extras/init.d/glustereventsd-Redhat
|
|
|
d1681e |
extras/init.d/glustereventsd-FreeBSD
|
|
|
d1681e |
+ extras/ganesha/Makefile
|
|
|
d1681e |
+ extras/ganesha/config/Makefile
|
|
|
d1681e |
+ extras/ganesha/scripts/Makefile
|
|
|
d1681e |
extras/systemd/Makefile
|
|
|
d1681e |
extras/systemd/glusterd.service
|
|
|
d1681e |
extras/systemd/glustereventsd.service
|
|
|
d1681e |
diff --git a/extras/Makefile.am b/extras/Makefile.am
|
|
|
74b1de |
index ff5ca9b..983f014 100644
|
|
|
d1681e |
--- a/extras/Makefile.am
|
|
|
d1681e |
+++ b/extras/Makefile.am
|
|
|
74b1de |
@@ -11,7 +11,8 @@ EditorModedir = $(docdir)
|
|
|
d1681e |
EditorMode_DATA = glusterfs-mode.el glusterfs.vim
|
|
|
d1681e |
|
|
|
d1681e |
SUBDIRS = init.d systemd benchmarking hook-scripts $(OCF_SUBDIR) LinuxRPM \
|
|
|
74b1de |
- $(GEOREP_EXTRAS_SUBDIR) snap_scheduler firewalld cliutils python
|
|
|
74b1de |
+ $(GEOREP_EXTRAS_SUBDIR) snap_scheduler firewalld cliutils python \
|
|
|
74b1de |
+ ganesha
|
|
|
d1681e |
|
|
|
d1681e |
confdir = $(sysconfdir)/glusterfs
|
|
|
74b1de |
if WITH_SERVER
|
|
|
d1681e |
diff --git a/extras/ganesha/Makefile.am b/extras/ganesha/Makefile.am
|
|
|
d1681e |
new file mode 100644
|
|
|
d1681e |
index 0000000..542de68
|
|
|
d1681e |
--- /dev/null
|
|
|
d1681e |
+++ b/extras/ganesha/Makefile.am
|
|
|
d1681e |
@@ -0,0 +1,2 @@
|
|
|
d1681e |
+SUBDIRS = scripts config
|
|
|
d1681e |
+CLEANFILES =
|
|
|
d1681e |
diff --git a/extras/ganesha/config/Makefile.am b/extras/ganesha/config/Makefile.am
|
|
|
d1681e |
new file mode 100644
|
|
|
d1681e |
index 0000000..c729273
|
|
|
d1681e |
--- /dev/null
|
|
|
d1681e |
+++ b/extras/ganesha/config/Makefile.am
|
|
|
d1681e |
@@ -0,0 +1,4 @@
|
|
|
d1681e |
+EXTRA_DIST= ganesha-ha.conf.sample
|
|
|
d1681e |
+
|
|
|
d1681e |
+confdir = $(sysconfdir)/ganesha
|
|
|
d1681e |
+conf_DATA = ganesha-ha.conf.sample
|
|
|
d1681e |
diff --git a/extras/ganesha/config/ganesha-ha.conf.sample b/extras/ganesha/config/ganesha-ha.conf.sample
|
|
|
d1681e |
new file mode 100644
|
|
|
d1681e |
index 0000000..c22892b
|
|
|
d1681e |
--- /dev/null
|
|
|
d1681e |
+++ b/extras/ganesha/config/ganesha-ha.conf.sample
|
|
|
d1681e |
@@ -0,0 +1,19 @@
|
|
|
d1681e |
+# Name of the HA cluster created.
|
|
|
d1681e |
+# must be unique within the subnet
|
|
|
d1681e |
+HA_NAME="ganesha-ha-360"
|
|
|
d1681e |
+#
|
|
|
d1681e |
+# N.B. you may use short names or long names; you may not use IP addrs.
|
|
|
d1681e |
+# Once you select one, stay with it as it will be mildly unpleasant to
|
|
|
d1681e |
+# clean up if you switch later on. Ensure that all names - short and/or
|
|
|
d1681e |
+# long - are in DNS or /etc/hosts on all machines in the cluster.
|
|
|
d1681e |
+#
|
|
|
d1681e |
+# The subset of nodes of the Gluster Trusted Pool that form the ganesha
|
|
|
d1681e |
+# HA cluster. Hostname is specified.
|
|
|
d1681e |
+HA_CLUSTER_NODES="server1,server2,..."
|
|
|
d1681e |
+#HA_CLUSTER_NODES="server1.lab.redhat.com,server2.lab.redhat.com,..."
|
|
|
d1681e |
+#
|
|
|
d1681e |
+# Virtual IPs for each of the nodes specified above.
|
|
|
d1681e |
+VIP_server1="10.0.2.1"
|
|
|
d1681e |
+VIP_server2="10.0.2.2"
|
|
|
d1681e |
+#VIP_server1_lab_redhat_com="10.0.2.1"
|
|
|
d1681e |
+#VIP_server2_lab_redhat_com="10.0.2.2"
|
|
|
d1681e |
diff --git a/extras/ganesha/scripts/Makefile.am b/extras/ganesha/scripts/Makefile.am
|
|
|
d1681e |
new file mode 100644
|
|
|
74b1de |
index 0000000..00a2c45
|
|
|
d1681e |
--- /dev/null
|
|
|
d1681e |
+++ b/extras/ganesha/scripts/Makefile.am
|
|
|
d1681e |
@@ -0,0 +1,4 @@
|
|
|
d1681e |
+EXTRA_DIST= create-export-ganesha.sh generate-epoch.py dbus-send.sh
|
|
|
d1681e |
+
|
|
|
d1681e |
+scriptsdir = $(libexecdir)/ganesha
|
|
|
74b1de |
+scripts_SCRIPTS = create-export-ganesha.sh dbus-send.sh generate-epoch.py
|
|
|
d1681e |
diff --git a/extras/ganesha/scripts/create-export-ganesha.sh b/extras/ganesha/scripts/create-export-ganesha.sh
|
|
|
d1681e |
new file mode 100755
|
|
|
d1681e |
index 0000000..1ffba42
|
|
|
d1681e |
--- /dev/null
|
|
|
d1681e |
+++ b/extras/ganesha/scripts/create-export-ganesha.sh
|
|
|
d1681e |
@@ -0,0 +1,91 @@
|
|
|
d1681e |
+#!/bin/bash
|
|
|
d1681e |
+
|
|
|
d1681e |
+#This script is called by glusterd when the user
|
|
|
d1681e |
+#tries to export a volume via NFS-Ganesha.
|
|
|
d1681e |
+#An export file specific to a volume
|
|
|
d1681e |
+#is created in GANESHA_DIR/exports.
|
|
|
d1681e |
+
|
|
|
d1681e |
+# Try loading the config from any of the distro
|
|
|
d1681e |
+# specific configuration locations
|
|
|
d1681e |
+if [ -f /etc/sysconfig/ganesha ]
|
|
|
d1681e |
+ then
|
|
|
d1681e |
+ . /etc/sysconfig/ganesha
|
|
|
d1681e |
+fi
|
|
|
d1681e |
+if [ -f /etc/conf.d/ganesha ]
|
|
|
d1681e |
+ then
|
|
|
d1681e |
+ . /etc/conf.d/ganesha
|
|
|
d1681e |
+fi
|
|
|
d1681e |
+if [ -f /etc/default/ganesha ]
|
|
|
d1681e |
+ then
|
|
|
d1681e |
+ . /etc/default/ganesha
|
|
|
d1681e |
+fi
|
|
|
d1681e |
+
|
|
|
d1681e |
+GANESHA_DIR=${1%/}
|
|
|
d1681e |
+OPTION=$2
|
|
|
d1681e |
+VOL=$3
|
|
|
d1681e |
+CONF=$GANESHA_DIR"/ganesha.conf"
|
|
|
d1681e |
+declare -i EXPORT_ID
|
|
|
d1681e |
+
|
|
|
d1681e |
+function check_cmd_status()
|
|
|
d1681e |
+{
|
|
|
d1681e |
+ if [ "$1" != "0" ]
|
|
|
d1681e |
+ then
|
|
|
d1681e |
+ rm -rf $GANESHA_DIR/exports/export.$VOL.conf
|
|
|
d1681e |
+ sed -i /$VOL.conf/d $CONF
|
|
|
d1681e |
+ exit 1
|
|
|
d1681e |
+ fi
|
|
|
d1681e |
+}
|
|
|
d1681e |
+
|
|
|
d1681e |
+
|
|
|
d1681e |
+if [ ! -d "$GANESHA_DIR/exports" ];
|
|
|
d1681e |
+ then
|
|
|
d1681e |
+ mkdir $GANESHA_DIR/exports
|
|
|
d1681e |
+ check_cmd_status `echo $?`
|
|
|
d1681e |
+fi
|
|
|
d1681e |
+
|
|
|
d1681e |
+function write_conf()
|
|
|
d1681e |
+{
|
|
|
d1681e |
+echo -e "# WARNING : Using Gluster CLI will overwrite manual
|
|
|
d1681e |
+# changes made to this file. To avoid it, edit the
|
|
|
d1681e |
+# file and run ganesha-ha.sh --refresh-config."
|
|
|
d1681e |
+
|
|
|
d1681e |
+echo "EXPORT{"
|
|
|
d1681e |
+echo " Export_Id = 2;"
|
|
|
d1681e |
+echo " Path = \"/$VOL\";"
|
|
|
d1681e |
+echo " FSAL {"
|
|
|
d1681e |
+echo " name = "GLUSTER";"
|
|
|
d1681e |
+echo " hostname=\"localhost\";"
|
|
|
d1681e |
+echo " volume=\"$VOL\";"
|
|
|
d1681e |
+echo " }"
|
|
|
d1681e |
+echo " Access_type = RW;"
|
|
|
d1681e |
+echo " Disable_ACL = true;"
|
|
|
d1681e |
+echo ' Squash="No_root_squash";'
|
|
|
d1681e |
+echo " Pseudo=\"/$VOL\";"
|
|
|
d1681e |
+echo ' Protocols = "3", "4" ;'
|
|
|
d1681e |
+echo ' Transports = "UDP","TCP";'
|
|
|
d1681e |
+echo ' SecType = "sys";'
|
|
|
d1681e |
+echo " }"
|
|
|
d1681e |
+}
|
|
|
d1681e |
+if [ "$OPTION" = "on" ];
|
|
|
d1681e |
+then
|
|
|
d1681e |
+ if ! (cat $CONF | grep $VOL.conf\"$ )
|
|
|
d1681e |
+ then
|
|
|
d1681e |
+ write_conf $@ > $GANESHA_DIR/exports/export.$VOL.conf
|
|
|
d1681e |
+ echo "%include \"$GANESHA_DIR/exports/export.$VOL.conf\"" >> $CONF
|
|
|
d1681e |
+ count=`ls -l $GANESHA_DIR/exports/*.conf | wc -l`
|
|
|
d1681e |
+ if [ "$count" = "1" ] ; then
|
|
|
d1681e |
+ EXPORT_ID=2
|
|
|
d1681e |
+ else
|
|
|
d1681e |
+ EXPORT_ID=`cat $GANESHA_DIR/.export_added`
|
|
|
d1681e |
+ check_cmd_status `echo $?`
|
|
|
d1681e |
+ EXPORT_ID=EXPORT_ID+1
|
|
|
d1681e |
+ sed -i s/Export_Id.*/"Export_Id= $EXPORT_ID ;"/ \
|
|
|
d1681e |
+ $GANESHA_DIR/exports/export.$VOL.conf
|
|
|
d1681e |
+ check_cmd_status `echo $?`
|
|
|
d1681e |
+ fi
|
|
|
d1681e |
+ echo $EXPORT_ID > $GANESHA_DIR/.export_added
|
|
|
d1681e |
+ fi
|
|
|
d1681e |
+else
|
|
|
d1681e |
+ rm -rf $GANESHA_DIR/exports/export.$VOL.conf
|
|
|
d1681e |
+ sed -i /$VOL.conf/d $CONF
|
|
|
d1681e |
+fi
|
|
|
d1681e |
diff --git a/extras/ganesha/scripts/dbus-send.sh b/extras/ganesha/scripts/dbus-send.sh
|
|
|
d1681e |
new file mode 100755
|
|
|
74b1de |
index 0000000..ec8d948
|
|
|
d1681e |
--- /dev/null
|
|
|
d1681e |
+++ b/extras/ganesha/scripts/dbus-send.sh
|
|
|
74b1de |
@@ -0,0 +1,60 @@
|
|
|
d1681e |
+#!/bin/bash
|
|
|
d1681e |
+
|
|
|
d1681e |
+# Try loading the config from any of the distro
|
|
|
d1681e |
+# specific configuration locations
|
|
|
d1681e |
+if [ -f /etc/sysconfig/ganesha ]
|
|
|
d1681e |
+ then
|
|
|
d1681e |
+ . /etc/sysconfig/ganesha
|
|
|
d1681e |
+fi
|
|
|
d1681e |
+if [ -f /etc/conf.d/ganesha ]
|
|
|
d1681e |
+ then
|
|
|
d1681e |
+ . /etc/conf.d/ganesha
|
|
|
d1681e |
+fi
|
|
|
d1681e |
+if [ -f /etc/default/ganesha ]
|
|
|
d1681e |
+ then
|
|
|
d1681e |
+ . /etc/default/ganesha
|
|
|
d1681e |
+fi
|
|
|
d1681e |
+
|
|
|
d1681e |
+GANESHA_DIR=${1%/}
|
|
|
d1681e |
+OPTION=$2
|
|
|
d1681e |
+VOL=$3
|
|
|
d1681e |
+CONF=$GANESHA_DIR"/ganesha.conf"
|
|
|
d1681e |
+
|
|
|
d1681e |
+function check_cmd_status()
|
|
|
d1681e |
+{
|
|
|
d1681e |
+ if [ "$1" != "0" ]
|
|
|
d1681e |
+ then
|
|
|
d1681e |
+ logger "dynamic export failed on node :${hostname -s}"
|
|
|
d1681e |
+ fi
|
|
|
d1681e |
+}
|
|
|
d1681e |
+
|
|
|
d1681e |
+#This function keeps track of export IDs and increments it with every new entry
|
|
|
d1681e |
+function dynamic_export_add()
|
|
|
d1681e |
+{
|
|
|
d1681e |
+ dbus-send --system \
|
|
|
d1681e |
+--dest=org.ganesha.nfsd /org/ganesha/nfsd/ExportMgr \
|
|
|
d1681e |
+org.ganesha.nfsd.exportmgr.AddExport string:$GANESHA_DIR/exports/export.$VOL.conf \
|
|
|
d1681e |
+string:"EXPORT(Path=/$VOL)"
|
|
|
d1681e |
+ check_cmd_status `echo $?`
|
|
|
d1681e |
+}
|
|
|
d1681e |
+
|
|
|
d1681e |
+#This function removes an export dynamically(uses the export_id of the export)
|
|
|
d1681e |
+function dynamic_export_remove()
|
|
|
d1681e |
+{
|
|
|
d1681e |
+ removed_id=`cat $GANESHA_DIR/exports/export.$VOL.conf |\
|
|
|
d1681e |
+grep Export_Id | awk -F"[=,;]" '{print$2}'| tr -d '[[:space:]]'`
|
|
|
d1681e |
+ dbus-send --print-reply --system \
|
|
|
d1681e |
+--dest=org.ganesha.nfsd /org/ganesha/nfsd/ExportMgr \
|
|
|
d1681e |
+org.ganesha.nfsd.exportmgr.RemoveExport uint16:$removed_id
|
|
|
d1681e |
+ check_cmd_status `echo $?`
|
|
|
d1681e |
+}
|
|
|
d1681e |
+
|
|
|
d1681e |
+if [ "$OPTION" = "on" ];
|
|
|
d1681e |
+then
|
|
|
d1681e |
+ dynamic_export_add $@
|
|
|
d1681e |
+fi
|
|
|
d1681e |
+
|
|
|
d1681e |
+if [ "$OPTION" = "off" ];
|
|
|
d1681e |
+then
|
|
|
d1681e |
+ dynamic_export_remove $@
|
|
|
d1681e |
+fi
|
|
|
d1681e |
diff --git a/extras/ganesha/scripts/generate-epoch.py b/extras/ganesha/scripts/generate-epoch.py
|
|
|
d1681e |
new file mode 100755
|
|
|
d1681e |
index 0000000..5db5e56
|
|
|
d1681e |
--- /dev/null
|
|
|
d1681e |
+++ b/extras/ganesha/scripts/generate-epoch.py
|
|
|
d1681e |
@@ -0,0 +1,48 @@
|
|
|
d1681e |
+#!/usr/bin/python
|
|
|
d1681e |
+#
|
|
|
d1681e |
+# Copyright (c) 2016 Red Hat, Inc. <http://www.redhat.com>
|
|
|
d1681e |
+# This file is part of GlusterFS.
|
|
|
d1681e |
+#
|
|
|
d1681e |
+# This file is licensed to you under your choice of the GNU Lesser
|
|
|
d1681e |
+# General Public License, version 3 or any later version (LGPLv3 or
|
|
|
d1681e |
+# later), or the GNU General Public License, version 2 (GPLv2), in all
|
|
|
d1681e |
+# cases as published by the Free Software Foundation.
|
|
|
d1681e |
+#
|
|
|
d1681e |
+# Generates unique epoch value on each gluster node to be used by
|
|
|
d1681e |
+# nfs-ganesha service on that node.
|
|
|
d1681e |
+#
|
|
|
d1681e |
+# Configure 'EPOCH_EXEC' option to this script path in
|
|
|
d1681e |
+# '/etc/sysconfig/ganesha' file used by nfs-ganesha service.
|
|
|
d1681e |
+#
|
|
|
d1681e |
+# Construct epoch as follows -
|
|
|
d1681e |
+# first 32-bit contains the now() time
|
|
|
d1681e |
+# rest 32-bit value contains the local glusterd node uuid
|
|
|
d1681e |
+
|
|
|
d1681e |
+import time
|
|
|
d1681e |
+import binascii
|
|
|
d1681e |
+
|
|
|
d1681e |
+# Calculate the now() time into a 64-bit integer value
|
|
|
d1681e |
+def epoch_now():
|
|
|
d1681e |
+ epoch_time = int(time.mktime(time.localtime())) << 32
|
|
|
d1681e |
+ return epoch_time
|
|
|
d1681e |
+
|
|
|
d1681e |
+# Read glusterd UUID and extract first 32-bit of it
|
|
|
d1681e |
+def epoch_uuid():
|
|
|
d1681e |
+ file_name = '/var/lib/glusterd/glusterd.info'
|
|
|
d1681e |
+
|
|
|
d1681e |
+ for line in open(file_name):
|
|
|
d1681e |
+ if "UUID" in line:
|
|
|
d1681e |
+ glusterd_uuid = line.split('=')[1].strip()
|
|
|
d1681e |
+
|
|
|
d1681e |
+ uuid_bin = binascii.unhexlify(glusterd_uuid.replace("-",""))
|
|
|
d1681e |
+
|
|
|
d1681e |
+ epoch_uuid = int(uuid_bin.encode('hex'), 32) & 0xFFFF0000
|
|
|
d1681e |
+ return epoch_uuid
|
|
|
d1681e |
+
|
|
|
d1681e |
+# Construct epoch as follows -
|
|
|
d1681e |
+# first 32-bit contains the now() time
|
|
|
d1681e |
+# rest 32-bit value contains the local glusterd node uuid
|
|
|
d1681e |
+epoch = (epoch_now() | epoch_uuid())
|
|
|
d1681e |
+print str(epoch)
|
|
|
d1681e |
+
|
|
|
d1681e |
+exit(0)
|
|
|
d1681e |
diff --git a/extras/hook-scripts/start/post/Makefile.am b/extras/hook-scripts/start/post/Makefile.am
|
|
|
74b1de |
index e32546d..792019d 100644
|
|
|
d1681e |
--- a/extras/hook-scripts/start/post/Makefile.am
|
|
|
d1681e |
+++ b/extras/hook-scripts/start/post/Makefile.am
|
|
|
d1681e |
@@ -1,4 +1,4 @@
|
|
|
d1681e |
-EXTRA_DIST = S29CTDBsetup.sh S30samba-start.sh
|
|
|
d1681e |
+EXTRA_DIST = S29CTDBsetup.sh S30samba-start.sh S31ganesha-start.sh
|
|
|
d1681e |
|
|
|
d1681e |
hookdir = $(GLUSTERD_WORKDIR)/hooks/1/start/post/
|
|
|
74b1de |
if WITH_SERVER
|
|
|
d1681e |
diff --git a/extras/hook-scripts/start/post/S31ganesha-start.sh b/extras/hook-scripts/start/post/S31ganesha-start.sh
|
|
|
d1681e |
new file mode 100755
|
|
|
d1681e |
index 0000000..90ba6bc
|
|
|
d1681e |
--- /dev/null
|
|
|
d1681e |
+++ b/extras/hook-scripts/start/post/S31ganesha-start.sh
|
|
|
d1681e |
@@ -0,0 +1,122 @@
|
|
|
d1681e |
+#!/bin/bash
|
|
|
d1681e |
+PROGNAME="Sganesha-start"
|
|
|
d1681e |
+OPTSPEC="volname:,gd-workdir:"
|
|
|
d1681e |
+VOL=
|
|
|
d1681e |
+declare -i EXPORT_ID
|
|
|
d1681e |
+ganesha_key="ganesha.enable"
|
|
|
d1681e |
+GANESHA_DIR="/var/run/gluster/shared_storage/nfs-ganesha"
|
|
|
d1681e |
+CONF1="$GANESHA_DIR/ganesha.conf"
|
|
|
d1681e |
+GLUSTERD_WORKDIR=
|
|
|
d1681e |
+
|
|
|
d1681e |
+function parse_args ()
|
|
|
d1681e |
+{
|
|
|
d1681e |
+ ARGS=$(getopt -l $OPTSPEC -o "o" -name $PROGNAME $@)
|
|
|
d1681e |
+ eval set -- "$ARGS"
|
|
|
d1681e |
+
|
|
|
d1681e |
+ while true; do
|
|
|
d1681e |
+ case $1 in
|
|
|
d1681e |
+ --volname)
|
|
|
d1681e |
+ shift
|
|
|
d1681e |
+ VOL=$1
|
|
|
d1681e |
+ ;;
|
|
|
d1681e |
+ --gd-workdir)
|
|
|
d1681e |
+ shift
|
|
|
d1681e |
+ GLUSTERD_WORKDIR=$1
|
|
|
d1681e |
+ ;;
|
|
|
d1681e |
+ *)
|
|
|
d1681e |
+ shift
|
|
|
d1681e |
+ break
|
|
|
d1681e |
+ ;;
|
|
|
d1681e |
+ esac
|
|
|
d1681e |
+ shift
|
|
|
d1681e |
+ done
|
|
|
d1681e |
+}
|
|
|
d1681e |
+
|
|
|
d1681e |
+
|
|
|
d1681e |
+
|
|
|
d1681e |
+#This function generates a new export entry as export.volume_name.conf
|
|
|
d1681e |
+function write_conf()
|
|
|
d1681e |
+{
|
|
|
d1681e |
+echo -e "# WARNING : Using Gluster CLI will overwrite manual
|
|
|
d1681e |
+# changes made to this file. To avoid it, edit the
|
|
|
d1681e |
+# file, copy it over to all the NFS-Ganesha nodes
|
|
|
d1681e |
+# and run ganesha-ha.sh --refresh-config."
|
|
|
d1681e |
+
|
|
|
d1681e |
+echo "EXPORT{"
|
|
|
d1681e |
+echo " Export_Id = 2;"
|
|
|
d1681e |
+echo " Path = \"/$VOL\";"
|
|
|
d1681e |
+echo " FSAL {"
|
|
|
d1681e |
+echo " name = \"GLUSTER\";"
|
|
|
d1681e |
+echo " hostname=\"localhost\";"
|
|
|
d1681e |
+echo " volume=\"$VOL\";"
|
|
|
d1681e |
+echo " }"
|
|
|
d1681e |
+echo " Access_type = RW;"
|
|
|
d1681e |
+echo " Disable_ACL = true;"
|
|
|
d1681e |
+echo " Squash=\"No_root_squash\";"
|
|
|
d1681e |
+echo " Pseudo=\"/$VOL\";"
|
|
|
d1681e |
+echo " Protocols = \"3\", \"4\" ;"
|
|
|
d1681e |
+echo " Transports = \"UDP\",\"TCP\";"
|
|
|
d1681e |
+echo " SecType = \"sys\";"
|
|
|
d1681e |
+echo "}"
|
|
|
d1681e |
+}
|
|
|
d1681e |
+
|
|
|
d1681e |
+#It adds the export dynamically by sending dbus signals
|
|
|
d1681e |
+function export_add()
|
|
|
d1681e |
+{
|
|
|
d1681e |
+ dbus-send --print-reply --system --dest=org.ganesha.nfsd \
|
|
|
d1681e |
+/org/ganesha/nfsd/ExportMgr org.ganesha.nfsd.exportmgr.AddExport \
|
|
|
d1681e |
+string:$GANESHA_DIR/exports/export.$VOL.conf string:"EXPORT(Export_Id=$EXPORT_ID)"
|
|
|
d1681e |
+
|
|
|
d1681e |
+}
|
|
|
d1681e |
+
|
|
|
d1681e |
+# based on src/scripts/ganeshactl/Ganesha/export_mgr.py
|
|
|
d1681e |
+function is_exported()
|
|
|
d1681e |
+{
|
|
|
d1681e |
+ local volume="${1}"
|
|
|
d1681e |
+
|
|
|
d1681e |
+ dbus-send --type=method_call --print-reply --system \
|
|
|
d1681e |
+ --dest=org.ganesha.nfsd /org/ganesha/nfsd/ExportMgr \
|
|
|
d1681e |
+ org.ganesha.nfsd.exportmgr.ShowExports \
|
|
|
d1681e |
+ | grep -w -q "/${volume}"
|
|
|
d1681e |
+
|
|
|
d1681e |
+ return $?
|
|
|
d1681e |
+}
|
|
|
d1681e |
+
|
|
|
d1681e |
+# Check the info file (contains the volume options) to see if Ganesha is
|
|
|
d1681e |
+# enabled for this volume.
|
|
|
d1681e |
+function ganesha_enabled()
|
|
|
d1681e |
+{
|
|
|
d1681e |
+ local volume="${1}"
|
|
|
d1681e |
+ local info_file="${GLUSTERD_WORKDIR}/vols/${VOL}/info"
|
|
|
d1681e |
+ local enabled="off"
|
|
|
d1681e |
+
|
|
|
d1681e |
+ enabled=$(grep -w ${ganesha_key} ${info_file} | cut -d"=" -f2)
|
|
|
d1681e |
+
|
|
|
d1681e |
+ [ "${enabled}" == "on" ]
|
|
|
d1681e |
+
|
|
|
d1681e |
+ return $?
|
|
|
d1681e |
+}
|
|
|
d1681e |
+
|
|
|
d1681e |
+parse_args $@
|
|
|
d1681e |
+
|
|
|
d1681e |
+if ganesha_enabled ${VOL} && ! is_exported ${VOL}
|
|
|
d1681e |
+then
|
|
|
d1681e |
+ if [ ! -e ${GANESHA_DIR}/exports/export.${VOL}.conf ]
|
|
|
d1681e |
+ then
|
|
|
d1681e |
+ #Remove export entry from nfs-ganesha.conf
|
|
|
d1681e |
+ sed -i /$VOL.conf/d $CONF1
|
|
|
d1681e |
+ write_conf ${VOL} > ${GANESHA_DIR}/exports/export.${VOL}.conf
|
|
|
d1681e |
+ EXPORT_ID=`cat $GANESHA_DIR/.export_added`
|
|
|
d1681e |
+ EXPORT_ID=EXPORT_ID+1
|
|
|
d1681e |
+ echo $EXPORT_ID > $GANESHA_DIR/.export_added
|
|
|
d1681e |
+ sed -i s/Export_Id.*/"Export_Id=$EXPORT_ID;"/ \
|
|
|
d1681e |
+ $GANESHA_DIR/exports/export.$VOL.conf
|
|
|
d1681e |
+ echo "%include \"$GANESHA_DIR/exports/export.$VOL.conf\"" >> $CONF1
|
|
|
d1681e |
+ else
|
|
|
d1681e |
+ EXPORT_ID=$(grep ^[[:space:]]*Export_Id $GANESHA_DIR/exports/export.$VOL.conf |\
|
|
|
d1681e |
+ awk -F"[=,;]" '{print $2}' | tr -d '[[:space:]]')
|
|
|
d1681e |
+ fi
|
|
|
d1681e |
+ export_add $VOL
|
|
|
d1681e |
+fi
|
|
|
d1681e |
+
|
|
|
d1681e |
+exit 0
|
|
|
d1681e |
diff --git a/glusterfs.spec.in b/glusterfs.spec.in
|
|
|
74b1de |
index 0d57b49..dd7438c 100644
|
|
|
d1681e |
--- a/glusterfs.spec.in
|
|
|
d1681e |
+++ b/glusterfs.spec.in
|
|
|
74b1de |
@@ -299,7 +299,6 @@ Obsoletes: hekafs
|
|
|
d1681e |
Obsoletes: %{name}-common < %{version}-%{release}
|
|
|
d1681e |
Obsoletes: %{name}-core < %{version}-%{release}
|
|
|
d1681e |
Obsoletes: %{name}-ufo
|
|
|
d1681e |
-Obsoletes: %{name}-ganesha
|
|
|
74b1de |
%if ( 0%{!?_with_gnfs:1} )
|
|
|
74b1de |
Obsoletes: %{name}-gnfs
|
|
|
74b1de |
%endif
|
|
|
74b1de |
@@ -455,6 +454,30 @@ is in user space and easily manageable.
|
|
|
74b1de |
This package provides support to FUSE based clients and inlcudes the
|
|
|
74b1de |
glusterfs(d) binary.
|
|
|
d1681e |
|
|
|
74b1de |
+%if ( 0%{!?_without_server:1} )
|
|
|
74b1de |
+%package ganesha
|
|
|
74b1de |
+Summary: NFS-Ganesha configuration
|
|
|
74b1de |
+Group: Applications/File
|
|
|
74b1de |
+
|
|
|
74b1de |
+Requires: %{name}-server%{?_isa} = %{version}-%{release}
|
|
|
74b1de |
+Requires: nfs-ganesha-gluster, pcs, dbus
|
|
|
74b1de |
+%if ( 0%{?rhel} && 0%{?rhel} == 6 )
|
|
|
74b1de |
+Requires: cman, pacemaker, corosync
|
|
|
74b1de |
+%endif
|
|
|
74b1de |
+
|
|
|
74b1de |
+%description ganesha
|
|
|
74b1de |
+GlusterFS is a distributed file-system capable of scaling to several
|
|
|
74b1de |
+petabytes. It aggregates various storage bricks over Infiniband RDMA
|
|
|
74b1de |
+or TCP/IP interconnect into one large parallel network file
|
|
|
74b1de |
+system. GlusterFS is one of the most sophisticated file systems in
|
|
|
74b1de |
+terms of features and extensibility. It borrows a powerful concept
|
|
|
74b1de |
+called Translators from GNU Hurd kernel. Much of the code in GlusterFS
|
|
|
74b1de |
+is in user space and easily manageable.
|
|
|
74b1de |
+
|
|
|
74b1de |
+This package provides the configuration and related files for using
|
|
|
74b1de |
+NFS-Ganesha as the NFS server using GlusterFS
|
|
|
74b1de |
+%endif
|
|
|
74b1de |
+
|
|
|
74b1de |
%if ( 0%{!?_without_georeplication:1} )
|
|
|
74b1de |
%package geo-replication
|
|
|
74b1de |
Summary: GlusterFS Geo-replication
|
|
|
74b1de |
@@ -1111,6 +1134,12 @@ exit 0
|
|
|
74b1de |
%endif
|
|
|
74b1de |
%endif
|
|
|
d1681e |
|
|
|
74b1de |
+%if ( 0%{?_without_server:1} )
|
|
|
74b1de |
+#exclude ganesha related files
|
|
|
74b1de |
+%exclude %{_sysconfdir}/ganesha/*
|
|
|
74b1de |
+%exclude %{_libexecdir}/ganesha/*
|
|
|
74b1de |
+%endif
|
|
|
74b1de |
+
|
|
|
74b1de |
%files api
|
|
|
74b1de |
%exclude %{_libdir}/*.so
|
|
|
74b1de |
# libgfapi files
|
|
|
74b1de |
@@ -1273,6 +1302,12 @@ exit 0
|
|
|
74b1de |
%exclude %{_datadir}/glusterfs/tests/vagrant
|
|
|
74b1de |
%endif
|
|
|
74b1de |
|
|
|
74b1de |
+%if ( 0%{!?_without_server:1} )
|
|
|
74b1de |
+%files ganesha
|
|
|
d1681e |
+%{_sysconfdir}/ganesha/*
|
|
|
d1681e |
+%{_libexecdir}/ganesha/*
|
|
|
74b1de |
+%endif
|
|
|
74b1de |
+
|
|
|
74b1de |
%if ( 0%{!?_without_ocf:1} )
|
|
|
74b1de |
%files resource-agents
|
|
|
74b1de |
# /usr/lib is the standard for OCF, also on x86_64
|
|
|
74b1de |
@@ -1396,6 +1431,7 @@ exit 0
|
|
|
74b1de |
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/start/post
|
|
|
74b1de |
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/start/post/S29CTDBsetup.sh
|
|
|
74b1de |
%attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/start/post/S30samba-start.sh
|
|
|
74b1de |
+ %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/start/post/S31ganesha-start.sh
|
|
|
74b1de |
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/start/pre
|
|
|
74b1de |
%dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/stop
|
|
|
74b1de |
%ghost %dir %attr(0755,-,-) %{_sharedstatedir}/glusterd/hooks/1/stop/post
|
|
|
74b1de |
@@ -1868,6 +1904,9 @@ fi
|
|
|
d1681e |
%endif
|
|
|
d1681e |
|
|
|
d1681e |
%changelog
|
|
|
74b1de |
+* Fri Apr 5 2019 Jiffin Tony Thottan <jthottan@redhat.com>
|
|
|
74b1de |
+- Adding ganesha bits back in gluster repository
|
|
|
d1681e |
+
|
|
|
74b1de |
* Wed Mar 6 2019 Kaleb S. KEITHLEY <kkeithle@redhat.com>
|
|
|
74b1de |
- remove unneeded ldconfig in scriptlets
|
|
|
74b1de |
- reported by Igor Gnatenko in Fedora
|
|
|
74b1de |
@@ -1960,9 +1999,6 @@ fi
|
|
|
d1681e |
* Thu Feb 16 2017 Niels de Vos <ndevos@redhat.com>
|
|
|
d1681e |
- Obsolete and Provide python-gluster for upgrading from glusterfs < 3.10
|
|
|
d1681e |
|
|
|
d1681e |
-* Tue Feb 7 2017 Kaleb S. KEITHLEY <kkeithle@redhat.com>
|
|
|
d1681e |
-- remove ganesha (#1418417)
|
|
|
d1681e |
-
|
|
|
d1681e |
* Wed Feb 1 2017 Poornima G <pgurusid@redhat.com>
|
|
|
d1681e |
- Install /var/lib/glusterd/groups/metadata-cache by default
|
|
|
d1681e |
|
|
|
d1681e |
--
|
|
|
d1681e |
1.8.3.1
|
|
|
d1681e |
|