diff options
author | Amar Tumballi <amar@gluster.com> | 2010-09-24 10:18:31 +0000 |
---|---|---|
committer | Vijay Bellur <vijay@dev.gluster.com> | 2010-09-24 11:26:02 -0700 |
commit | dca5c02cf31e373e6e4ff376a5f35684cd43e081 (patch) | |
tree | d13e4676b8b40d274d8f72620f81993b3551bdc9 | |
parent | f91dad3f618b2d981e69ecd5000974db712f9188 (diff) |
glusterd-volgen: add 'io-stats' xlator on server volfile too
Signed-off-by: Amar Tumballi <amar@gluster.com>
Signed-off-by: Vijay Bellur <vijay@dev.gluster.com>
BUG: 1701 (better statistics gathering in glusterd)
URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=1701
-rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-volgen.c | 32 |
1 files changed, 23 insertions, 9 deletions
diff --git a/xlators/mgmt/glusterd/src/glusterd-volgen.c b/xlators/mgmt/glusterd/src/glusterd-volgen.c index bf0e8c5f9..9609342b6 100644 --- a/xlators/mgmt/glusterd/src/glusterd-volgen.c +++ b/xlators/mgmt/glusterd/src/glusterd-volgen.c @@ -625,7 +625,7 @@ __write_iothreads_xlator (FILE *file, dict_t *dict, char *opt_maxthreads = NULL; int ret = -1; - const char *iot_str = "volume %s\n" + const char *iot_str = "volume %s-iot\n" " type performance/io-threads\n" " option thread-count %s\n" "# option autoscaling %s\n" @@ -634,7 +634,7 @@ __write_iothreads_xlator (FILE *file, dict_t *dict, " subvolumes %s\n" "end-volume\n\n"; - ret = dict_get_str (dict, "export-path", &volname); + ret = dict_get_str (dict, "volname", &volname); if (ret) { goto out; } @@ -642,11 +642,10 @@ __write_iothreads_xlator (FILE *file, dict_t *dict, if (dict_get (dict, "thread-count")) { gf_log("", GF_LOG_DEBUG, "Resetting the thread-count value"); ret = dict_get_str (dict, "thread-count", &opt_threadcount); - } - else + } else ret = dict_get_str (dict, VOLGEN_IOT_OPTION_THREADCOUNT, &opt_threadcount); - + if (ret) { goto out; } @@ -1605,10 +1604,12 @@ __write_iostats_xlator (FILE *file, dict_t *dict, const char *iostats_str = "volume %s\n" " type debug/io-stats\n" + " # option dump-fd-stats enable\n" + " # option latency-measurement enable\n" " subvolumes %s\n" "end-volume\n\n"; - ret = dict_get_str (dict, "volname", &volname); + ret = dict_get_str (dict, "iostat-volname", &volname); if (ret) { goto out; } @@ -1709,16 +1710,24 @@ generate_server_volfile (glusterd_brickinfo_t *brickinfo, } else VOLGEN_GENERATE_VOLNAME (subvol, volname, "locks"); + ret = __write_iothreads_xlator (file, dict, subvol); + if (ret) { + gf_log ("", GF_LOG_DEBUG, + "Could not write xlator"); + goto out; + } - ret = dict_set_str (dict, "export-path", brickinfo->path); + ret = dict_set_str (dict, "iostat-volname", brickinfo->path); if (ret) { goto out; } - ret = __write_iothreads_xlator (file, dict, subvol); + VOLGEN_GENERATE_VOLNAME (subvol, volname, "iot"); + + ret = __write_iostats_xlator (file, dict, subvol); if (ret) { gf_log ("", GF_LOG_DEBUG, - "Could not write xlator"); + "Could not write io-stats xlator"); goto out; } @@ -2133,6 +2142,11 @@ generate_client_volfile (glusterd_volinfo_t *volinfo, char *filename) goto out; } + ret = dict_set_str (dict, "iostat-volname", volname); + if (ret) { + goto out; + } + ret = __write_iostats_xlator (file, dict, last_xlator); |