- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我的基于 Libmongoose 的服务器在 Windows 终端和服务中运行良好。
现在,我正在将它移植到 Linux。它在终端中运行时完美运行。现在,我想将它作为守护进程运行——它可以工作,但令我惊讶的是它调用了所有函数两次。我检查了 PID 只有一个进程在运行。这让我疯狂。守护进程代码如下:
if(CommandArgs.at("-d") == "true")
{
#if __linux
pid_t pid, sid;
pid = fork();
if (pid < 0) {
exit(EXIT_FAILURE);
}
if (pid > 0) {
exit(EXIT_SUCCESS);
}
umask(0);
sid = setsid();
if (sid < 0) {
exit(EXIT_FAILURE);
}
/* Change the current working directory */
if ((chdir("/")) < 0) {
exit(EXIT_FAILURE);
}
/* Close out the standard file descriptors */
close(STDIN_FILENO);
close(STDOUT_FILENO);
close(STDERR_FILENO);
if(start_server() == false)
{
exit(EXIT_FAILURE);
}
else
{
signal(SIGHUP, signal_handler);
signal(SIGTERM, signal_handler);
signal(SIGINT, signal_handler);
signal(SIGQUIT, signal_handler);
pause();
}
//exit(EXIT_SUCCESS);
return 0;
#endif
}
现在,在我调用 start_server()
函数之后,内部函数被调用了两次:
static bool start_server()
{
try{
// invoked once as expected
MyLogger(2, "Info: Starting Server ...");
#ifdef _WIN32
mutex = CreateMutex( NULL, FALSE, NULL);
#else
pthread_mutex_init(&mutex, NULL);
#endif
for(int i = 0; i < serverConf.totalThreads; i++)
{
server[i] = mg_create_server(NULL, event_handler);
if(i==0)
{
const char * error_msg = mg_set_option(server[0], "listening_port", serverConf.port.c_str());
if (error_msg != NULL) {
MyLogger(1,"Error: Cannot bind to the port:",serverConf.port.c_str());
return false;
}
}
else
{
mg_copy_listeners(server[0], server[i]);
}
}
// Now all the logging happening twice
ServerStarted = true;
for(int i = 0; i < serverConf.totalThreads; i++)
{
mg_start_thread(serve, server[i]);
}
// server1 goes to separate thread, server 2 runs in main thread.
// IMPORTANT: NEVER LET DIFFERENT THREADS HANDLE THE SAME SERVER.
MyLogger(2, "Info: Server Started!"); // why was i logged twice
MyLogger(2, "Info: Listening on port:", mg_get_option(server[0], "listening_port")); // why was i logged twice
}
catch(std::exception& e)
{
return false;
}
return true;
}
现在日志是:
2015-04-27, 23:06:39 信息:启动服务器..
2015-04-27, 23:06:41 信息:服务器已启动!
2015-04-27, 23:06:41 信息:服务器已启动!
2015-04-27, 23:06:41 信息:监听端口:8091
2015-04-27, 23:06:41 信息:监听端口:8091
void MyLogger(int level, const char* msg1)
{
if(level > LogLevel)
{
return;
}
string time = currentDateTime();
std::ofstream out(LogFilePath.c_str(), std::fstream::app);
if(silentMode == false)
{
cout<<"\n"<<time<<" "<<msg1<<"\n";
}
out<<"\n"<<time<<" "<<msg1<<"\n";
}
最佳答案
消息似乎被函数 MyLogger()
复制了。在 silentMode == false
的情况下,它将向两个流打印相同的消息,但实际上它们可能是相同的流,否则两者的输出可能最终被重定向到同一个地方。
如果其中一个函数mg_create_server()
、mg_set_option()
或 mg_copy_listeners()
修改 out
,设置 silentMode
为 false
,或以其他方式进行会产生此类结果的更改。
关于c++ - Linux 守护进程 - 运行函数两次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29902775/
一 点睛 线程可以设置为守护线程,ThreadGroup 也可以设置为守护 ThreadGroup,但是若将一个 ThreadGroup 设置为 deamon,也并不会影响线程的 daemon 属性,
我有一个 python 脚本需要在启动时作为守护进程运行。进程从 tty(和 pdb)分离,但代码不运行。 我已经将它缩小到一个最小的例子 import daemon from time import
reactjs isMounted API 的文档提到: You can use this method to guard asynchronous calls to setState() or fo
我正在开发一个需要嵌入 HTTP 服务器的守护进程。我正在尝试使用 BaseHTTPServer 来完成它,当我在前台运行它时,它工作正常,但是当我尝试将守护进程 fork 到后台时,它停止工作。我的
我正在尝试使用 Apache Commons Daemon 使用 Daemon 接口(interface)来守护我的应用程序。 Java 应用程序本身不执行任何操作,只是写入 stout。 我编译了j
我正在使用 Bootle Python Web Framework 在 Ubuntu 上开发网络应用程序。是否有任何有效的方法来守护启动默认 bottlepy 网络服务器的脚本? 谢谢。 UPD:现在
我一直使用 bluepill成功地守护简单的 Ruby 脚本。然而这一次,我有一个脚本,它也在加载 Rails 环境,因此我可以访问 Rails 应用程序及其各自模型的数据库连接。我使用的 bluep
我试图守护一些代码,但我遇到了一些麻烦。 如果我用 tklogger() 调用代码,它运行得很好。但是,如果我在守护程序上下文中调用它,我会得到以下跟踪信息: Traceback (most rece
我打算使用 systemd 将 celery 4.3.0 作为守护进程运行,但它给了我这个错误: 它会启动 worker 但会很快停止它们。但是,我可以通过键入以下命令手动运行工作人员: celery
我是一名优秀的程序员,十分优秀!