根据配置文件来切换不同服务的实现

在MicroService开发中经常会遇到一个问题,自己的服务需要调用其它小组的服务,但是其他小组的服务还没有完成。为了不耽误进度,我们就需要先实现一个Mock的服务,最后再切换到真正的外部服务上去。同时,一旦外部服务出现问题,为了不阻塞本地开发,我们需要很方便的切换到Mock服务上去。通过修改配置文件里面的内容,可以实现不修改代码来切换不同的服务。

通用服务接口:

public interface OrderAtpChecker {
    /**
     * @param order  order to be checked by ATP
     * @param tenant tenant id for client
     * @return a map whose key is the order line id and value is the validity of its apt check result
     */
    Map<OrderLineId, Boolean> atpCheck(Order order, String tenant);

    String getType();
}

不同的服务实现:

public class MockOrderAtpChecker implements OrderAtpChecker {
    @Override
    public Map<OrderLineId, Boolean> atpCheck(final Order order, final String tenant) {
        if (null == order) {
            throw new IllegalArgumentException("Can‘t atp check a null order.");
        }
        return order.getOrderLines().parallelStream()
                .collect(toMap(OrderLine::getId, o -> o.getQuantity() < 100));
    }

    @Override
    public String getType() {
        return "Mock";
    }
}
public class OrderAtpChecker implements OrderAtpChecker {
    @Override
    public Map<OrderLineId, Boolean> atpCheck(final Order order, final String tenant) {
        ............
    }

    @Override
    public String getType() {
        return "Inventory";
    }
}

Service Factory的实现:

@Service
public class InventoryServiceFactory {
    @Autowired
    private List<OrderAtpChecker> services;

    private static final Map<String, OrderAtpChecker> myServiceCache = new HashMap<>();

    @PostConstruct
    public void initMyServiceCache() {
        for (final OrderAtpChecker service : this.services) {
            myServiceCache.put(service.getType(), service);
        }
    }

    public static OrderAtpChecker getService(final String type) {
        final OrderAtpChecker service = myServiceCache.get(type);
        if (service == null) throw new RuntimeException("Unknown service type: " + type);
        return service;
    }
}

具体调用服务的地方:

@Value("${inventory_service}")
private String serviceType;
private OrderAtpChecker orderAtpChecker;
this.orderAtpChecker = InventoryServiceFactory.getService(this.serviceType);
时间: 2024-10-10 14:49:20

根据配置文件来切换不同服务的实现的相关文章

Zabbix配置文件详解之服务端——zabbix_server

作为zabbix的部署,这里就不说了,网上一大堆文档,但关于配置文件的说明就比较少,这里列出服务端的配置文件zabbix_server的详细解释,感谢我主管的功劳. Zabbix Server端配置文件说明 # This is a configuration file for Zabbix Server process # To get more information about Zabbix, # visit http://www.zabbix.com ############ GENERA

MongoDB 通过配置文件启动及注册服务

1.配置mongodb环境变量,配置完成之后就可以直接执行mong.mongod等常用命令,不用每次都到mongodb安装目录bin下去执行: 2.通过命令启动mongo服务 mongod --dbpath = D:\mongodb\data\db --logpath = D:\mongodb\data\log\mongod.log 3.每次都通过命令去启动mongod太麻烦,那就注册系统服务 mongod --install --dbpath = D:\mongodb\data\db --lo

Oracle 11gR2光钎链路切换crs服务发生crash

Oracle 11gR2光钎链路切换crs服务发生crash 背景: 我们将Oracle 11gR2(11.2.0.4)在RedHat EnterPrise 5.8上通过RDAC完成的多路径链路冗余,在部署完成后,我们需要做多路径链路冗余测试,我们的光钎链路连接方式如下.我们做多路径测试完成了如下几个组合: 拔线测试组合一: 1. 先拔下光钎链路 ②和④ 一切正常没有问题:插上五分钟后执行第2步. 2. 再拔下光钎链路 ①和③ 数据库服务正常,crs进程crash无法访问,手工重启crs进程即可

利用python3.5 构建流媒体后台音视频切换的服务端程序

#!/usr/bin/env python3.5.0 # -*- coding:utf8 -*- import os,sys,socket,hashlib,time,select,threading,configparser import pymssql rootdir =os.path.abspath(sys.argv[0]) rootdir =os.path.dirname(rootdir) +"/" cf =configparser.ConfigParser() if os.pa

0120Keeplived实现自动切换Mysql服务

转自http://biancheng.dnbcw.info/mysql/381020.html Keepalived+mysql 自动切换网络结构:VIP 192.168.88.200mysq11 192.168.88.130 主mysql2 192.168.88.131 备一 mysql 主主同步二 安装keepalived 三 keepalived 主备配置文件四 mysql状态检测脚本/root/keepalived_check_mysql.sh五 防火墙设置 六 启动keepalived

Zabbix配置文件详解之服务端zabbix_server

作为zabbix的部署,这里就不说了,网上一大堆文档,但关于配置文件的说明就比较少,这里列出服务端的配置文件zabbix_server的详细解释,感谢我主管的功劳. Zabbix Server端配置文件说明 # This is a configuration file for Zabbix Server process # To get more information about Zabbix, # visit http://www.zabbix.com ############ GENERA

python根据nagios配置文件将监控的服务联系人等信息导出到excel表格

前阵子,遇到需要把nagios监控的服务统计到表格的需求,想着如果每一次改动,都要去维护表格的话,难免会有疏漏或者问题,于是观察了nagios的host.cfg,services.cfg等配置文件写了一个脚本,包含对多个主机关联到同一个服务的处理等,脚本也有局限性,就是需要把每个主机,都归类到某个组,比如Linux主机归类到Linux组,实际环境,一般也是有这样做归类的,脚本运行过程中会有文件产生,但都很小,以下是相应模块安装和脚本文件,建议在测试机上面跑完再到实际环境跑. 一,安装xlsxwr

keepalived+nginx配置文件及检查nginx服务的脚本

原地址:http://www.cnblogs.com/fansik/p/6248684.html 脚本一启动的速度要快一些哦,因为脚本二要判断两次以后才启动哎 这两个一般配合keepalived使用 脚本一: #!/bin/bash #author:fansik #description:check nginx service run=`ps -C nginx --no-header | wc -l` if [ $run -eq 0 ] then /etc/rc.d/init.d/nginx s

spring 数据源动态切换 与dubbo服务

1:问题描述 项目用了spring数据源动态切换,服务用的是dubbo.在运行一段时间后程序异常,更新操作没有切换到主库上.这个问题在先调用读操作后再调用写操作会出现.经分析原因有3: 第一:当程序运行一段时间后调用duboo服务时,读操作与写操作有可能会在一个线程里,当这种情况出现时 2:数据源配置 <idclass>    <name>       <key-type>          <keyvalue-ref/>          <keyv