58同城开源web框架 Argo (四)

姜弘新
2023-12-01

58同城开源的轻量级web框架 https://github.com/58code/Argo

 

今天开头说说抽象,面向对象的特点:抽象、继承、多态,好的设计都是基于优秀的抽象,抽象层次越高、越完善,他的扩展性就越好,也越容易理解。好比居家过日子,多多少少需要一些工具,可切割的、可裁剪的,这就是两个interface,于是我们准备了刀和剪子,就是一种实现。再后有了水果刀和切菜刀、园艺剪子和裁衣服剪子,这就是多态。再然对菜进行分类,把荤素分开,准备同样的两把菜刀,一把切荤的一把切素的,就是重载。

中心思想就是以特性为核心,然后一点点的实现,过程中可以对底层不同特性组合使用,但是尽量保持最高抽象级别,以便于……(你懂的)

 

看看ArgoFilter 的 init()方法

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底层应该是面向大型企业架构的一种简单抽象,具体实现到什么程度以后继续深入。
 类似资料: