58同城开源的轻量级web框架 monospace; font-size: 12px; line-height: 1.5;">https://github.com/58code/Argo
?
今天开头说说抽象,面向对象的特点:抽象、继承、多态,好的设计都是基于优秀的抽象,抽象层次越高、越完善,他的扩展性就越好,也越容易理解。好比居家过日子,多多少少需要一些工具,可切割的、可裁剪的,这就是两个interface,于是我们准备了刀和剪子,就是一种实现。再后有了水果刀和切菜刀、园艺剪子和裁衣服剪子,这就是多态。再然对菜进行分类,把荤素分开,准备同样的两把菜刀,一把切荤的一把切素的,就是重载。
中心思想就是以特性为核心,然后一点点的实现,过程中可以对底层不同特性组合使用,但是尽量保持最高抽象级别,以便于……(你懂的)
?
看看ArgoFilter?的 init()方法
class="java">public void init(FilterConfig filterConfig) throws ServletException { ServletContext servletContext = filterConfig.getServletContext(); try { dispatcher = ArgoDispatcherFactory.create(servletContext); dispatcher.init(); } catch (Exception e) { servletContext.log("failed to argo initialize, system exit!!!", e); System.exit(1); } }
ArgoDispatcherFactory.create(servletContext) 进入之后看到简单的两行代码
1. GroupConvention groupConvention = GroupConventionFactory.getGroupConvention();
这句话是获取了一个默认的约定配置。Argo的配置分为组织级和项目级,组织级包括配置文件路径configFolder(),日志文件路径logFolder(),组织级Guice的注入Module module(),项目级包括项目ID? id(),所有的controller类 controllerClasses(),项目级Guice的注入Module module()。?
?
2.Argo.instance.init(servletContext, groupConvention);
这里对全局的Argo进行初始化。instance应该是一个静态实例,Argo不是用Guice么,怎么还能看见new,这种强引用的初始化方法暴露出来,难道不怕重复加载导致错误么。再去看看这个init方法。里面的onlyOnce.check();可以保证只进行一次初始化,看来是自己写的一个工具类了。
?
List<Module> modules = Lists.newArrayList(); modules.add(new ArgoModule(this)); Module groupModule = groupConvention.group().module(); if (null != groupModule) modules.add(groupModule); Module projectModule = groupConvention.currentProject().module(); if (null != projectModule) modules.add(projectModule);看到了吧,秘密在这里,Argo本身用的Module是ArgoModule,此外还允许开发者定义自己的Module,组织级和项目级分得很明确,就是SOA的基石,统一由Argo的Guice来管理调度。(有远见!)
?
?
this.argoDispatcher = getInstance(ArgoDispatcher.class); return argoDispatcher;init()方法返回ArgoDispatcher,ArgoDispatcher绑定的实现是com.bj58.argo.internal.DefaultArgoDispatcher,Argo用于处理请求的调度中心。看得出他的service方法 ??public void service(HttpServletRequest request, HttpServletResponse response) 就是处理方法了。 这次看到这里,可以知道Argo底层应该是面向大型企业架构的一种简单抽象,具体实现到什么程度以后继续深入。