多租户微服务中使用Java Config注册HSF服务

简介: 有了速卖通中间件的spring-boot-starter-hsf,在基于Spring Boot微服务中使用HSF,是件简单而惬意的事情。 我们首先来看最简单

有了速卖通中间件的spring-boot-starter-hsf,在基于Spring Boot微服务中使用HSF,是件简单而惬意的事情。

我们首先来看最简单的服务注册

@HSFProvider(serviceInterface = QasHsfService.class, serviceVersion = "1.0.0.qas", serviceGroup = "HSF")
public class QasHsfServiceImpl implements QasHsfService {
...
}

再附上最简单的服务调用

@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(QasHsfApplication.class)
public class QasHsfServiceConsumer {
    @HSFConsumer(serviceVersion = "1.0.0.qas", serviceGroup = "HSF")
    private QasHsfService qasHsfService;

    @Test
    public void testQuestion() {
        qasHsfService.question(new QasRequest());
    }
}

然后是入口类

@SpringBootApplication
@EnableHSF
@PropertySource("file:/opt/qas/qas.properties")
public class QasHsfApplication {
    public static void main(String[] args) {
        SpringApplication.run(QasHsfApplication.class, args);
    }
}

然后是……,没有了,就这么愉快地结束了。

以上代码实现,对于通用的微服务来说已经足够。但对于我们iDST的智能语音交互服务来说,还差点东西要填。

我们的每一种服务(确切地说,是由一份Java代码+一份C++代码编译后,容器化的一个镜像)会因为启动时引导的租户配置不同,而加载不同的算法模型。容器启动后,不同租户的服务,只在流程上是一致的。也就是说,镜像是一个,容器按租户分组。

那么,使用@HSFProvider这种静态注册服务的方式就不够用了,服务启动时,要从运维系统获取租户的分组信息,然后将其作为服务名称的一部分,注册为HSF服务。

这时,最理想、最优雅的方式就是使用Java Config来编程实现了:

@Configuration
public class QasHsfProviderConfig {
    @Bean(initMethod = "init")
    public HSFSpringProviderBean qasHsfProviderService() {
        HSFSpringProviderBean providerBean = new HSFSpringProviderBean();
        providerBean.setServiceInterface("com.aliyun.nls.hsf.QasHsfService");
        providerBean.setTarget(qasHsfServiceImpl());
        providerBean.setServiceVersion("1.0.0." + whoAmI());
        providerBean.setServiceGroup(HSFGroup.HSF.toString());
        return providerBean;
    }

    @Bean
    public QasHsfServiceImpl qasHsfServiceImpl() {
        return new QasHsfServiceImpl();
    }

    private String whoAmI() {
        //mock
        return "aliyun";
    }
}

相应地,服务调用可以是这样(调用端使用上述方式也是可以的,这里只为了保持风格一致,别怪我强迫症):

@Configuration
public class QasHsfConsumerConfig {

    @Bean(initMethod = "init",name="qasHsfConsumerService")
    public HSFSpringConsumerBean qasHsfConsumerService() {
        HSFSpringConsumerBean consumerBean = new HSFSpringConsumerBean();
        consumerBean.setInterfaceName("com.aliyun.nls.hsf.QasHsfService");
        consumerBean.setVersion("1.0.0.aliyun");
        consumerBean.setGroup(HSFGroup.HSF.toString());
        return consumerBean;
    }
}

@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(QasHsfApplication.class)
public class QasHsfServiceConsumer {

    @Autowired
    @Qualifier("qasHsfConsumerService")
    private QasHsfService qasHsfService;

    @Test
    public void testQuestion() {
        qasHsfService.question(new QasRequest());
    }
}
目录
相关文章
|
7月前
|
存储 数据采集 搜索推荐
Java 大视界 -- Java 大数据在智慧文旅旅游景区游客情感分析与服务改进中的应用实践(226)
本篇文章探讨了 Java 大数据在智慧文旅景区中的创新应用,重点分析了如何通过数据采集、情感分析与可视化等技术,挖掘游客情感需求,进而优化景区服务。文章结合实际案例,展示了 Java 在数据处理与智能推荐等方面的强大能力,为文旅行业的智慧化升级提供了可行路径。
Java 大视界 -- Java 大数据在智慧文旅旅游景区游客情感分析与服务改进中的应用实践(226)
|
5月前
|
JSON Java 数据格式
java调用服务报错400
java调用服务报错400
137 6
java调用服务报错400
|
5月前
|
JSON Java 数据格式
java调用服务报错415 Content type ‘application/octet-stream‘ not supported
java调用服务报错415 Content type ‘application/octet-stream‘ not supported
340 6
|
8月前
|
分布式计算 搜索推荐 算法
Java 大视界 -- Java 大数据在智慧养老服务需求分析与个性化服务匹配中的应用(186)
本篇文章探讨了Java大数据技术在智慧养老服务需求分析与个性化服务匹配中的应用。通过整合老年人健康数据与行为数据,结合机器学习与推荐算法,实现对老年人健康风险的预测及个性化服务推荐,提升养老服务的智能化与精准化水平,助力智慧养老高质量发展。
|
网络协议 Java Shell
java spring 项目若依框架启动失败,启动不了服务提示端口8080占用escription: Web server failed to start. Port 8080 was already in use. Action: Identify and stop the process that’s listening on port 8080 or configure this application to listen on another port-优雅草卓伊凡解决方案
java spring 项目若依框架启动失败,启动不了服务提示端口8080占用escription: Web server failed to start. Port 8080 was already in use. Action: Identify and stop the process that’s listening on port 8080 or configure this application to listen on another port-优雅草卓伊凡解决方案
898 7
|
监控 JavaScript 数据可视化
建筑施工一体化信息管理平台源码,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
智慧工地云平台是专为建筑施工领域打造的一体化信息管理平台,利用大数据、云计算、物联网等技术,实现施工区域各系统数据汇总与可视化管理。平台涵盖人员、设备、物料、环境等关键因素的实时监控与数据分析,提供远程指挥、决策支持等功能,提升工作效率,促进产业信息化发展。系统由PC端、APP移动端及项目、监管、数据屏三大平台组成,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
535 7
|
NoSQL 前端开发 测试技术
👀探秘微服务:从零开启网关 SSO 服务搭建之旅
单点登录(Single Sign-On,简称SSO)是一种认证机制,它允许用户只需一次登录就可以访问多个应用程序或系统。本文结合网关和SaToken快速搭建可用的Session管理服务。
1310 8
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
778 6
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
399 1