diff options
author | Csaba Henk <csaba@redhat.com> | 2012-05-26 19:04:25 +0530 |
---|---|---|
committer | Vijay Bellur <vijay@gluster.com> | 2012-05-27 10:54:34 -0700 |
commit | f2e05c9f7b5e484fb0deadfc37f0a33f536c4440 (patch) | |
tree | 6a8327da78157b34e293e65076282dd1ef555a2a /xlators/mgmt/glusterd/src/glusterd-geo-rep.c | |
parent | 4227ec88ab7ee386ae22ab9b6fc27152944fc9df (diff) |
glusterd/geo-rep: cleanup and fixes
- fix the hilarious fd leak of "geo-rep status"
- instead of "corrupt", which can trip up users to think their
data is in danger, use the term "defunct" to describe the
condition when gsyncd is dead/unresponsive
- don't use buffered I/O when unnecessary
- stop using PATH_MAX for sizing buffers that don't hold paths
- some cleanups wrt. memory management
Change-Id: I396aacc45dc06a002318b19c60c44041fa9fa18d
BUG: 764268
Signed-off-by: Csaba Henk <csaba@redhat.com>
Reviewed-on: http://review.gluster.com/3454
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Vijay Bellur <vijay@gluster.com>
Diffstat (limited to 'xlators/mgmt/glusterd/src/glusterd-geo-rep.c')
-rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-geo-rep.c | 89 |
1 files changed, 54 insertions, 35 deletions
diff --git a/xlators/mgmt/glusterd/src/glusterd-geo-rep.c b/xlators/mgmt/glusterd/src/glusterd-geo-rep.c index 7bd2df8fca2..847fed49eb8 100644 --- a/xlators/mgmt/glusterd/src/glusterd-geo-rep.c +++ b/xlators/mgmt/glusterd/src/glusterd-geo-rep.c @@ -1149,8 +1149,8 @@ stop_gsync (char *master, char *slave, char **msg) gf_log ("", GF_LOG_ERROR, "gsyncd b/w %s & %s is not" " running", master, slave); if (msg) - *msg = gf_strdup ("Warning: "GEOREP" session was in " - "corrupt state"); + *msg = gf_strdup ("Warning: "GEOREP" session was " + "defunct at stop time"); /* monitor gsyncd already dead */ goto out; } @@ -1277,41 +1277,45 @@ out: } int -glusterd_gsync_read_frm_status (char *path, char *data) +glusterd_gsync_read_frm_status (char *path, char *buf, size_t blen) { int ret = 0; - FILE *status_file = NULL; + int status_fd = -1; + char *p = NULL; GF_ASSERT (path); - GF_ASSERT (data); - status_file = fopen (path, "r"); - if (status_file == NULL) { - gf_log ("", GF_LOG_WARNING, "Unable to read gsyncd status" + GF_ASSERT (buf); + status_fd = open (path, O_RDONLY); + if (status_fd == -1) { + gf_log ("", GF_LOG_ERROR, "Unable to read gsyncd status" " file"); return -1; } - ret = fread (data, PATH_MAX, 1, status_file); - if (ret < 0) { - gf_log ("", GF_LOG_WARNING, "Status file of gsyncd is corrupt"); - return -1; - } - - data[strlen(data)-1] = '\0'; + ret = read (status_fd, buf, blen - 1); + if (ret > 0) { + p = buf + strlen (buf) - 1; + while (isspace (*p)) + *p-- = '\0'; + ret = 0; + } else if (ret < 0) + gf_log ("", GF_LOG_ERROR, "Status file of gsyncd is corrupt"); - return 0; + close (status_fd); + return ret; } int glusterd_read_status_file (char *master, char *slave, dict_t *dict) { - glusterd_conf_t *priv = NULL; + glusterd_conf_t *priv = NULL; int ret = 0; - char statusfile[PATH_MAX] = {0, }; - char buff[PATH_MAX] = {0, }; - char mst[PATH_MAX] = {0, }; - char slv[PATH_MAX] = {0, }; - char sts[PATH_MAX] = {0, }; + char statefile[PATH_MAX] = {0, }; + char buf[1024] = {0, }; + char mst[1024] = {0, }; + char slv[1024] = {0, }; + char sts[1024] = {0, }; + char *bufp = NULL; int gsync_count = 0; int status = 0; @@ -1319,10 +1323,10 @@ glusterd_read_status_file (char *master, char *slave, GF_ASSERT (THIS->private); priv = THIS->private; - ret = glusterd_gsync_get_param_file (statusfile, "state", master, + ret = glusterd_gsync_get_param_file (statefile, "state", master, slave, priv->workdir); if (ret) { - gf_log ("", GF_LOG_WARNING, "Unable to get the name of status" + gf_log ("", GF_LOG_ERROR, "Unable to get the name of status" "file for %s(master), %s(slave)", master, slave); goto out; @@ -1330,17 +1334,17 @@ glusterd_read_status_file (char *master, char *slave, ret = gsync_status (master, slave, &status); if (ret == 0 && status == -1) { - strncpy (buff, "corrupt", sizeof (buff)); + strncpy (buf, "defunct", sizeof (buf)); goto done; } else if (ret == -1) goto out; - ret = glusterd_gsync_read_frm_status (statusfile, buff); + ret = glusterd_gsync_read_frm_status (statefile, buf, sizeof (buf)); if (ret) { - gf_log ("", GF_LOG_WARNING, "Unable to read the status" + gf_log ("", GF_LOG_ERROR, "Unable to read the status" "file for %s(master), %s(slave)", master, slave); - goto out; - + strncpy (buf, "defunct", sizeof (buf)); + goto done; } done: @@ -1352,19 +1356,34 @@ glusterd_read_status_file (char *master, char *slave, gsync_count++; snprintf (mst, sizeof (mst), "master%d", gsync_count); - ret = dict_set_dynstr (dict, mst, gf_strdup (master)); - if (ret) + master = gf_strdup (master); + if (!master) + goto out; + ret = dict_set_dynstr (dict, mst, master); + if (ret) { + GF_FREE (master); goto out; + } snprintf (slv, sizeof (slv), "slave%d", gsync_count); - ret = dict_set_dynstr (dict, slv, gf_strdup (slave)); - if (ret) + slave = gf_strdup (slave); + if (!slave) + goto out; + ret = dict_set_dynstr (dict, slv, slave); + if (ret) { + GF_FREE (slave); goto out; + } snprintf (sts, sizeof (slv), "status%d", gsync_count); - ret = dict_set_dynstr (dict, sts, gf_strdup (buff)); - if (ret) + bufp = gf_strdup (buf); + if (!bufp) goto out; + ret = dict_set_dynstr (dict, sts, bufp); + if (ret) { + GF_FREE (bufp); + goto out; + } ret = dict_set_int32 (dict, "gsync-count", gsync_count); if (ret) goto out; |