使用Jython重新启动WebSphere AppCluster

问题描述 投票:0回答:1

我想使用Jython在WebSphere 8.5中重新启动AppCluster。

  cluster = AdminControl.completeObjectName('name=ICXTCluster,*')
  AdminControl.invoke(cluster, 'restart')

这不起作用:

无法在ModelMBeanInfo中重新启动操作

所以我尝试通过停止然后启动集群来手动实现重新启动:

  cluster = AdminControl.completeObjectName('name=ICXTCluster,*')
  AdminControl.invoke(cluster, 'stop')
  AdminControl.invoke(cluster, 'start')

它引发另一个错误:

com.ibm.websphere.wlm.exception.ClusterException:启动操作失败,因为另一个管理操作:Stop已经在进行中。

停止似乎有效,ISC向我显示AppCluster已停止。但这并没有再次开始。我假设那些调用操作是异步的,所以AdminControl.invoke(cluster, 'start')在上一个停止完成之前就已执行。

如何停止集群同步?还是有另一种方法可以重新启动它?

websphere jython ibm-connections
1个回答
0
投票

由于内置的​​Jython命令似乎无法实现,因此我编写了一个脚本,该脚本每5秒轮询一次集群状态,并检查其是否等于所需的状态。因此,我们可以使用异步功能,并通过等待服务器停止和启动来使它们同步:

import time
def set_state_sync(invoke_state, target_state):
    print 'Check state for ' + cluster_name
    cluster = AdminControl.completeObjectName('name=' + cluster_name + ',*')
    state = AdminControl.getAttribute(cluster, 'state')
    print 'Initial state: ' + state
    if state == target_state:
        print 'State is already ' + target_state
        return

    print '[Changed]: Invoke state ' + invoke_state
    AdminControl.invoke(cluster, invoke_state)

    max_wait = 300
    interval = 5
    waited = 0
    while state != target_state:
        time.sleep(interval)
        state = AdminControl.getAttribute(cluster, 'state')
        print 'State poll: ' + state
        waited += interval
        if waited > max_wait:
            print 'Error: Timed out after ' + max_wait + ' seconds!'
            exit()
    return

cluster_name = '{{ cluster_name }}'
set_state_sync('stop', 'websphere.cluster.stopped')
set_state_sync('start', 'websphere.cluster.running')
print 'Finished Restarting'
© www.soinside.com 2019 - 2024. All rights reserved.