以下代码片段尝试创建一个连接到特定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的Web界面列出了多个可用服务,该命令也会打印零,。 为什么会发生这种情况?
我连接到的守护程序正在运行软件的v 7.5.1,而我正在使用的
rvconfig.jar
也来自v 7.5.1。使用Tibco的DaemonManager时会引起我卡住的情况吗?
最佳答案
我使用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只是一个屏幕抓取器。
但是,如果它们出现在正在屏幕抓取的网页上,为什么我没有任何服务?
打开调试:
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一起提出! :(