From 86c7aebfe47426ac96dc97712d64cbc6a85ba863 Mon Sep 17 00:00:00 2001 From: yangsheng <yangsheng> Date: Wed, 17 Sep 2008 14:30:22 +0000 Subject: [PATCH] Branch HEAD b=16953 i=johann, robert.read Add mount retry support for liblustre. --- lustre/liblustre/llite_lib.c | 22 ++++++++++++++++++++-- lustre/tests/acceptance-small.sh | 1 + 2 files changed, 21 insertions(+), 2 deletions(-) diff --git a/lustre/liblustre/llite_lib.c b/lustre/liblustre/llite_lib.c index e70ff8f877..31ee23bb9a 100644 --- a/lustre/liblustre/llite_lib.c +++ b/lustre/liblustre/llite_lib.c @@ -326,6 +326,8 @@ int _sysio_lustre_init(void) extern int _sysio_native_init(); +static int mnt_retry = 0; + char *lustre_path = NULL; void __liblustre_setup_(void) @@ -333,13 +335,20 @@ void __liblustre_setup_(void) char *target = NULL; char *lustre_driver = "lustre"; unsigned mntflgs = 0; - int err; + int err, count; lustre_path = getenv("LIBLUSTRE_MOUNT_POINT"); if (!lustre_path) { lustre_path = "/mnt/lustre"; } + target = getenv("LIBLUSTRE_MOUNT_RETRY"); + if (target) { + mnt_retry = atoi(target); + if (mnt_retry < 0) + mnt_retry = 0; + } + /* mount target */ target = getenv("LIBLUSTRE_MOUNT_TARGET"); if (!target) { @@ -368,7 +377,16 @@ void __liblustre_setup_(void) exit(1); #endif /* INIT_SYSIO */ - err = mount(target, lustre_path, lustre_driver, mntflgs, NULL); + count = mnt_retry; + do { + err = mount(target, lustre_path, lustre_driver, mntflgs, NULL); + if (err && mnt_retry && (-- count)) { + fprintf(stderr, "Lustre mount failed: %s. " + "Will retry %d more times\n", + strerror(errno), mnt_retry - count ); + sleep(2); + } + } while (err && count > 0); if (err) { fprintf(stderr, "Lustre mount failed: %s\n", strerror(errno)); exit(1); diff --git a/lustre/tests/acceptance-small.sh b/lustre/tests/acceptance-small.sh index 72ca68d030..a6391eaf7b 100755 --- a/lustre/tests/acceptance-small.sh +++ b/lustre/tests/acceptance-small.sh @@ -306,6 +306,7 @@ for NAME in $CONFIGS; do MDS_MOUNT_OPTS=${MDS_MOUNT_OPTS/#,/-o } \ $SETUP export LIBLUSTRE_MOUNT_POINT=$MOUNT2 + export LIBLUSTRE_MOUNT_RETRY=5 export LIBLUSTRE_MOUNT_TARGET=$MGSNID:/$FSNAME export LIBLUSTRE_TIMEOUT=`lctl get_param -n timeout` #export LIBLUSTRE_DEBUG_MASK=`lctl get_param -n debug` -- GitLab