PostgreSQL的notify 与listen (六)

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
简介:
开两个终端执行psql,进行notify 与 listen动作的实验,当时我有一个疑问:

从listen 端看到的PID ,到底是谁的ID?

验证如下:

启动 postgres, 执行 ps -ef|grep postgres

看到除了系统级别的postgres外,并没有其他的。

postgres -D /usr/local/data  (进程号为19651/父进程号为1)
postgres:writer process
postgres:wal writer process
postgres:autovacuum launcher process
postgres:stats collector process

开session A(用作listen 端), psql:

postgres#listen gaojian;
postgres#
再来看 ps -ef|grep postgre:

发现多了一个  进程号19924/父进程号19651 的 名为postgres的进程。

这表明:为给session A 的psql 服务,服务器端启动了一个进程 号为19924的back end prosgres。

开session B(用作notify 端),psql:
postgres#notify gaojian;
postgres#
再来看 ps -ef|grep postgre:

发现又多了一个  进程号19938/父进程号19651 的 名为postgres的进程。

这表明:为给session B的psql 服务,服务器端启动了一个进程 号为19938的back end prosgres。

再回到session A, 随便执行一条命令:

postgres#select current_date;
...
收到来自伺服器 "gaojian" 进程PID 19938 非同步通知
postgres#
这表明 信息的发送者实际上是 和notify 端对应的 后台postgres进程。









本文转自健哥的数据花园博客园博客,原文链接:http://www.cnblogs.com/gaojian/archive/2012/07/13/2590274.html,如需转载请自行联系原作者
相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
关系型数据库 PostgreSQL
|
Java 关系型数据库 数据库连接
|
关系型数据库 PostgreSQL
|
关系型数据库 PostgreSQL
|
关系型数据库 PostgreSQL
|
关系型数据库 数据库 PostgreSQL
|
16天前
|
关系型数据库 MySQL 数据库
mysql卸载、下载、安装(window版本)
mysql卸载、下载、安装(window版本)