为什么RvdProxy.getServices()错误地返回一个空数组?

时间:2010-03-11 18:08:05

标签: java tibco tibco-rv

以下代码段尝试创建连接到特定rvd的Tib DaemonManager,然后查询该rvd的服务。

public static void main(String[] args) throws RuntimeException {
    DaemonManager daemonManager = new DaemonManager("http://foo.com:7580");
    if(daemonManager.getDaemonType() == DaemonManager.RVD) {
        DaemonProxy daemonProxy = daemonManager.getDaemonProxy();
        final RvdProxy rvdProxy = (RvdProxy) daemonProxy;
        Service[] services = rvdProxy.getServices();
        System.out.println(services.length); //prints 0
        for (Service service : services) {
            System.out.println(service.getNetwork());
        }
    }
}

此打印零,即使此rvd的网络界面列出多个可用服务。 为什么会发生这种情况?

我要连接的守护程序正在运行v 7.5.1软件,而我正在使用的rvconfig.jar也来自v 7.5.1。

当使用Tibco的DaemonManager导致我失败时,有没有问题?

1 个答案:

答案 0 :(得分:4)

我使用Wireshark来查看我的RvdProxy和RVD本身之间发送的流量,它看起来像是HTTP GET流量的很多。例如:

0000  00 1e 0b a4 d1 7c 00 12  d9 7c 8a bf 08 00 45 00   .....|.. .|....E.
0010  03 87 a4 58 40 00 3d 06  66 90 0a 09 14 15 0a 0a   ...X@.=. f.......
0020  07 61 1d 9c bf 09 fe 1e  d6 82 6e 77 b9 52 80 18   .a...... ..nw.R..
0030  00 1b 05 43 00 00 01 01  08 0a ac 1c 6f 67 07 b2   ...C.... ....og..
0040  86 1f 72 3d 23 30 30 38  30 38 30 3e 3c 66 6f 6e   ..r=#008 080><fon
0050  74 20 66 61 63 65 3d 48  65 6c 76 65 74 69 63 61   t face=H elvetica
0060  2c 41 72 69 61 6c 20 73  69 7a 65 3d 32 20 63 6f   ,Arial s ize=2 co
0070  6c 6f 72 3d 23 46 46 46  46 46 46 3e 3c 62 3e 43   lor=#FFF FFF><b>C

果然,经过进一步检查,发现代理发出的请求是由守护程序本身提供的网页 - 所以代理API只是一个屏幕-scraper

但是,如果它们出现在被屏幕抓取的网页上,为什么我没有获得任何服务?

开启调试:

System.setProperty("com.tibco.tibrv.config.debug","classes-to-debug")

您发现用于从网页中提取服务的模式......

/services,GET~~~~~\
service_detail\\?(\\d+)>\\1</a>.*?size=2>(\\d+\\.\\d+\\.\\d+\\.\\d+)</td>.*?size=2>
(\\d+)</td>.*?size=2>(\\d+)</td>~~~~~\

......无法匹配任何东西!在我的情况下,这是因为我的服务网络不是形式为(\\d+\\.\\d+\\.\\d+\\.\\d+),而是形式为;(\\d+\\.\\d+\\.\\d+\\.\\d+) - 请注意前导分号。这种微妙的差异是我所有问题的根源!

这看起来像rvconfig jar中的一个错误 - 需要与Tibco一起提出! :(