使用 wsadmin 脚本编制对业务级应用程序配置进行自动化

脚本编制库提供 Jython 脚本编制过程来辅助对环境进行自动化。使用应用程序管理脚本,在环境中安装、卸载、导出、启动、停止和管理业务级应用程序。

关于此任务

脚本库提供了一组过程,可自动执行最常见的应用程序服务器管理功能。 使用 Jython 脚本库的方式有三种。
  • 使用 wsadmin 工具从 Jython 脚本库以交互方式运行脚本。可以启动 wsadmin 工具,并使用以下语法来运行包括在脚本库中的各个脚本:
    wsadmin>AdminServerManagement.createApplicationServer("myNode", "myServer", "default")
  • 使用文本编辑器组合 Jython 脚本库中的若干个脚本,如下例所示:
    #
    # My Custom Jython Script - file.py
    #
    AdminServerManagement.createApplicationServer("myNode", "Server1", "default")
    AdminServerManagement.createApplicationServer("myNode", "Server2", "default")
    
    # Use one of them as the first member of a cluster
    AdminClusterManagement.createClusterWithFirstMember("myCluster", "APPLICATION_SERVER",
        "myNode", "Server1")
    
    # Add a second member to the cluster
    AdminClusterManagement.createClusterMember("myCluster", "myNode", "Server3")
    
    # Install an application
    AdminApplication.installAppWithClusterOption("DefaultApplication",
        "..\installableApps\DefaultApplication.ear", "myCluster") 
    
    # Start all servers and applications on the node
    AdminServerManagement.startAllServers("myNode")
    保存定制脚本并从命令行运行该脚本,如以下语法所示:
    bin>wsadmin -language jython -f path/to/your/jython/file.py
  • 将 Jython 脚本库代码用作样本语法来编写定制脚本。脚本库中的每个脚本示例都演示了编写 wsadmin 脚本的最佳实践。脚本库代码位于 app_server_root/scriptLibraries 目录中。在此目录中,脚本按照功能组织到各个子目录中。例如,app_server_root/scriptLibraries/application/V70 子目录包含执行应用程序管理任务的过程,这些过程可用于产品的 V7.0 和更高版本。脚本库路径中的子目录 V70 并不表示该子目录中的脚本是 V7.0 脚本。
脚本编制库中的业务级应用程序过程位于 app_server_root/scriptLibraries/application/V70 子目录中。当您启动 wsadmin 工具时,会自动从该目录中装入每个脚本。要在启动 wsadmin 工具时自动装入您自己的 Jython 脚本 (*.py),请在 app_server_root/scriptLibraries 目录下创建新的子目录,然后将现有自动化脚本保存到该子目录。
最佳实践 最佳实践: 要使用脚本编制库过程来创建定制脚本编制,请将所修改的脚本编制保存到新的子目录以避免覆盖此库。请不要编辑脚本编制库中的脚本编制过程。bprac

您可以使用 AdminBLA.py 脚本来执行管理功能的多个组合。请参阅《业务级应用程序配置脚本》文档,以查看自变量描述和语法示例。

使用以下步骤和脚本编制库来创建空的业务级应用程序,将资产添加为组合单元,并启动该业务级应用程序。

