本文主要是介绍(MSOA)微型面向服务的架构的设计与实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
设计目的:
1、系统按照功能或者业务逻辑层次划分服务,系统架构清晰、灵活;
2、提供服务自动注册;
3、服务调用简单,服务之间的调用可以通过getXXXService()直接获得;
4、服务统一管理;
5、服务可监控;
一、Service 接口
Service接口提供了一个自动注册的机制。实现了registe()方法来完成服务的注册。
public interface Service {public void registe();
}
二、AbstractService抽象类
AbstractService抽象类实现了一个registe(String,Object)的方法,通过ServiceManager完成服务的注册。
ServiceManager负责保存所有服务。同时提供服务的注册和获取服务,是服务注册和获取的唯一通道。
在AbstractService中调用了registe()无参数的方法,这是个在Service中定义,在AbstractService没有实现的方法。
要求继承AbstractService的子类实现并调用registe(String,Object)方法实现自身的注册。
public abstract class AbstractService implements Service {public AbstractService() {registe();}protected void registe(String serviceName, Object service) {ServiceManager.registe(serviceName, service);}public Object getService(String serviceName) {return ServiceManager.getService(serviceName);}
}
三、举例 UserService
UserService继承了AbstractServcie,由于AbstractServcie没有实现registe()方法,要求UserService实现。
UserService实现 registe()方法,并在方法中调用 AbstractServcie提供的registe(String,Object)方法,传入当前服务的serviceName和this完成注册。
继承了AbstractServcie的子类可以直接通过getService(String serviceName)获得所需要的任何服务。
public abstract class AbstractService implements Service {public AbstractService() {registe();}protected void registe(String serviceName, Object service) {ServiceManager.registe(serviceName, service);}public Object getService(String serviceName) {return ServiceManager.getService(serviceName);}
}
四、ServiceManager
用于保存service,提供注册和获取服务方法。同时还提供服务监控的机制。
ServiceManager也是所有服务调用的Facade 门面,是 Facade模式的应用。
public final class ServiceManager {private static Map<String, Object> services = new HashMap<String, Object>();private static ServiceMonitor serviceMonitor = null;/*** serviceMonitor 可以管理 services 变量* * @return*/public static ServiceMonitor getServiceMonitor() {if (serviceMonitor == null) {serviceMonitor = new ServiceMonitor(services);}return serviceMonitor;}/*** 注册service到 serviceManager。* * 此方法由 AbstractService类使用,AbstractService的子类需要实现registe()* 方法并在方法中调用AbstractService的registe(String serviceName, Object service)方法。* * 将子类注册到当前 ServiceManager 中。* * @param serviceName* 形如: ServiceManager.class.getName()* @param service*/public static void registe(String serviceName, Object service) {services.put(serviceName, service);}/*** 通过service名字获取 service,此方法由 AbstractService 类使用。* * @param serviceName* 形如: ServiceManager.class.getName()* @return*/public static Object getService(String serviceName) {Object service = services.get(serviceName);if (service == null) {try {Class<?> serviceClass = Class.forName(serviceName);service = serviceClass.newInstance();} catch (ClassNotFoundException e) {e.printStackTrace();} catch (InstantiationException e) {e.printStackTrace();} catch (IllegalAccessException e) {e.printStackTrace();}}return service;}}
五、ServiceMonitor
由于 ServiceManager中的services是私有变量,并且ServiceManager只负责服务的保存、注册和获取,因此提供ServiceMonitor对 services变量实现操作(监控)。
public class ServiceMonitor {private Map<String, Object> services = null;public ServiceMonitor(Map<String, Object> monitedServices) {this.services = monitedServices;}public int getServiceCount() {return this.services.size();}
}
这篇关于(MSOA)微型面向服务的架构的设计与实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!