C Syslog.h не записывает журнал

Привет, хакеры Stackoverflow!

У меня очень незначительный случай серьезной проблемы или недопонимания между мной и функцией C syslog () .

Код компилируется отлично, и я вижу, что он выполняет свою "фиктивную работу" (пинг 8.8.8.8), но определенный журнал просто не добавляется. Я полностью озадачен этим и понятия не имею, что могло ошибаюсь. Уже SMAO (искал мою задницу - пытаюсь популяризировать это), но просто не могу заставить его работать должным образом.

Код здесь:

#include <sys/types.h>
#include <sys/stat.h>
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <errno.h>
#include <unistd.h>
#include <syslog.h>
#include <string.h>

// Application settings # TODO: import these from a .ini file

#define WORKDIR   "/var/run/management"
#define LOGDIR    "/var/log/management"
#define LOGFILE   "/var/log/management.log"
#define SCRIPTDIR "/var/spool/management"
#define PIDFILE   "/var/run/management/daemon.pid"

int main(void) {
  printf("Management Daemon\nInitializing...");
  pid_t pid, sid;

  setlogmask(LOG_UPTO (LOG_NOTICE));
  openlog(LOGFILE, LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
  syslog(LOG_NOTICE, "Management Daemon started by User %d", getuid());
  closelog();

  printf("Done.\nForking...\n");

  pid = fork();
  if(pid < 0) {
    printf("Fork failed! Exiting...\n");
    // TODO: syslog facility

    syslog(LOG_EMERG, "Forking failed, exiting.");
    closelog();

    exit(EXIT_FAILURE);
  }
  if(pid > 0) {
    FILE *pidfile;
    pidfile = fopen(PIDFILE, "w");
    fprintf(pidfile, "%d\n", pid);
    fclose(pidfile);
    printf("PID written to %s\nUsing log file %s\nGoing silent...\n", PIDFILE, LOGFILE);
    // TODO: syslog facility

    openlog(LOGFILE, LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
    syslog(LOG_NOTICE, "Fork returned with valid PID: %d. PID file: %s", pid, PIDFILE);

    exit(EXIT_SUCCESS);
  }

  umask(0);

  sid = setsid();
  if(sid < 0) {
    // TODO: syslog facility
    printf("SID is corrupt\n");
    exit(EXIT_FAILURE);
  }
  if(sid > 0) {
    printf("Acquired valid SID!\n");
  }
  if((chdir(WORKDIR)) < 0) {
    // TODO: syslog facility
    printf("Directory change failed. Got permissions?\n");
    exit(EXIT_FAILURE);
  }

  // Going Silent
  close(STDIN_FILENO);
  close(STDOUT_FILENO);
  close(STDERR_FILENO);

  // daemon init here

  FILE *fp;

  // The big loop
  closelog();

  while(1) {
    // Do your thing...
    // TODO: implement daemon executing mechanics.
    ret = system("ping 8.8.8.8 -c 1");
    fp = fopen("/var/run/management.output", "a");
    if(ret == 0) {
      fprintf(fp, "Success!\n");
      fclose(fp);
    }
    if(ret == 512) {
      fprintf(fp, "Failure!\n");
      fclose(fp);
    }
    // Sleep till the next heartbeat
    // TODO: notice level log about heartbeats if verbosity is set to high
    sleep(30);
  }
 exit(EXIT_SUCCESS);
}

Любая помощь будет очень признательна!

estol


Решение:

В syslog-ng.conf добавлены следующие строки:

destination d_management { file("/var/log/management/management.log"); };
filter f_management { match("MD:" value("MESSAGE")); };
log { source(src); filter(f_management); destination(d_management);  };

Все сообщения журнала, содержащие последовательность MD:, будут перенаправлены в файл management.log.

Привет, хакеры Stackoverflow!

У меня очень незначительный случай серьезной проблемы или недопонимания между мной и функцией syslog () C.

Код компилируется отлично, и я вижу, что он делает свое "фиктивное задание" (пинг 8.8.8.8), но определенный журнал просто не добавляется. Я полностью озадачен этим и понятия не имею, что может быть не так. Уже SMAO (искал мою задницу - пытаюсь популяризировать это), но просто не могу заставить его работать должным образом.

Код здесь:

#include <sys/types.h>
#include <sys/stat.h>
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <errno.h>
#include <unistd.h>
#include <syslog.h>
#include <string.h>

// Application settings # TODO: import these from a .ini file

#define WORKDIR   "/var/run/management"
#define LOGDIR    "/var/log/management"
#define LOGFILE   "/var/log/management.log"
#define SCRIPTDIR "/var/spool/management"
#define PIDFILE   "/var/run/management/daemon.pid"

int main(void) {
  printf("Management Daemon\nInitializing...");
  pid_t pid, sid;

  setlogmask(LOG_UPTO (LOG_NOTICE));
  openlog(LOGFILE, LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
  syslog(LOG_NOTICE, "Management Daemon started by User %d", getuid());
  closelog();

  printf("Done.\nForking...\n");

  pid = fork();
  if(pid < 0) {
    printf("Fork failed! Exiting...\n");
    // TODO: syslog facility

    syslog(LOG_EMERG, "Forking failed, exiting.");
    closelog();

    exit(EXIT_FAILURE);
  }
  if(pid > 0) {
    FILE *pidfile;
    pidfile = fopen(PIDFILE, "w");
    fprintf(pidfile, "%d\n", pid);
    fclose(pidfile);
    printf("PID written to %s\nUsing log file %s\nGoing silent...\n", PIDFILE, LOGFILE);
    // TODO: syslog facility

    openlog(LOGFILE, LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
    syslog(LOG_NOTICE, "Fork returned with valid PID: %d. PID file: %s", pid, PIDFILE);

    exit(EXIT_SUCCESS);
  }

  umask(0);

  sid = setsid();
  if(sid < 0) {
    // TODO: syslog facility
    printf("SID is corrupt\n");
    exit(EXIT_FAILURE);
  }
  if(sid > 0) {
    printf("Acquired valid SID!\n");
  }
  if((chdir(WORKDIR)) < 0) {
    // TODO: syslog facility
    printf("Directory change failed. Got permissions?\n");
    exit(EXIT_FAILURE);
  }

  // Going Silent
  close(STDIN_FILENO);
  close(STDOUT_FILENO);
  close(STDERR_FILENO);

  // daemon init here

  FILE *fp;

  // The big loop
  closelog();

  while(1) {
    // Do your thing...
    // TODO: implement daemon executing mechanics.
    ret = system("ping 8.8.8.8 -c 1");
    fp = fopen("/var/run/management.output", "a");
    if(ret == 0) {
      fprintf(fp, "Success!\n");
      fclose(fp);
    }
    if(ret == 512) {
      fprintf(fp, "Failure!\n");
      fclose(fp);
    }
    // Sleep till the next heartbeat
    // TODO: notice level log about heartbeats if verbosity is set to high
    sleep(30);
  }
 exit(EXIT_SUCCESS);
}

Любая помощь будет очень признательна!

estol


Решение:

В syslog-ng.conf добавлены следующие строки:

destination d_management { file("/var/log/management/management.log"); };
filter f_management { match("MD:" value("MESSAGE")); };
log { source(src); filter(f_management); destination(d_management);  };

Все сообщения журнала, содержащие последовательность MD :, будут перенаправлены в файл management.log.

Привет, хакеры Stackoverflow!

У меня очень незначительный случай серьезной проблемы или недопонимания между мной и функцией syslog () C.

Код компилируется отлично, и я вижу, что он делает свое "фиктивное задание" (пинг 8.8.8.8), но определенный журнал просто не добавляется. Я полностью озадачен этим и понятия не имею, что может быть не так. Уже SMAO (искал мою задницу - пытаюсь популяризировать это), но просто не могу заставить его работать должным образом.

Код здесь:

#include <sys/types.h>
#include <sys/stat.h>
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <errno.h>
#include <unistd.h>
#include <syslog.h>
#include <string.h>

// Application settings # TODO: import these from a .ini file

#define WORKDIR   "/var/run/management"
#define LOGDIR    "/var/log/management"
#define LOGFILE   "/var/log/management.log"
#define SCRIPTDIR "/var/spool/management"
#define PIDFILE   "/var/run/management/daemon.pid"

int main(void) {
  printf("Management Daemon\nInitializing...");
  pid_t pid, sid;

  setlogmask(LOG_UPTO (LOG_NOTICE));
  openlog(LOGFILE, LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
  syslog(LOG_NOTICE, "Management Daemon started by User %d", getuid());
  closelog();

  printf("Done.\nForking...\n");

  pid = fork();
  if(pid < 0) {
    printf("Fork failed! Exiting...\n");
    // TODO: syslog facility

    syslog(LOG_EMERG, "Forking failed, exiting.");
    closelog();

    exit(EXIT_FAILURE);
  }
  if(pid > 0) {
    FILE *pidfile;
    pidfile = fopen(PIDFILE, "w");
    fprintf(pidfile, "%d\n", pid);
    fclose(pidfile);
    printf("PID written to %s\nUsing log file %s\nGoing silent...\n", PIDFILE, LOGFILE);
    // TODO: syslog facility

    openlog(LOGFILE, LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
    syslog(LOG_NOTICE, "Fork returned with valid PID: %d. PID file: %s", pid, PIDFILE);

    exit(EXIT_SUCCESS);
  }

  umask(0);

  sid = setsid();
  if(sid < 0) {
    // TODO: syslog facility
    printf("SID is corrupt\n");
    exit(EXIT_FAILURE);
  }
  if(sid > 0) {
    printf("Acquired valid SID!\n");
  }
  if((chdir(WORKDIR)) < 0) {
    // TODO: syslog facility
    printf("Directory change failed. Got permissions?\n");
    exit(EXIT_FAILURE);
  }

  // Going Silent
  close(STDIN_FILENO);
  close(STDOUT_FILENO);
  close(STDERR_FILENO);

  // daemon init here

  FILE *fp;

  // The big loop
  closelog();

  while(1) {
    // Do your thing...
    // TODO: implement daemon executing mechanics.
    ret = system("ping 8.8.8.8 -c 1");
    fp = fopen("/var/run/management.output", "a");
    if(ret == 0) {
      fprintf(fp, "Success!\n");
      fclose(fp);
    }
    if(ret == 512) {
      fprintf(fp, "Failure!\n");
      fclose(fp);
    }
    // Sleep till the next heartbeat
    // TODO: notice level log about heartbeats if verbosity is set to high
    sleep(30);
  }
 exit(EXIT_SUCCESS);
}

Любая помощь будет очень признательна!

estol


Решение:

В syslog-ng.conf добавлены следующие строки:

destination d_management { file("/var/log/management/management.log"); };
filter f_management { match("MD:" value("MESSAGE")); };
log { source(src); filter(f_management); destination(d_management);  };

Все сообщения журнала, содержащие последовательность MD :, будут перенаправлены в файл management.log.

Код компилируется отлично, и я вижу, что он выполняет свою «фиктивную работу» (пинг 8.8.8.8), но определенный журнал просто не добавляется. Я совершенно озадачен этим и понятия не имею, что может быть не так. Уже SMAO (искал мою задницу - пытаюсь популяризировать это), но просто не могу заставить его работать должным образом.

Код здесь:

#include <sys/types.h>
#include <sys/stat.h>
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <errno.h>
#include <unistd.h>
#include <syslog.h>
#include <string.h>

// Application settings # TODO: import these from a .ini file

#define WORKDIR   "/var/run/management"
#define LOGDIR    "/var/log/management"
#define LOGFILE   "/var/log/management.log"
#define SCRIPTDIR "/var/spool/management"
#define PIDFILE   "/var/run/management/daemon.pid"

int main(void) {
  printf("Management Daemon\nInitializing...");
  pid_t pid, sid;

  setlogmask(LOG_UPTO (LOG_NOTICE));
  openlog(LOGFILE, LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
  syslog(LOG_NOTICE, "Management Daemon started by User %d", getuid());
  closelog();

  printf("Done.\nForking...\n");

  pid = fork();
  if(pid < 0) {
    printf("Fork failed! Exiting...\n");
    // TODO: syslog facility

    syslog(LOG_EMERG, "Forking failed, exiting.");
    closelog();

    exit(EXIT_FAILURE);
  }
  if(pid > 0) {
    FILE *pidfile;
    pidfile = fopen(PIDFILE, "w");
    fprintf(pidfile, "%d\n", pid);
    fclose(pidfile);
    printf("PID written to %s\nUsing log file %s\nGoing silent...\n", PIDFILE, LOGFILE);
    // TODO: syslog facility

    openlog(LOGFILE, LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
    syslog(LOG_NOTICE, "Fork returned with valid PID: %d. PID file: %s", pid, PIDFILE);

    exit(EXIT_SUCCESS);
  }

  umask(0);

  sid = setsid();
  if(sid < 0) {
    // TODO: syslog facility
    printf("SID is corrupt\n");
    exit(EXIT_FAILURE);
  }
  if(sid > 0) {
    printf("Acquired valid SID!\n");
  }
  if((chdir(WORKDIR)) < 0) {
    // TODO: syslog facility
    printf("Directory change failed. Got permissions?\n");
    exit(EXIT_FAILURE);
  }

  // Going Silent
  close(STDIN_FILENO);
  close(STDOUT_FILENO);
  close(STDERR_FILENO);

  // daemon init here

  FILE *fp;

  // The big loop
  closelog();

  while(1) {
    // Do your thing...
    // TODO: implement daemon executing mechanics.
    ret = system("ping 8.8.8.8 -c 1");
    fp = fopen("/var/run/management.output", "a");
    if(ret == 0) {
      fprintf(fp, "Success!\n");
      fclose(fp);
    }
    if(ret == 512) {
      fprintf(fp, "Failure!\n");
      fclose(fp);
    }
    // Sleep till the next heartbeat
    // TODO: notice level log about heartbeats if verbosity is set to high
    sleep(30);
  }
 exit(EXIT_SUCCESS);
}

Любая помощь будет очень признательна!

estol


Решение:

В syslog-ng.conf добавлены следующие строки:

destination d_management { file("/var/log/management/management.log"); };
filter f_management { match("MD:" value("MESSAGE")); };
log { source(src); filter(f_management); destination(d_management);  };

Все сообщения журнала, содержащие последовательность MD :, будут перенаправлены в файл management.log.

Код компилируется отлично, и я вижу, что он выполняет свою «фиктивную работу» (пинг 8.8.8.8), но определенный журнал просто не добавляется. Я совершенно озадачен этим и понятия не имею, что может быть не так. Уже SMAO (искал мою задницу - пытаюсь популяризировать это), но просто не могу заставить его работать должным образом.

Код здесь:

#include <sys/types.h>
#include <sys/stat.h>
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <errno.h>
#include <unistd.h>
#include <syslog.h>
#include <string.h>

// Application settings # TODO: import these from a .ini file

#define WORKDIR   "/var/run/management"
#define LOGDIR    "/var/log/management"
#define LOGFILE   "/var/log/management.log"
#define SCRIPTDIR "/var/spool/management"
#define PIDFILE   "/var/run/management/daemon.pid"

int main(void) {
  printf("Management Daemon\nInitializing...");
  pid_t pid, sid;

  setlogmask(LOG_UPTO (LOG_NOTICE));
  openlog(LOGFILE, LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
  syslog(LOG_NOTICE, "Management Daemon started by User %d", getuid());
  closelog();

  printf("Done.\nForking...\n");

  pid = fork();
  if(pid < 0) {
    printf("Fork failed! Exiting...\n");
    // TODO: syslog facility

    syslog(LOG_EMERG, "Forking failed, exiting.");
    closelog();

    exit(EXIT_FAILURE);
  }
  if(pid > 0) {
    FILE *pidfile;
    pidfile = fopen(PIDFILE, "w");
    fprintf(pidfile, "%d\n", pid);
    fclose(pidfile);
    printf("PID written to %s\nUsing log file %s\nGoing silent...\n", PIDFILE, LOGFILE);
    // TODO: syslog facility

    openlog(LOGFILE, LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
    syslog(LOG_NOTICE, "Fork returned with valid PID: %d. PID file: %s", pid, PIDFILE);

    exit(EXIT_SUCCESS);
  }

  umask(0);

  sid = setsid();
  if(sid < 0) {
    // TODO: syslog facility
    printf("SID is corrupt\n");
    exit(EXIT_FAILURE);
  }
  if(sid > 0) {
    printf("Acquired valid SID!\n");
  }
  if((chdir(WORKDIR)) < 0) {
    // TODO: syslog facility
    printf("Directory change failed. Got permissions?\n");
    exit(EXIT_FAILURE);
  }

  // Going Silent
  close(STDIN_FILENO);
  close(STDOUT_FILENO);
  close(STDERR_FILENO);

  // daemon init here

  FILE *fp;

  // The big loop
  closelog();

  while(1) {
    // Do your thing...
    // TODO: implement daemon executing mechanics.
    ret = system("ping 8.8.8.8 -c 1");
    fp = fopen("/var/run/management.output", "a");
    if(ret == 0) {
      fprintf(fp, "Success!\n");
      fclose(fp);
    }
    if(ret == 512) {
      fprintf(fp, "Failure!\n");
      fclose(fp);
    }
    // Sleep till the next heartbeat
    // TODO: notice level log about heartbeats if verbosity is set to high
    sleep(30);
  }
 exit(EXIT_SUCCESS);
}

Любая помощь будет принята с благодарностью!

estol


Решение:

В syslog-ng.conf добавлены следующие строки:

destination d_management { file("/var/log/management/management.log"); };
filter f_management { match("MD:" value("MESSAGE")); };
log { source(src); filter(f_management); destination(d_management);  };

Все сообщения журнала, содержащие последовательность MD :, будут перенаправлены в файл management.log. Работает как шарм. Еще раз спасибо за то, что указали мне правильное направление.

9
задан Peter Szabo 31 August 2014 в 16:15
поделиться