过程

  1. 启动 wsadmin 工具。
    执行此步骤以启动 wsadmin 工具并连接至服务器,或者在本地方式下运行该工具。如果启动 wsadmin 工具,请使用交互方式示例来运行脚本。
    • 从 bin 目录输入以下命令,以启动 wsadmin 工具并连接至服务器:
      bin>wsadmin -lang jython
    • 从 bin 目录输入以下命令,以在本地方式下使用 Jython 脚本编制语言来启动 wsadmin 工具:
      bin>wsadmin -conntype none -lang jython
    当启动 wsadmin 工具时,系统会从脚本编制库中装入所有脚本编制。
  2. 将资产导入配置。

    资产所代表的应用程序二进制文件包含业务逻辑,该业务逻辑可以在目标运行时环境上运行并服务客户机请求。资产可以包含文件、文件归档(例如 ZIP 或 Java™ 归档 (JAR) 文件)或归档文件的归档(例如 Java Platform, Enterprise Edition (Java EE) EAR 文件)。其他资产示例包括 Enterprise JavaBeans (EJB) JAR 文件、EAR 文件、OSGi 捆绑软件、调解 JAR 文件、共享库 JAR 文件及非 Java EE 内容(例如,PHP 应用程序)。

    运行 AdminBLA 脚本库中的 importAsset 脚本,以将资产导入到应用程序服务器配置库,如以下示例所示:
    bin>wsadmin -lang jython -c "AdminBLA.importAsset("asset.zip", "true", "true")"
    您也可以使用交互方式来运行脚本过程,如以下示例所示:
    wsadmin>AdminBLA.importAsset("asset.zip", "true", "true")
  3. 创建空的业务级应用程序。
    运行 AdminBLA 脚本库中的 createEmptyBLA 脚本,以创建新的业务级应用程序,如以下示例所示:
    bin>wsadmin -lang jython -c "AdminBLA.createEmptyBLA("myBLA", "bla to control transactions")"
    您也可以使用交互方式来运行脚本过程,如以下示例所示:
    wsadmin>AdminBLA.createEmptyBLA("myBLA", "bla to control transactions")
  4. 将资产作为组合单元添加到业务级应用程序。

    组合单元可以代表已部署的资产、其他业务级应用程序或外部工件(已在非 WebSphere Application Server 运行时环境上部署,但无支持资产)。业务级应用程序包含零个或更多的组合单元。无法将同一组合单元添加到多个业务级应用程序,但您可以使用一个资产来创建多个组合单元。

    运行 AdminBLA 脚本库中的 addCompUnit 脚本,以将 asset.zip 作为组合单元添加到 myBLA,如以下示例所示:
    bin>wsadmin -lang jython -c "AdminBLA.addCompUnit("myBLA", "asset.zip", "default",
     "myCompositionUnit", "cu description", "1", "server1", "specname=actplan1")"
    您也可以使用交互方式来运行脚本过程,如以下示例所示:
    wsadmin>AdminBLA.addCompUnit("myBLA", "asset.zip", "default", "myCompositionUnit",
     "cu description", "1", "server1", "specname=actplan1")
  5. 保存配置更改。
    请使用以下命令示例来保存配置更改:
    AdminConfig.save()
  6. 使节点同步。
    使用 AdminNodeManagement 脚本库中的 syncActiveNodes 脚本,对环境中每个处于活动状态的节点进行同步,如以下示例所示:
    wsadmin>AdminNodeManagement.syncActiveNodes()
  7. 启动业务级应用程序。
    使用 AdminBLA 脚本库中的 startBLA 脚本来启动部署目标上业务级应用程序的每个组合单元(已针对部署目标配置这些组合单元),如以下示例所示:
    wsadmin>AdminBLA.startBLA("myBLA")

结果

在相关部署目标上配置并启动了业务级应用程序。

wsadmin 脚本库返回的输出与关联 wsadmin 命令返回的输出相同。例如,AdminServerManagement.listServers() 脚本会返回可用服务器的列表。AdminClusterManagement.checkIfClusterExists() 脚本会返回值 true(如果集群存在)或 false(如果集群不存在)。如果此命令未返回期望的输出,那么当此脚本成功运行时,脚本库会返回值 1。如果此脚本失败,那么脚本库会返回值 -1 及一条包含该异常的错误消息。

缺省情况下,系统会禁用 failonerror 选项。要启用此选项,请指定 true 作为该脚本过程的最后一个自变量,如以下示例所示:
wsadmin>AdminApplication.startApplicationOnCluster("myApplication","myCluster","true")

下一步做什么

使用业务级应用程序配置脚本来创建定制脚本,以对环境进行自动化。将定制脚本保存到 app_server_root/scriptLibraries 目录的新子目录。


指示主题类型的图标 任务主题



时间戳记图标 最近一次更新时间: last_date
http://www14.software.ibm.com/webapp/wsbroker/redirect?version=cord&product=was-nd-mp&topic=txml_7libbla
文件名:txml_7libbla.html