使用 wsadmin 脚本编制对数据访问资源配置进行自动化

脚本编制库提供 Jython 脚本编制过程来辅助对环境进行自动化。使用资源管理脚本来设置和管理 Java™ 数据库连接 (JDBC) 配置。

关于此任务

脚本库提供了一组过程,可自动执行最常见的应用程序服务器管理功能。 使用 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/resources/JDBC/V70 子目录中。 当您启动 wsadmin 工具时,会自动从该目录中装入每个脚本。要在启动 wsadmin 工具时自动装入您自己的 Jython 脚本 (*.py),请将自动化脚本保存到 app_server_root/scriptLibraries 目录中的新子目录。
最佳实践 最佳实践: 要使用脚本编制库过程来创建定制脚本编制,请将所修改的脚本编制保存到新的子目录以避免覆盖此库。请不要编辑脚本编制库中的脚本编制过程。bprac

您可以使用这些脚本来执行管理功能的许多组合。请使用以下过程组合样本来配置 JDBC 提供程序和数据源。

过程

  1. 验证是否已在节点管理器上安装了所有必需的 JDBC 驱动程序文件。如果您选择配置用户定义的 JDBC 提供程序,请查阅数据库文档以了解有关驱动程序文件的信息。
  2. 可选: 启动 wsadmin 工具。
    执行此步骤以启动 wsadmin 工具并连接至服务器,或者在本地方式下运行该工具。如果启动 wsadmin 工具,请使用本主题中的交互方式示例来运行脚本。
    • bin 目录输入以下命令,以启动 wsadmin 工具并连接至服务器:
      bin>wsadmin -lang jython
    • bin 目录输入以下命令,以在本地方式下使用 Jython 脚本编制语言来启动 wsadmin 工具:
      bin>wsadmin -conntype none -lang jython
    当启动 wsadmin 工具时,系统会从脚本编制库中装入所有脚本编制。
  3. 配置 JDBC 提供程序。

    运行脚本库中的 createJDBCProvider 过程,并指定必需自变量。要运行此脚本,请指定节点名、服务器名称、要分配给新 JDBC 提供程序的名称以及实现类名。可选择性地以如下格式指定其他属性:[["attr1", "value1"], ["attr2", "value2"]]。必须在应用程序服务器数据源上设置特定供应商 JDBC 驱动程序的定制属性。有关可用的定制属性的信息,请参阅数据库文档。

    以下示例会在配置中创建 JDBC 提供程序:
    bin>wsadmin -lang jython -c "AdminJDBC.createJDBCProvider("myNode", "myServer", "myJDBCProvider",
     "myImplementationClass", [["description", "testing"], ["xa", "false"], ["providerType", "provType"]])"
    您也可以使用交互方式来运行脚本过程,如以下示例所示:
    wsadmin>AdminJDBC.createJDBCProvider("myNode", "myServer", "myJDBCProvider", "myImplementationClass",
     [["description", "testing"], ["xa", "false"], ["providerType", "provType"]])
    此脚本会返回新 JDBC 提供程序的配置标识。
  4. 使用模板来配置数据源。

    运行脚本库中的 createDataSourceUsingTemplate 过程,并指定必需自变量。要运行此脚本,请指定节点名、服务器名称、JDBC 提供程序名称、要使用的模板的配置标识以及要分配给新数据源的名称。可选择性地以如下格式指定其他属性:[["attr1", "value1"], ["attr2", "value2"]]

    以下示例使用模板在配置中创建数据源:
    bin>wsadmin -lang jython -c "AdminJDBC.createDataSourceUsingTemplate("myNode", "myServer", "myJDBCProvider",
     "Derby JDBC Driver DataSource(templates/system|jdbc-resource-provider-templates.xml#DataSource_derby_1)",
     "myDataSource", [["authDataAlias", "myalias"], ["authMechanismPreference", "BASIC_PASSWORD"],
     ["description", "testing"], ["jndiName", "dsjndi1"], ["logMissingTransactionContext", "true"],
     ["statementCacheSize", "5"]])"
    您也可以使用交互方式来运行脚本过程,如以下示例所示:
    wsadmin>AdminJDBC.createDataSourceUsingTemplate("myNode", "myServer", "myJDBCProvider", "Derby JDBC Driver 
     DataSource(templates/system|jdbc-resource-provider-templates.xml#DataSource_derby_1)", "myDataSource", 
     [["authDataAlias", "myalias"], ["authMechanismPreference", "BASIC_PASSWORD"], ["description", "testing"],
     ["jndiName", "dsjndi1"], ["logMissingTransactionContext", "true"], ["statementCacheSize", "5"]])
    此脚本会返回新数据源的配置标识。

结果

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_7libresource
文件名:txml_7libresource.html