Commit 489d82fc authored by Bobi Jam's avatar Bobi Jam Committed by Greg Kroah-Hartman

staging: lustre: obd: MDT mount fails on MDS w/o MGS on it

If we specify multiple --mgsnode for a MDT, when we start MDS upon
it while MGS is no the other node, the MGC import connection will
always select the local nid (which is one of the candidate mgsnode)
since it think its the closest connection.

This patch treats further --mgsnode nids as failover nids, so that
multiple import connections are added for the MGC import.
Signed-off-by: default avatarBobi Jam <bobijam.xu@intel.com>
Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-3829
Reviewed-on: http://review.whamcloud.com/7509Reviewed-by: default avatarLiang Zhen <liang.zhen@intel.com>
Reviewed-by: default avatarLai Siyao <lai.siyao@intel.com>
Reviewed-by: default avatarOleg Drokin <oleg.drokin@intel.com>
Signed-off-by: default avatarJames Simmons <jsimmons@infradead.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 32cc01c4
...@@ -307,6 +307,7 @@ int lustre_start_mgc(struct super_block *sb) ...@@ -307,6 +307,7 @@ int lustre_start_mgc(struct super_block *sb)
while (class_parse_nid(ptr, &nid, &ptr) == 0) { while (class_parse_nid(ptr, &nid, &ptr) == 0) {
rc = do_lcfg(mgcname, nid, rc = do_lcfg(mgcname, nid,
LCFG_ADD_UUID, niduuid, NULL, NULL, NULL); LCFG_ADD_UUID, niduuid, NULL, NULL, NULL);
if (!rc)
i++; i++;
/* Stop at the first failover nid */ /* Stop at the first failover nid */
if (*ptr == ':') if (*ptr == ':')
...@@ -345,15 +346,17 @@ int lustre_start_mgc(struct super_block *sb) ...@@ -345,15 +346,17 @@ int lustre_start_mgc(struct super_block *sb)
sprintf(niduuid, "%s_%x", mgcname, i); sprintf(niduuid, "%s_%x", mgcname, i);
j = 0; j = 0;
while (class_parse_nid_quiet(ptr, &nid, &ptr) == 0) { while (class_parse_nid_quiet(ptr, &nid, &ptr) == 0) {
j++; rc = do_lcfg(mgcname, nid, LCFG_ADD_UUID, niduuid,
rc = do_lcfg(mgcname, nid, NULL, NULL, NULL);
LCFG_ADD_UUID, niduuid, NULL, NULL, NULL); if (!rc)
++j;
if (*ptr == ':') if (*ptr == ':')
break; break;
} }
if (j > 0) { if (j > 0) {
rc = do_lcfg(mgcname, 0, LCFG_ADD_CONN, rc = do_lcfg(mgcname, 0, LCFG_ADD_CONN,
niduuid, NULL, NULL, NULL); niduuid, NULL, NULL, NULL);
if (!rc)
i++; i++;
} else { } else {
/* at ":/fsname" */ /* at ":/fsname" */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment