Make no local logging a runtime option for network logging...
This commit is contained in:
parent
76fef0a5d0
commit
bf2b8ae49a
@ -1176,6 +1176,7 @@ const char syslogd_usage[] =
|
|||||||
"\t-O FILE\t\tUse an alternate log file (default=/var/log/messages)\n"
|
"\t-O FILE\t\tUse an alternate log file (default=/var/log/messages)\n"
|
||||||
#ifdef BB_FEATURE_REMOTE_LOG
|
#ifdef BB_FEATURE_REMOTE_LOG
|
||||||
"\t-R HOST[:PORT]\t\tLog remotely to IP or hostname on PORT (default PORT=514/UDP)\n"
|
"\t-R HOST[:PORT]\t\tLog remotely to IP or hostname on PORT (default PORT=514/UDP)\n"
|
||||||
|
"\t-N\t\tDo not log anything locally -- network logging only.\n"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
;
|
;
|
||||||
|
@ -1702,11 +1702,12 @@ Note that this version of syslogd/klogd ignores /etc/syslog.conf.
|
|||||||
|
|
||||||
Options:
|
Options:
|
||||||
|
|
||||||
-m NUM Interval between MARK lines (default=20min, 0=off)
|
-m NUM Interval between MARK lines (default=20min, 0=off)
|
||||||
-n Run as a foreground process
|
-n Run as a foreground process
|
||||||
-K Do not start up the klogd process
|
-K Do not start up the klogd process
|
||||||
-O FILE Use an alternate log file (default=/var/log/messages)
|
-O FILE Use an alternate log file (default=/var/log/messages)
|
||||||
-R HOST[:PORT] Log messages to HOST on PORT (default=514) over UDP.
|
-R HOST[:PORT] Log messages to HOST on PORT (default=514) over UDP.
|
||||||
|
-N Do not log anything locally -- network logging only
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
@ -2261,4 +2262,4 @@ Enrique Zanardi <ezanardi@ull.es>
|
|||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
# $Id: busybox.pod,v 1.77 2000/11/17 17:23:16 andersen Exp $
|
# $Id: busybox.pod,v 1.78 2000/12/08 19:52:01 andersen Exp $
|
||||||
|
@ -2991,6 +2991,7 @@
|
|||||||
-K Do not start up the klogd process
|
-K Do not start up the klogd process
|
||||||
-O FILE Use an alternate log file (default=/var/log/messages)
|
-O FILE Use an alternate log file (default=/var/log/messages)
|
||||||
-R HOST[:PORT] Log messages to HOST on PORT (default=514) over UDP.
|
-R HOST[:PORT] Log messages to HOST on PORT (default=514) over UDP.
|
||||||
|
-N Do not log anything locally -- network logging only
|
||||||
</screen>
|
</screen>
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
@ -79,13 +79,14 @@ static char LocalHostName[32];
|
|||||||
#ifdef BB_FEATURE_REMOTE_LOG
|
#ifdef BB_FEATURE_REMOTE_LOG
|
||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
/* udp socket for logging to remote host */
|
/* udp socket for logging to remote host */
|
||||||
static int remotefd = -1;
|
static int remotefd = -1;
|
||||||
/* where do we log? */
|
/* where do we log? */
|
||||||
static char *RemoteHost;
|
static char *RemoteHost;
|
||||||
/* what port to log to? */
|
/* what port to log to? */
|
||||||
static int RemotePort = 514;
|
static int RemotePort = 514;
|
||||||
/* To remote log or not to remote log, that is the question. */
|
/* To remote log or not to remote log, that is the question. */
|
||||||
static int doRemoteLog = FALSE;
|
static int doRemoteLog = FALSE;
|
||||||
|
static int local_logging = TRUE;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Note: There is also a function called "message()" in init.c */
|
/* Note: There is also a function called "message()" in init.c */
|
||||||
@ -139,9 +140,9 @@ static void logMessage (int pri, char *msg)
|
|||||||
|
|
||||||
if (pri != 0) {
|
if (pri != 0) {
|
||||||
for (c_fac = facilitynames;
|
for (c_fac = facilitynames;
|
||||||
c_fac->c_name && !(c_fac->c_val == LOG_FAC(pri) << 3); c_fac++);
|
c_fac->c_name && !(c_fac->c_val == LOG_FAC(pri) << 3); c_fac++);
|
||||||
for (c_pri = prioritynames;
|
for (c_pri = prioritynames;
|
||||||
c_pri->c_name && !(c_pri->c_val == LOG_PRI(pri)); c_pri++);
|
c_pri->c_name && !(c_pri->c_val == LOG_PRI(pri)); c_pri++);
|
||||||
if (*c_fac->c_name == '\0' || *c_pri->c_name == '\0')
|
if (*c_fac->c_name == '\0' || *c_pri->c_name == '\0')
|
||||||
snprintf(res, sizeof(res), "<%d>", pri);
|
snprintf(res, sizeof(res), "<%d>", pri);
|
||||||
else
|
else
|
||||||
@ -149,7 +150,7 @@ static void logMessage (int pri, char *msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (strlen(msg) < 16 || msg[3] != ' ' || msg[6] != ' ' ||
|
if (strlen(msg) < 16 || msg[3] != ' ' || msg[6] != ' ' ||
|
||||||
msg[9] != ':' || msg[12] != ':' || msg[15] != ' ') {
|
msg[9] != ':' || msg[12] != ':' || msg[15] != ' ') {
|
||||||
time(&now);
|
time(&now);
|
||||||
timestamp = ctime(&now) + 4;
|
timestamp = ctime(&now) + 4;
|
||||||
timestamp[15] = '\0';
|
timestamp[15] = '\0';
|
||||||
@ -163,28 +164,29 @@ static void logMessage (int pri, char *msg)
|
|||||||
|
|
||||||
#ifdef BB_FEATURE_REMOTE_LOG
|
#ifdef BB_FEATURE_REMOTE_LOG
|
||||||
/* send message to remote logger */
|
/* send message to remote logger */
|
||||||
if ( -1 != remotefd){
|
if ( -1 != remotefd){
|
||||||
#define IOV_COUNT 2
|
#define IOV_COUNT 2
|
||||||
struct iovec iov[IOV_COUNT];
|
struct iovec iov[IOV_COUNT];
|
||||||
struct iovec *v = iov;
|
struct iovec *v = iov;
|
||||||
|
|
||||||
bzero(&res, sizeof(res));
|
bzero(&res, sizeof(res));
|
||||||
snprintf(res, sizeof(res), "<%d>", pri);
|
snprintf(res, sizeof(res), "<%d>", pri);
|
||||||
v->iov_base = res ;
|
v->iov_base = res ;
|
||||||
v->iov_len = strlen(res);
|
v->iov_len = strlen(res);
|
||||||
v++;
|
v++;
|
||||||
|
|
||||||
v->iov_base = msg;
|
v->iov_base = msg;
|
||||||
v->iov_len = strlen(msg);
|
v->iov_len = strlen(msg);
|
||||||
|
|
||||||
if ( -1 == writev(remotefd,iov, IOV_COUNT)){
|
if ( -1 == writev(remotefd,iov, IOV_COUNT)){
|
||||||
error_msg_and_die("syslogd: cannot write to remote file handle on"
|
error_msg_and_die("syslogd: cannot write to remote file handle on"
|
||||||
"%s:%d\n",RemoteHost,RemotePort);
|
"%s:%d\n",RemoteHost,RemotePort);
|
||||||
}
|
}
|
||||||
} else
|
}
|
||||||
|
if (local_logging == TRUE)
|
||||||
#endif
|
#endif
|
||||||
/* now spew out the message to wherever it is supposed to go */
|
/* now spew out the message to wherever it is supposed to go */
|
||||||
message("%s %s %s %s\n", timestamp, LocalHostName, res, msg);
|
message("%s %s %s %s\n", timestamp, LocalHostName, res, msg);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -529,6 +531,9 @@ extern int syslogd_main(int argc, char **argv)
|
|||||||
doRemoteLog = TRUE;
|
doRemoteLog = TRUE;
|
||||||
stopDoingThat = TRUE;
|
stopDoingThat = TRUE;
|
||||||
break;
|
break;
|
||||||
|
case 'N':
|
||||||
|
local_logging = FALSE;
|
||||||
|
break;
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
usage(syslogd_usage);
|
usage(syslogd_usage);
|
||||||
|
51
syslogd.c
51
syslogd.c
@ -79,13 +79,14 @@ static char LocalHostName[32];
|
|||||||
#ifdef BB_FEATURE_REMOTE_LOG
|
#ifdef BB_FEATURE_REMOTE_LOG
|
||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
/* udp socket for logging to remote host */
|
/* udp socket for logging to remote host */
|
||||||
static int remotefd = -1;
|
static int remotefd = -1;
|
||||||
/* where do we log? */
|
/* where do we log? */
|
||||||
static char *RemoteHost;
|
static char *RemoteHost;
|
||||||
/* what port to log to? */
|
/* what port to log to? */
|
||||||
static int RemotePort = 514;
|
static int RemotePort = 514;
|
||||||
/* To remote log or not to remote log, that is the question. */
|
/* To remote log or not to remote log, that is the question. */
|
||||||
static int doRemoteLog = FALSE;
|
static int doRemoteLog = FALSE;
|
||||||
|
static int local_logging = TRUE;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Note: There is also a function called "message()" in init.c */
|
/* Note: There is also a function called "message()" in init.c */
|
||||||
@ -139,9 +140,9 @@ static void logMessage (int pri, char *msg)
|
|||||||
|
|
||||||
if (pri != 0) {
|
if (pri != 0) {
|
||||||
for (c_fac = facilitynames;
|
for (c_fac = facilitynames;
|
||||||
c_fac->c_name && !(c_fac->c_val == LOG_FAC(pri) << 3); c_fac++);
|
c_fac->c_name && !(c_fac->c_val == LOG_FAC(pri) << 3); c_fac++);
|
||||||
for (c_pri = prioritynames;
|
for (c_pri = prioritynames;
|
||||||
c_pri->c_name && !(c_pri->c_val == LOG_PRI(pri)); c_pri++);
|
c_pri->c_name && !(c_pri->c_val == LOG_PRI(pri)); c_pri++);
|
||||||
if (*c_fac->c_name == '\0' || *c_pri->c_name == '\0')
|
if (*c_fac->c_name == '\0' || *c_pri->c_name == '\0')
|
||||||
snprintf(res, sizeof(res), "<%d>", pri);
|
snprintf(res, sizeof(res), "<%d>", pri);
|
||||||
else
|
else
|
||||||
@ -149,7 +150,7 @@ static void logMessage (int pri, char *msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (strlen(msg) < 16 || msg[3] != ' ' || msg[6] != ' ' ||
|
if (strlen(msg) < 16 || msg[3] != ' ' || msg[6] != ' ' ||
|
||||||
msg[9] != ':' || msg[12] != ':' || msg[15] != ' ') {
|
msg[9] != ':' || msg[12] != ':' || msg[15] != ' ') {
|
||||||
time(&now);
|
time(&now);
|
||||||
timestamp = ctime(&now) + 4;
|
timestamp = ctime(&now) + 4;
|
||||||
timestamp[15] = '\0';
|
timestamp[15] = '\0';
|
||||||
@ -163,28 +164,29 @@ static void logMessage (int pri, char *msg)
|
|||||||
|
|
||||||
#ifdef BB_FEATURE_REMOTE_LOG
|
#ifdef BB_FEATURE_REMOTE_LOG
|
||||||
/* send message to remote logger */
|
/* send message to remote logger */
|
||||||
if ( -1 != remotefd){
|
if ( -1 != remotefd){
|
||||||
#define IOV_COUNT 2
|
#define IOV_COUNT 2
|
||||||
struct iovec iov[IOV_COUNT];
|
struct iovec iov[IOV_COUNT];
|
||||||
struct iovec *v = iov;
|
struct iovec *v = iov;
|
||||||
|
|
||||||
bzero(&res, sizeof(res));
|
bzero(&res, sizeof(res));
|
||||||
snprintf(res, sizeof(res), "<%d>", pri);
|
snprintf(res, sizeof(res), "<%d>", pri);
|
||||||
v->iov_base = res ;
|
v->iov_base = res ;
|
||||||
v->iov_len = strlen(res);
|
v->iov_len = strlen(res);
|
||||||
v++;
|
v++;
|
||||||
|
|
||||||
v->iov_base = msg;
|
v->iov_base = msg;
|
||||||
v->iov_len = strlen(msg);
|
v->iov_len = strlen(msg);
|
||||||
|
|
||||||
if ( -1 == writev(remotefd,iov, IOV_COUNT)){
|
if ( -1 == writev(remotefd,iov, IOV_COUNT)){
|
||||||
error_msg_and_die("syslogd: cannot write to remote file handle on"
|
error_msg_and_die("syslogd: cannot write to remote file handle on"
|
||||||
"%s:%d\n",RemoteHost,RemotePort);
|
"%s:%d\n",RemoteHost,RemotePort);
|
||||||
}
|
}
|
||||||
} else
|
}
|
||||||
|
if (local_logging == TRUE)
|
||||||
#endif
|
#endif
|
||||||
/* now spew out the message to wherever it is supposed to go */
|
/* now spew out the message to wherever it is supposed to go */
|
||||||
message("%s %s %s %s\n", timestamp, LocalHostName, res, msg);
|
message("%s %s %s %s\n", timestamp, LocalHostName, res, msg);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -529,6 +531,9 @@ extern int syslogd_main(int argc, char **argv)
|
|||||||
doRemoteLog = TRUE;
|
doRemoteLog = TRUE;
|
||||||
stopDoingThat = TRUE;
|
stopDoingThat = TRUE;
|
||||||
break;
|
break;
|
||||||
|
case 'N':
|
||||||
|
local_logging = FALSE;
|
||||||
|
break;
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
usage(syslogd_usage);
|
usage(syslogd_usage);
|
||||||
|
1
usage.c
1
usage.c
@ -1176,6 +1176,7 @@ const char syslogd_usage[] =
|
|||||||
"\t-O FILE\t\tUse an alternate log file (default=/var/log/messages)\n"
|
"\t-O FILE\t\tUse an alternate log file (default=/var/log/messages)\n"
|
||||||
#ifdef BB_FEATURE_REMOTE_LOG
|
#ifdef BB_FEATURE_REMOTE_LOG
|
||||||
"\t-R HOST[:PORT]\t\tLog remotely to IP or hostname on PORT (default PORT=514/UDP)\n"
|
"\t-R HOST[:PORT]\t\tLog remotely to IP or hostname on PORT (default PORT=514/UDP)\n"
|
||||||
|
"\t-N\t\tDo not log anything locally -- network logging only.\n"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
;
|
;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user