博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PostgreSQL的notify 与listen (五)
阅读量:6703 次
发布时间:2019-06-25

本文共 1534 字,大约阅读时间需要 5 分钟。

利用PostgreSQL的notify /listen 机制,可以实现在psql客户端看到通知消息。
但是,如果是Java 应用程序,将会是怎样的?
按照PostgreSQL的官方文档,是这样说的:
http://jdbc.postgresql.org/documentation/91/listennotify.html
A key limitation of the JDBC driver is that it cannot receive asynchronous notifications and must poll the backend to check if any notifications were issued.
Java程序通过JDBC Driver,来被数据库端数据变化/消息通知激活,是不能直接实现的。
只不过是采用变通方式,还是要轮询数据库端,只是"select 1"这种查询,可以尽量使网络通讯量较少。
摘要其关键代码如下:
复制代码
 1 while (true) {                
 2     try {            
 3       // issue a dummy query to contact the backend        
 4       // and receive any pending notifications.        
 5       Statement stmt = conn.createStatement();        
 6       ResultSet rs = stmt.executeQuery("SELECT 1");        
 7       rs.close();        
 8       stmt.close();        
 9                 
10      org.postgresql.PGNotification notifications[] = pgconn.getNotifications(); 11      if (notifications != null) {        
12          for (int i=0; i<notifications.length; i++) {    
13           System.out.println("Got notification: " + notifications[i].getName());
14             }    
15      }        
16                 
17      // wait a while before checking again for new        
18      // notifications        
19      Thread.sleep(500);
       ...        
复制代码
打个比方来说,剧场看门人和剧场经理是观察者模式,剧场经理有了新剧目,他会通知看门人。
而你作为观众,没必要老去打扰繁忙的剧场经理,只要隔一段时间打电话给剧场看门人。
电话费比较贵(越洋国际电话10美刀/分钟)所以,你给看门人打电话时,只是简单问候。
如果剧场看门人已经被剧场经理通知有新剧目,他会告诉你说有新戏某某!你就知道有新剧目了。
你作为观众就是 Java Thread      
电话设备和电话线就是 JDBC Driver
你给看门人打电话就是 "select 1"  
看门人就是 libpq里的 PGNotification
剧场经理就是 PostgreSQL后台服务器进程
你的大老板则是最终用户。大老板看来,下面的经理(Java Application)忙着向他汇报工作;
当国外剧场有新剧目的时候,花很少钱(你和看门人联系,废话从不多讲),也没有耽误(电话都是你这个Java Thread 来用的) 工作,就知道了消息;于是大老板坐飞机去悉尼看戏去也。
http://www.cnblogs.com/gaojian/archive/2012/07/12/2588368.htmlXXXXXXXX,如需转载请自行联系原作者
你可能感兴趣的文章
php 性能分析工具 xhprof 使用
查看>>
C++Builder 2010深入TForm类之方法
查看>>
Horizon View 网络配置要点
查看>>
java实现spark streaming与kafka集成进行流式计算
查看>>
这个招聘不错!!
查看>>
7月第2周游戏运营类网站/频道:91.com首次第一
查看>>
7月28日全球域名商(国际域名)解析新增量TOP20
查看>>
rsync工具介绍/rsync通过ssh同步
查看>>
win7启动盘或PE无法启动,原因是U盘问题
查看>>
(二) azure虚拟机
查看>>
最佳实践:使用负载均衡SLB IPv6搞定苹果AppStore审核
查看>>
腾讯的核心竞争力到底是什么?
查看>>
Redis学习(2)—— 实例与注释说明
查看>>
windows2008NPS(网络连接策略)设置radius 实现telent登陆交换机路由器权限分配
查看>>
nginx-如何将自己的HTTP模块编译进nginx
查看>>
亚洲各国程序员命运 中国程序员为高薪奋斗
查看>>
用shell统计局域网内的IP+MAC地址,还有没有使用的IP地址
查看>>
vim 查找替换 和高级应用 vim的多行注释和替换
查看>>
linux out of memory分析
查看>>
ExtJS给iframe设置src
查看>>