Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/python-2.7/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 2.7 如何在Openstack中捕获堆栈状态_Python 2.7_Automation_Openstack - Fatal编程技术网

Python 2.7 如何在Openstack中捕获堆栈状态

Python 2.7 如何在Openstack中捕获堆栈状态,python-2.7,automation,openstack,Python 2.7,Automation,Openstack,我有以下情况 1.堆栈创建 2.堆栈更新 3.堆栈创建 我想做的是,在触发stackCreate/Update/Delete时,我需要检查进度。我该怎么做?我知道两种方法 1.openstack堆栈事件列表。 2.我有下面的python代码 stack_id = str(hc.stacks.get(stack_name).id) hc.stacks.delete(stack_id=stack_id) try:

我有以下情况 1.堆栈创建 2.堆栈更新 3.堆栈创建

我想做的是,在触发stackCreate/Update/Delete时,我需要检查进度。我该怎么做?我知道两种方法 1.openstack堆栈事件列表。 2.我有下面的python代码

    stack_id = str(hc.stacks.get(stack_name).id)
                    hc.stacks.delete(stack_id=stack_id)
                    try:
                        evntsdata = hc.events.list(stack_name)[0].to_dict()
                        event_handle = evntsdata['resource_status']
                        if event_handle == 'DELETE_IN_PROGRESS':
                            loopcontinue = True
                            while loopcontinue:
                                evntsdata = hc.events.list(stack_name)[0].to_dict()
                                event_handle = evntsdata['resource_status']

                                if event_handle == 'DELETE_COMPLETE':
                                    loopcontinue = False
                                    print(str(timestamp()) + " " + "Delete is Completed!")
                                elif event_handle == 'DELETE_FAILED':
                                    print("Failed")  # this needs a proper error msg
                                    sys.exit(0)
                                else:
                                    print(str(timestamp()) + " " + "Delete in Progress!")
                                    time.sleep(5)
                        elif event_handle == 'DELETE_COMPLETE':
                            print(str(timestamp()) + " " + "Delete is Completed!")
                            sys.exit(0)
                        elif event_handle == 'DELETE_FAILED':
                            print("Failed")
                            sys.exit(0)
                    except AttributeError as e:
                        print(str(timestamp()) + " " + "ERROR: Stack Delete Failure")
                        raise
                except (RuntimeError, heatclient.exc.NotFound):
                    print("Stack doesnt exist:", stack_name)
第一种方法是shell命令,我不太擅长。(或者说我不知道如何在python中最好地集成shell命令)
这两种方法的问题是,我要用这些步骤来确定堆栈删除是否成功。对于stackupdate和create,我也在重复同样的方法,我认为这不是最佳实践。有人知道我该如何最小化这个逻辑吗?非常感谢您的帮助

您可以编写简单的函数来创建/更新/删除堆栈,还可以检查堆栈的状态

请检查下面的示例代码以创建堆栈并轮询堆栈的状态

from keystoneauth1 import loading
from keystoneauth1 import session
from heatclient import client


tenant_id = 'ab3fd9ca29e149acb25161ec8053da9c'
heat_url = 'http://10.26.12.31:8004/v1/%s' % tenant_id
auth_token = 'gAAAAABZYxfjz88XNXnfoCPkNLVeVtqtJ9o8qEtgFhI2GJ-ewSCuiypdwt3K5evgQeICVRqMa2jXgzVlENAUB19ZNyQfVCxSX4_lMBKyChM76SGuQUP8U-xJ9EKIfFaVwRGBkk4Ow9OO-iNINfMs0B5-LzJvxTFybi8yZw4EiagQpNpfu1onYfc'
heat = client.Client('1', endpoint=heat_url, token=auth_token)


def create_stack(stack_file_path, stack_name, parameters=None):
    template = open(stack_file_path)
    if parameters:
        stack = heat.stacks.create(stack_name=stack_name, template=template.read(), parameters=parameters)
    else:
        stack = heat.stacks.create(stack_name=stack_name, template=template.read())
    template.close()
    return stack


def get_stack_status(stack_id):
    stack = heat.stacks.get(stack_id)
    return stack.stack_status


def poll_stack_status(stack_id, poll_time=5):
    stack_status = get_stack_status(stack_id)
    while stack_status != 'CREATE_COMPLETE':
        if stack_status == 'CREATE_FAILED':
            return 1
        time.sleep(poll_time)
        stack_status = get_stack_status(stack_id)
    return 0    

我现在在下面工作。这不是我认为最好的,但满足了我需要做的

def stackStatus(status):
    evntsdata = hc.events.list(stack_name)[0].to_dict()
    event_handle = evntsdata['resource_status'].split("_")
    event_handle = '_'.join(event_handle[1:])
    if event_handle == 'IN_PROGRESS':
        loopcontinue = True
        while loopcontinue:
            evntsdata = hc.events.list(stack_name)[0].to_dict()
            event_handle = evntsdata['resource_status'].split("_")
            event_handle = '_'.join(event_handle[1:])
            if event_handle == 'COMPLETE':
                loopcontinue = False
                print(str(timestamp()) + status + " IS COMPLETED!")
            elif event_handle == 'FAILED':
                print("Failed")
                exit(1)
            else:
                print(str(timestamp()) + status + " IN PROGRESS!")
                time.sleep(5)
调用这个函数

stackStatus("DELETE")
stackStatus("CREATE")
stackStatus("UPDATE")

我仍然觉得这很冗长。我正在考虑循环检查输出([“openstack”、“stack”、“event”、“list”、“stack\u name]),您可以使用“openstack stack show-f value-c stack\u status”,这仍然不好,因为它没有循环通过不断变化的状态。您想知道哪个状态?如果只是堆栈的状态,那么这就足够了。来自openstack堆栈事件列表的状态。我继续循环,除非得到“完成”或“失败”的结果