简单的客户端程序获取Tibco EMS Server状态信息

目标

编写Java代码,根据提供的URL, username, password连接到EMS Server,并获取指定名字的Queue的状态信息,比如ConsumerCount、PendingMessageCount等

代码

import com.tibco.tibjms.admin.QueueInfo;
import com.tibco.tibjms.admin.TibjmsAdmin;
import com.tibco.tibjms.admin.TibjmsAdminException;

/**
 * Created on 12/17/2015.
 */
public class TestEMSClient {
    public static final String user = "xxx";
    public static final String password = "xxx";
    public static final String url = "xxx";
    public static final String queueName = "xxx";

    public static void main(String[] args) {
        try {
            // 连接server获取TibjmsAdmin对象
            TibjmsAdmin admin = new TibjmsAdmin(url, user, password);
            // 根据queueName获取QueueInfo对象,Queue的所有状态信息都在该对象中获取
            QueueInfo queueInfo = admin.getQueue(queueName);
            printStatusInfo(queueInfo);
        } catch (TibjmsAdminException e) {
            e.printStackTrace();
        }
    }

    // 打印QueueInfo对象的一些信息
    private static void printStatusInfo(QueueInfo queueInfo) {
        System.out.println("Queue name: " + queueInfo.getName());
        System.out.println("ConsumerCount:" + queueInfo.getConsumerCount());
        System.out.println("PendingMessageCount: " + queueInfo.getPendingMessageCount());
    }
}

注意点

运行该代码需要依赖tibcojms相关的jar包:tibcojmsadmin.jar,jms.jar(tibcojmsadmin.jar依赖)
这些jar包可以在tibco ems的安装目录里Lib文件夹下找到

参考:

[TIBCO Enterprise Message Service™
User’s Guide]
[TIBCO Ems Java Api Reference]

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TIBCO Rendezvous(RV)是一种基于消息的中间件,它提供了高效、可靠的消息传递机制。下面是一个简单Java RV Server 和 Client 的示例代码: Server: ```java import com.tibco.tibrv.*; public class RVServer implements TibrvMsgCallback { private TibrvQueue queue; private TibrvRvdTransport transport; public RVServer(String service, String network, String daemon) throws TibrvException { Tibrv.open(); queue = new TibrvQueue(); transport = new TibrvRvdTransport(service, network, daemon); new TibrvListener(queue, this, transport, "test.subject", null); } public void onMsg(TibrvListener listener, TibrvMsg msg) { try { String message = msg.getField("message").data.toString(); System.out.println("Received message: " + message); } catch (TibrvException e) { e.printStackTrace(); } } public void start() throws TibrvException { queue.dispatch(); } public void stop() throws TibrvException { Tibrv.close(); } public static void main(String[] args) { try { RVServer server = new RVServer("7500", null, "tcp:7500"); server.start(); } catch (TibrvException e) { e.printStackTrace(); } } } ``` Client: ```java import com.tibco.tibrv.*; public class RVClient { private TibrvRvdTransport transport; public RVClient(String service, String network, String daemon) throws TibrvException { Tibrv.open(); transport = new TibrvRvdTransport(service, network, daemon); } public void send(String subject, String message) throws TibrvException { TibrvMsg msg = new TibrvMsg(); msg.setSendSubject(subject); msg.add("message", message); transport.send(msg); System.out.println("Sent message: " + message); } public void stop() throws TibrvException { Tibrv.close(); } public static void main(String[] args) { try { RVClient client = new RVClient("7500", null, "tcp:7500"); client.send("test.subject", "Hello, World!"); client.stop(); } catch (TibrvException e) { e.printStackTrace(); } } } ``` 在上面的示例中,Server 和 Client 都使用了 `TibrvRvdTransport` 来进行通信。Server 运行在本地的 `7500` 端口上,监听 `test.subject` 主题。当收到消息时,会调用 `onMsg` 方法进行处理。Client 发送一条消息到 `test.subject` 主题。 需要注意的是,上述代码需要使用 TIBCO RV Java API 来编译和运行。你需要在项目中添加相应的 JAR 文件,并在代码中进行引用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值