ich habe eine Serveranwendung welche auf der Mongoose Webserver API aufsetzt und bislang immer via Commandline gestartet wurde.
Nachdem ich mir ein Beispiel für einen C++ Daemon besorgt hatte und dieses eingebaut habe. Hatte ich diverse Probleme erhalten bei denen ich nun überfragt bin.
Problem: Habe festgestellt das der Server gar nicht auf HTTP Anfragen reagiert
Lösung: while(1) ans Ende gesetzt?
Problem: Unter Linux erhalte ich Ressourcen Probleme, d. h. Ressourcen die in der Konsolenanwendung geladen werden konnten werden so nicht gefunden
Lösung: offen
Problem: Embedded Hardware mit Busybox lässt keine Verbindung mit dem HTTP Server zu, Client hängt fest (Konsolenanwendung hingegen nicht)
Lösung: offen
Problem: Wie debugge ich den Daemon bzw. wie kann ich herausfinden was hier schief geht. Benötige ja das Logfile
Hoffe mir kann Jemand einen Rat geben (habe dies übrigens in einer C++ Community ebenfalls gepostet jedoch bisher ohne Ergebnis)
Code: Alles auswählen
#ifdef WIN32
#ifndef WIN32_LEAN_AND_MEAN
#define WIN32_LEAN_AND_MEAN
#endif
#include <windows.h>
#else
//Quelle http://www.enderunix.org/docs/eng/daemon.php
//abgeändert für c++, da sonst Fehler bzgl. Prototypdefinition erfolgen
#include <fcntl.h>
#include <signal.h>
#include <unistd.h>
#define RUNNING_DIR "/tmp"
#define LOCK_FILE "blubb.lock"
#define LOG_FILE "blubb.log"
void log_message(char *filename,char *message)
{
FILE *logfile;
logfile=fopen(filename,"a");
if(!logfile) return;
fprintf(logfile,"%s\n",message);
fclose(logfile);
}
void signal_handler(int sig)
{
switch(sig) {
case SIGHUP:
log_message(LOG_FILE,"hangup signal catched");
break;
case SIGTERM:
log_message(LOG_FILE,"terminate signal catched");
exit(0);
break;
}
}
void daemonize()
{
int i,lfp;
char str[10];
if(getppid()==1) return; /* already a daemon */
i=fork();
if (i<0) exit(1); /* fork error */
if (i>0) exit(0); /* parent exits */
/* child (daemon) continues */
setsid(); /* obtain a new process group */
for (i=getdtablesize();i>=0;--i) close(i); /* close all descriptors */
i=open("/dev/null",O_RDWR); dup(i); dup(i); /* handle standart I/O */
umask(027); /* set newly created file permissions */
chdir(RUNNING_DIR); /* change running directory */
lfp=open(LOCK_FILE,O_RDWR|O_CREAT,0640);
if (lfp<0) exit(1); /* can not open */
if (lockf(lfp,F_TLOCK,0)<0) exit(0); /* can not lock */
/* first instance continues */
sprintf(str,"%d\n",getpid());
write(lfp,str,strlen(str)); /* record pid to lockfile */
signal(SIGCHLD,SIG_IGN); /* ignore child */
signal(SIGTSTP,SIG_IGN); /* ignore tty signals */
signal(SIGTTOU,SIG_IGN);
signal(SIGTTIN,SIG_IGN);
signal(SIGHUP,signal_handler); /* catch hangup signal */
signal(SIGTERM,signal_handler); /* catch kill signal */
}
int main(int argc, char** argv) {
struct mg_context *ctx;
const char *options[] = {"listening_ports", "9999", NULL};
ctx = mg_start(&Service::mongooseCallbackStatic, NULL, options);
#ifndef WIN32
// TODO http://www.enderunix.org/docs/eng/daemon.php
daemonize();
#endif
getchar(); // Wait until user hits "enter"
return 0;
}