コード例 #1
0
def add_or_update(conf, api, hosts):
    cl = _add(conf, api, hosts)

    # Add services
    for svc in conf['cluster']['services']:
        service.add_or_update(svc, cl, hosts, False)
        restart(cl, True)
        service.start(svc, cl)
コード例 #2
0
ファイル: cluster.py プロジェクト: elisska/provisionator
def add_or_update(conf, api, hosts):
    cl = _add(conf, api, hosts)

    # Add services
    for svc in conf['cluster']['services']:
        service.add_or_update(svc, cl, hosts, False)
        restart(cl, True)
        service.start(svc, cl)
コード例 #3
0
  if len(sys.argv) < 2:
    logging.fatal("No configuration file specified")
    sys.exit(-1)

  config = config.read_config(sys.argv[1])

  try:
    # Open a connection to CM and get a CM object
    api = util.get_api_handle(config)
    host_id_map = util.host_id_map(config, api)
    cm = api.get_cloudera_manager()

    # Update CM config
    if 'config' in config['cm']:
      cm.update_config(config['cm']['config'])

    # Create Cloudera Management Services
    mgmt.create(config, cm, host_id_map)
    mgmt.start(cm)

    # Add cluster
    cl = cluster.add(config, api, host_id_map)

    # Add services
    for svc in config['cluster']['services']:
      service.add_or_update(svc, cl, host_id_map)
      # service.start(svc, cl)

  except ApiException, e:
    logging.error("Error: %s" % e)