普通maven工程 引用dubbo

本文介绍了一个基于Dubbo框架实现的服务调用示例,包括应用配置、注册中心设置及服务引用过程。示例中详细展示了如何通过Zookeeper作为注册中心,并利用动态代理返回服务接口引用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class Main {
    static ApplicationConfig ac = null;
    static RegistryConfig rc = null;
    static PrestoManagerService managerService;
    static {
        try {
            ac = new ApplicationConfig();
            ac.setName("Test");//应用名字
            rc = new RegistryConfig();
            rc.setAddress("zookeeper://10.210.72.177:2181?backup=10.210.72.178:2181,10.210.72.179:2181");//zookeeper注册中心地址
            rc.setProtocol("zookeeper");//协议
            managerService = getProvider(PrestoManagerService.class, "");
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    
	private static <T> T getProvider(Class<T> c, String group) {
	        ReferenceConfig<T> rcc = new ReferenceConfig<T>();
	        rcc.setTimeout(50000);
	        rcc.setRegistry(rc);
	        rcc.setApplication(ac);
	        rcc.setCheck(false);
	        rcc.setInterface(c);
	        rcc.setGroup(group);
	        return rcc.get();
	}
	// 调用方法
	public static void excute(String sql) {
		System.out.println("sql : " + sql);
		 long t0 = System.currentTimeMillis();
		 //根据接口的字节码和服务的group获得接口引用(此处是dubbo通过你传入的参数 使用动态代理 返回给你接口的引用)
		 Map<String, Object> sqlData = managerService.getSqlData(sql);
		 long t1 = System.currentTimeMillis();
		 System.out.println(sqlData.get("data").toString());
		 System.out.println("时间/ms:" + (t1 - t0));
	}
	
	public static void main(String[] args) {
		excute(“”);
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值