Exemplo de daemon em C II

Publicado por Andre Luiz da Silva 14/05/2004

[ Hits: 7.998 ]

Homepage: http://localhost

Download exampled1.c




Galera... mais um exmplo de um daemon em C, agora usando mais alguns recursos como o uso syslog.  Em um único código vc vai ver um exemplo de fork, uso do syslog e signals. belê?!


obs: eu não escrevi o código ;-)

  



Esconder código-fonte

/*
UNIX Daemon Server Programming Sample Program
Levent Karakas <levent@mis.boun.edu.tr> May 2001

To compile:   cc -o exampled examped.c
To run:      ./exampled
To test daemon:   ps -ef|grep exampled (or ps -aux on BSD systems)
To test log:   tail -f /tmp/exampled.log
To test signal:   kill -HUP `cat /tmp/exampled.lock`
To terminate:   kill `cat /tmp/exampled.lock`
*/

#include <stdio.h>
#include <fcntl.h>
#include <signal.h>
#include <unistd.h>

#define RUNNING_DIR   "/tmp"
#define LOCK_FILE   "exampled.lock"
#define LOG_FILE   "exampled.log"

void log_message(filename,message)
char *filename;
char *message;
{
FILE *logfile;
   logfile=fopen(filename,"a");
   if(!logfile) return;
   fprintf(logfile,"%s\n",message);
   fclose(logfile);
}

void signal_handler(sig)
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 */
}

main()
{
   daemonize();
   while(1) sleep(1); /* run */
}

/* EOF */

Scripts recomendados

Signal

Anagramas

Jogo da velha, básico

Método de Power para calcular o autovelor dominante de uma matriz

A - Comando streql


  

Comentários
[1] Comentário enviado por filiagees em 22/12/2011 - 19:17h

Muito bom esse programa! Dá para entender bem o que cada parte faz.

obs, precisei acrescentar:

#include <stdlib.h> //exit()
#include <string.h> //strlen()
#include <sys/types.h> //
#include <sys/stat.h> //umask()


Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts