recover.py 1.9 KB
Newer Older
F
v1.6.0  
frf12 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
# coding: utf-8
# OceanBase Deploy.
# Copyright (C) 2021 OceanBase
#
# This file is part of OceanBase Deploy.
#
# OceanBase Deploy is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# OceanBase Deploy is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with OceanBase Deploy.  If not, see <https://www.gnu.org/licenses/>.


from __future__ import absolute_import, division, print_function

from ssh import LocalClient


def recover(plugin_context, optimize_config, ob_cursor, odp_cursor, optimize_envs=None, *args, **kwargs):
    stdio = plugin_context.stdio
    client = LocalClient
    if optimize_envs is None:
        optimize_envs = {}
    stdio.start_loading("Recover")
    optimize_config.set_envs(optimize_envs)
    optimize_envs['optimize_entrances_done'] = optimize_envs.get('optimize_entrances_done', {})
    restart_components = []
    for component, entrances in optimize_envs['optimize_entrances_done'].items():
        if component in ['oceanbase', 'oceanbase-ce']:
            cursor = ob_cursor
        elif component in ['obproxy', 'obproxy-ce']:
            cursor = odp_cursor
        else:
            raise Exception('Invalid component {}'.format(component))
        for entrance in entrances[::-1]:
            entrance.recover(cursor=cursor, client=client, stdio=stdio)
            if entrance.need_restart:
                restart_components.append(component)
    stdio.stop_loading("succeed")
    return plugin_context.return_true(restart_components=restart_components)