Make proc failure loud but nonfatal
This commit is contained in:
parent
c1f4665d37
commit
35e3b9ed5e
75
Make-proc-file-failure-loud-but-nonfatal.patch
Normal file
75
Make-proc-file-failure-loud-but-nonfatal.patch
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
From bc4c8a61c0615ca76b930a22e3602d0e1ec900f1 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Robbie Harwood <rharwood@redhat.com>
|
||||||
|
Date: Thu, 25 May 2017 13:06:17 -0400
|
||||||
|
Subject: [PATCH] Make proc file failure loud but nonfatal
|
||||||
|
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
|
Reviewed-by: Simo Sorce <simo@redhat.com>
|
||||||
|
Resolves: #190
|
||||||
|
(cherry picked from commit 4f60bf02a1a68cbb26251e764357b753f80790f3)
|
||||||
|
---
|
||||||
|
proxy/src/gp_init.c | 34 +++++++++++++++-------------------
|
||||||
|
1 file changed, 15 insertions(+), 19 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/proxy/src/gp_init.c b/proxy/src/gp_init.c
|
||||||
|
index 4673f02..e69934d 100644
|
||||||
|
--- a/proxy/src/gp_init.c
|
||||||
|
+++ b/proxy/src/gp_init.c
|
||||||
|
@@ -144,11 +144,11 @@ void init_proc_nfsd(struct gp_config *cfg)
|
||||||
|
{
|
||||||
|
char buf[] = "1";
|
||||||
|
bool enabled = false;
|
||||||
|
- int fd, i, ret;
|
||||||
|
+ int fd, ret;
|
||||||
|
|
||||||
|
/* check first if any service enabled kernel support */
|
||||||
|
- for (i = 0; i < cfg->num_svcs; i++) {
|
||||||
|
- if (cfg->svcs[i]->kernel_nfsd == true) {
|
||||||
|
+ for (int i = 0; i < cfg->num_svcs; i++) {
|
||||||
|
+ if (cfg->svcs[i]->kernel_nfsd) {
|
||||||
|
enabled = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
@@ -161,30 +161,26 @@ void init_proc_nfsd(struct gp_config *cfg)
|
||||||
|
fd = open(LINUX_PROC_USE_GSS_PROXY_FILE, O_RDWR);
|
||||||
|
if (fd == -1) {
|
||||||
|
ret = errno;
|
||||||
|
- fprintf(stderr, "GSS-Proxy is not supported by this kernel since "
|
||||||
|
- "file %s could not be found: %d (%s)\n",
|
||||||
|
- LINUX_PROC_USE_GSS_PROXY_FILE,
|
||||||
|
- ret, gp_strerror(ret));
|
||||||
|
- exit(1);
|
||||||
|
+ GPDEBUG("Kernel doesn't support GSS-Proxy (can't open %s: %d (%s))\n",
|
||||||
|
+ LINUX_PROC_USE_GSS_PROXY_FILE, ret, gp_strerror(ret));
|
||||||
|
+ goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = write(fd, buf, 1);
|
||||||
|
if (ret != 1) {
|
||||||
|
ret = errno;
|
||||||
|
- fprintf(stderr, "Failed to write to %s: %d (%s)\n",
|
||||||
|
- LINUX_PROC_USE_GSS_PROXY_FILE,
|
||||||
|
- ret, gp_strerror(ret));
|
||||||
|
- exit(1);
|
||||||
|
+ GPDEBUG("Failed to write to %s: %d (%s)\n",
|
||||||
|
+ LINUX_PROC_USE_GSS_PROXY_FILE, ret, gp_strerror(ret));
|
||||||
|
}
|
||||||
|
|
||||||
|
- ret = close(fd);
|
||||||
|
- if (ret == -1) {
|
||||||
|
- ret = errno;
|
||||||
|
- fprintf(stderr, "Failed to close %s: %d (%s)\n",
|
||||||
|
- LINUX_PROC_USE_GSS_PROXY_FILE,
|
||||||
|
- ret, gp_strerror(ret));
|
||||||
|
- exit(1);
|
||||||
|
+ close(fd);
|
||||||
|
+ if (ret != 0) {
|
||||||
|
+ goto fail;
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ return;
|
||||||
|
+fail:
|
||||||
|
+ GPDEBUG("Problem with kernel communication! NFS server will not work\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
void write_pid(void)
|
@ -1,6 +1,6 @@
|
|||||||
Name: gssproxy
|
Name: gssproxy
|
||||||
Version: 0.7.0
|
Version: 0.7.0
|
||||||
Release: 8%{?dist}
|
Release: 9%{?dist}
|
||||||
Summary: GSSAPI Proxy
|
Summary: GSSAPI Proxy
|
||||||
|
|
||||||
Group: System Environment/Libraries
|
Group: System Environment/Libraries
|
||||||
@ -22,6 +22,7 @@ Patch4: Update-systemd-file.patch
|
|||||||
Patch5: Fix-unused-variables.patch
|
Patch5: Fix-unused-variables.patch
|
||||||
Patch6: Fix-segfault-when-no-config-files-are-present.patch
|
Patch6: Fix-segfault-when-no-config-files-are-present.patch
|
||||||
Patch7: Include-header-for-writev.patch
|
Patch7: Include-header-for-writev.patch
|
||||||
|
Patch8: Make-proc-file-failure-loud-but-nonfatal.patch
|
||||||
|
|
||||||
### Dependencies ###
|
### Dependencies ###
|
||||||
Requires: krb5-libs >= 1.12.0
|
Requires: krb5-libs >= 1.12.0
|
||||||
@ -65,6 +66,7 @@ A proxy for GSSAPI credential handling
|
|||||||
%patch5 -p2 -b .Fix-unused-variables
|
%patch5 -p2 -b .Fix-unused-variables
|
||||||
%patch6 -p2 -b .Fix-segfault-when-no-config-files-are-present
|
%patch6 -p2 -b .Fix-segfault-when-no-config-files-are-present
|
||||||
%patch7 -p2 -b .Include-header-for-writev
|
%patch7 -p2 -b .Include-header-for-writev
|
||||||
|
%patch8 -p2 -b .Make-proc-file-failure-loud-but-nonfatal
|
||||||
|
|
||||||
%build
|
%build
|
||||||
autoreconf -f -i
|
autoreconf -f -i
|
||||||
@ -120,6 +122,9 @@ rm -rf %{buildroot}
|
|||||||
%systemd_postun_with_restart gssproxy.service
|
%systemd_postun_with_restart gssproxy.service
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu May 25 2017 Robbie Harwood <rharwood@redhat.com> - 0.7.0-9
|
||||||
|
- Make proc failure loud but nonfatal
|
||||||
|
|
||||||
* Wed May 24 2017 Robbie Harwood <rharwood@redhat.com> - 0.7.0-8
|
* Wed May 24 2017 Robbie Harwood <rharwood@redhat.com> - 0.7.0-8
|
||||||
- Remove (buggy?) logic around NFS snippet.
|
- Remove (buggy?) logic around NFS snippet.
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user