diff options
| author | Krishnan Parthasarathi <kparthas@redhat.com> | 2013-12-17 11:43:22 +0530 | 
|---|---|---|
| committer | Vijay Bellur <vbellur@redhat.com> | 2013-12-19 03:45:53 -0800 | 
| commit | 709d9247bb467b801814637bd181bc7cddd36cb5 (patch) | |
| tree | eb61c7aebc61a757516c78f14fb1b145df93bdb6 /xlators/mgmt | |
| parent | 30bdde315e01d4d71cca121f0cba55b7ae82dd1b (diff) | |
glusterd: ignore failure to stop a stopped service.
kill(2) returns -1 with errno set to ESRCH when the pid of the process
being killed doesn't exist. Failing glusterd_brick_stop on a stopped
brick could result in volume-stop failing, in commit phase.
This fix prevents that from happening.
Change-Id: I00f46fa06e489a671efbb8e4119f545f8ccea329
BUG: 1038051
Signed-off-by: Krishnan Parthasarathi <kparthas@redhat.com>
Reviewed-on: http://review.gluster.org/6525
Reviewed-by: Vijaikumar Mallikarjuna <vmallika@redhat.com>
Reviewed-by: Kaushal M <kaushal@redhat.com>
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Vijay Bellur <vbellur@redhat.com>
Diffstat (limited to 'xlators/mgmt')
| -rw-r--r-- | xlators/mgmt/glusterd/src/glusterd-utils.c | 12 | 
1 files changed, 12 insertions, 0 deletions
| diff --git a/xlators/mgmt/glusterd/src/glusterd-utils.c b/xlators/mgmt/glusterd/src/glusterd-utils.c index b05c39c3e..6614f98db 100644 --- a/xlators/mgmt/glusterd/src/glusterd-utils.c +++ b/xlators/mgmt/glusterd/src/glusterd-utils.c @@ -1142,6 +1142,18 @@ glusterd_service_stop (const char *service, char *pidfile, int sig,                  "%d", service, pid);          ret = kill (pid, sig); +        if (ret) { +                switch (errno) { +                case ESRCH: +                        gf_log (this->name, GF_LOG_DEBUG, "%s is already stopped", +                                service); +                        ret = 0; +                        break; +                default: +                        gf_log (this->name, GF_LOG_ERROR, "Failed to kill %s: %s", +                                service, strerror (errno)); +                } +        }          if (!force_kill)                  goto out; | 
