这篇文章将为大家详细讲解有关PostgreSQL在Windows系统下的信号处理都是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
PostgreSQL在Windows下的信号处理,其实只能说是模拟或者代码封装,调用的时候看起来也是 pgsignal
函数,实现了代码的跨平台,但在实现上完全跟信号无关,毕竟Windows也没有这个特性。
1、PostgreSQL的Windows代码在函数 save_backend_variables
中:
#ifdef WIN32 param->PostmasterHandle = PostmasterHandle; if (!write_duplicated_handle(¶m->initial_signal_pipe, pgwin32_create_signal_listener(childPid), childProcess)) return false; #else
下边分别讲这里的两个函数,用到的API可以自行查阅微软文档。
2、创建命名管道
函数 pgwin32_create_signal_listener
的作用是创建一个命名管道
snprintf(pipename, sizeof(pipename), "\\\\.\\pipe\\pgsignal_%u", (int) pid); pipe = CreateNamedPipe(pipename, PIPE_ACCESS_DUPLEX, PIPE_TYPE_MESSAGE | PIPE_READMODE_MESSAGE | PIPE_WAIT, PIPE_UNLIMITED_INSTANCES, 16, 16, 1000, NULL);
3、复制管道句柄
函数 write_duplicated_handle
中:
if (!DuplicateHandle(GetCurrentProcess(), src, childProcess, &hChild, 0, TRUE, DUPLICATE_CLOSE_SOURCE | DUPLICATE_SAME_ACCESS))
这个复制的句柄通过 param
传递给新创建的后端进程。
4、Windows下的信号函数
pqsigfunc pqsignal(int signum, pqsigfunc handler) { pqsigfunc prevfunc; if (signum >= PG_SIGNAL_COUNT || signum < 0) return SIG_ERR; prevfunc = pg_signal_array[signum]; pg_signal_array[signum] = handler; return prevfunc; }
这里有一个信号处理函数数组,pqsignal
的作用是记录下这是处理哪个信号的函数。
5、Windows下的 kill
函数
#define kill(pid,sig) pgkill(pid,sig) extern int pgkill(int pid, int sig);
在 pgkill
里,使用上边创建的命名管道
snprintf(pipename, sizeof(pipename), "\\\\.\\pipe\\pgsignal_%u", pid); if (CallNamedPipe(pipename, &sigData, 1, &sigRet, 1, &bytes, 1000))
将信号写入管道,例如 SIGHUP。
6、信号处理线程
在启动时,创建一个专门处理命名管道事件的线程:
/* Create thread for handling signals */ signal_thread_handle = CreateThread(NULL, 0, pg_signal_thread, NULL, 0, NULL);
7、后端进程的信号处理
函数 pg_signal_dispatch_thread
里(src/backend/port/win32/signal.c
):
/* Create thread for handling signals */ signal_thread_handle = CreateThread(NULL, 0, pg_signal_thread, NULL, 0, NULL); ... pg_queue_signal(sigNum);
关于PostgreSQL在Windows系统下的信号处理都是怎样的就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。