Создание процесса демона в Linux
#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>
int main(void) {
/* Our process ID and Session ID */
pid_t pid, sid;
/* Fork off the parent process */
pid = fork();
if (pid == 0) { //child process
CreateSocket(); //this function will recieve the data from the client
}
else
{
exit(EXIT_SUCCESS); //exit the parent process
}
/* Change the file mode mask */
umask(0);
/* Open any logs here */
/* Create a new SID for the child process */
sid = setsid();
if (sid < 0) {
/* Log the failure */
exit(EXIT_FAILURE);
}
/* Change the current working directory */
if ((chdir("/")) < 0) {
/* Log the failure */
exit(EXIT_FAILURE);
}
/* Close out the standard file descriptors */
close(STDIN_FILENO);
close(STDOUT_FILENO);
close(STDERR_FILENO);
/* Daemon-specific initialization goes here */
/* The Big Loop */
while (1) {
/* Do some task here ... */
Timer(); // this will create a timer and call the task for every 2ms, 10ms
}
exit(EXIT_SUCCESS);
}
Моя задача - получить данные от клиента через сокет и запустить таймер в фоновом режиме. Поэтому я создал родительский процесс и дочерний процесс, а затем процесс демона для запуска в фоновом режиме. Я вызвал функцию CreateSocket(); в дочернем процессе, чтобы получить данные от клиента в дочернем процессе, и я ничего не делаю в родительском процессе (просто я выхожу). Позже вызов демона для запуска моей задачи таймера в фоновом режиме
мой вопрос: если я сделаю, как указано выше, то моя задача таймера будет продолжать работать в фоновом режиме, а создание сокета будет продолжать получать данные от клиента
2 ответа
Если ваше приложение является одним из следующих типов:
{
".sh": "bash",
".py": "python",
".rb": "ruby",
".coffee" : "coffee",
".php": "php",
".pl" : "perl",
".js" : "node"
}
Вы хотите использовать пакет pm2 от npm.
Это демонизирует ваше приложение, просто запустив pm2 start.
Более того, хотя ваше приложение, как правило, работает на 1 ядре, с pm2 вы можете очень легко запустить приложение на всех ядрах, и оно будет балансировать нагрузку между ядрами. Если это звучит слишком экзотично для вас, то и баланс нагрузки не составит труда!
Это то что ты делаешь:
npm install -g pm2
pm2 start app.js -i 0 --name "api" # load balance app on all cores
pm2 start app.js --name "api" # run on 1 core, like apps typically do
затем:
pm2 startup (creates a pm2 systemd or equivalent service)
pm2 save (remembers the apps pm2 is running and starts them on reboot)
Готово!
Самый простой способ демонизации какого-либо процесса - использовать библиотечную функцию daemon(3) (внутренне основанную на fork
а также setsid
...) в начале вашей программы (например, перед созданием какого-либо потока).