前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Glassfish 启动流程

Glassfish 启动流程

作者头像
mazhen
发布2023-11-24 16:51:43
1970
发布2023-11-24 16:51:43
举报
文章被收录于专栏:mazhen.techmazhen.tech

asadminGlassFish 的命令行工具,它提供了一系列子命令,使用 asadmin 可以让你完成 Glassfish 的所有管理任务。

使用 asadmin 的子命令 start-domain 可以启动 GlassFish。下面将描述 GlassFish启动过程的主要流程。先从 asadmin 命令的执行开始。

asadmin 执行流程

asadmin 命令的入口是 org.glassfish.admin.cli.AsadminMain, 包含在 ${AS_INSTALL_LIB}/client/appserver-cli.jar包中。

AsadminMain 执行的主要流程如下:

AsadminMain
AsadminMain

其中的一些关键点:

  • 调用CLICommand.getCommand()获得启动服务器的子命令。asadmin 的所有子命令的都继承自com.sun.enterprise.admin.cli.CLICommand ,从下列目录或 Jar 中加载:
    • ${com.sun.aas.installRoot}/lib/asadmin
    • ${com.sun.aas.installRoot}/modules/admin-cli.jar
  • 所有子命令的执行都是调用CLICommand.execute(String... argv)
  • 启动 GlassFish 的子命令实现类为StartDomainCommand,内部调用 GFLauncher.launch()启动服务器。
  • 最终 GFLauncher 使用 ProcessBuilder 启动一个新的进程,就是 GlassFish 的主进程。这个新进程的入口是com.sun.enterprise.glassfish.bootstrap.ASMain

另外,如果设置了 verbosewatchdog 参数,作为父进程的asadmin 不会退出,一直等到 GlassFish 运行结束:

代码语言:javascript
复制
// If verbose, hang around until the domain stops
if (getInfo().isVerboseOrWatchdog()) {
    wait(glassFishProcess);
}

下面分析 GlassFish 主进程的启动流程。

主进程启动流程

GlassFish 主进程的入口是 com.sun.enterprise.glassfish.bootstrap.ASMainmain方法,启动过程的主要流程如下:

glassfish startup
glassfish startup

启动过程比较复杂,但主要步骤很清晰:

  1. 使用 RuntimeBuilder 创建 GlassFishRuntime
  2. 使用 GlassFishRuntime 创建 GlassFish 实例
  3. 调用 GlassFish.start() 启动 Glassfish 实例

创建 GlassFishRuntime

创建 GlassFishRuntime 的主要步骤包括:

  1. 创建 RuntimeBuilder
  2. 创建并初始化 OSGi Framework
  3. 加载 OSGi bundles
  4. 启动 OSGi Framework
  5. 启动 bundles 中的 BundleActivator
  6. HK2Main 的启动过程中查找并注册 HK2 modules

在创建 GlassFishRuntime的过程中,OSGiGlassFishRuntimeBuilder 会创建并初始化 OSGi Framework ,然后使用 BundleProvisionerinstallBundles() 方法向 OSGi 安装 GlassFish 的所有 bundles。

BundleProvisioner从哪里找到要加载的 bundles?config/osgi.properties 文件中的 glassfish.osgi.auto.install 属性定义了 OSGi bundles 的加载路径。BundleProvisioner.discoverJars() 方法会扫描这些路径,发现需要加载的 Jar 包。

在完成 bundles 的加载后,OSGiGlassFishRuntimeBuilder会调用 Framework.start() 启动 OSGi Framework。 Framework 的启动过程中,bundles 中的 BundleActivator 会被启动。其中两个重要的 BundleActivator 是:

GlassFishMainActivator 启动过程中会向 OSGi 中注册 EmbeddedOSGiGlassFishRuntime

HK2Main 会创建 ModulesRegistryModulesRegistry 是 HK2 的关键组件,HK2 中的 modules 都注册在这里。在 OSGi 环境下,ModulesRegistry 的具体实现类是 OSGiModulesRegistryImpl,它会从所有 bundle Jar 的 META-INF/hk2-locator 目录中查找并注册该 bundle 包含的 HK2 modules。

ModulesRegistryHK2Main 都会注册为 OSGi 的 service。

创建 GlassFish 实例

通过GlassFishRuntime.newGlassFish() 创建出 GlassFish 实例,这个过程主要做了两件事:

  1. 创建出 HK2 的 ServiceLocator
  2. ServiceLocator 获取 ModuleStartup

EmbeddedOSGiGlassFishRuntime 中使用 ModulesRegistry.newServiceLocator() 创建出 ServiceLocator,然后从 ServiceLocator 获取 ModuleStartup。在 GlassFish 启动场景获取的是 ModuleStartup 的一个具体实现 AppServerStartup

ServiceLocator 是 HK2 service 的注册表,它提供了一系列获取 HK2 service 的方法。

HK2 Module 和 Service 的关系可以看作是容器和内容的关系。Module(容器)包含了一组 Service(内容),并且负责将这些 Service 注册到 ServiceLocator 中。当一个 Module 被初始化时,它的所有 Service 都会被注册到 ServiceLocator 中,然后这些 Service 就可以被其他 Service 查找和使用。

最后将 AppServerStartupServiceLocator 作为构造函数的参数,创建出 GlassFish 实例。

启动 Glassfish 实例

使用 GlassFish.start() 启动 Glassfish 实例。其中最关键的步骤是调用 AppServerStartup.start(),分级启动 HK2 的 service。HK2 的 service 可以指定启动级别,级别越低,越先启动。

AppServerStartup.start() 运行完成,所有 service 启动,Glassfish 完成启动并运行。

本文参与?腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-07-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客?前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • asadmin 执行流程
  • 主进程启动流程
    • 创建 GlassFishRuntime
      • 创建 GlassFish 实例
        • 启动 Glassfish 实例
        相关产品与服务
        容器服务
        腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
        http://www.vxiaotou.com