generate_config.py 2.4 KB
Newer Older
R
Rongfeng Fu 已提交
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 48
# 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


def generate_config(plugin_context, deploy_config, *args, **kwargs):
    cluster_config = plugin_context.cluster_config
    clients = plugin_context.clients
    stdio = plugin_context.stdio
    success = True
    have_depend = False
    depends = ['oceanbase', 'oceanbase-ce']
    server_depends = {}
    stdio.start_loading('Generate obagent configuration')

    for server in cluster_config.servers:
        server_depends[server] = []
        server_config = cluster_config.get_server_conf(server)
        if not server_config.get('home_path'):
            stdio.error("obagent %s: missing configuration 'home_path' in configuration file" % server)
            success = False
            continue
    if not success:
        stdio.stop_loading('fail')
        return

    for comp in cluster_config.depends:
        if comp in depends:
            have_depend = True
            for server in cluster_config.servers:
R
Rongfeng Fu 已提交
49
                obs_config = cluster_config.get_depend_config(comp, server)
R
Rongfeng Fu 已提交
50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
                if obs_config is not None:
                    server_depends[server].append(comp)
    
    if have_depend:
        server_num = len(cluster_config.servers)
        for server in cluster_config.servers:
            for comp in depends:
                if comp in server_depends[server]:
                    break
            else:
                cluster_config.update_server_conf(server, 'ob_monitor_status', 'inactive', False)
    else:
        cluster_config.update_global_conf('ob_monitor_status', 'inactive', False)

    stdio.stop_loading('succeed')
    plugin_context.return_true()