示例#1
0
    def __init__(self, dbname, fullName, indexPrefix="", parentLogger=None):
        """c'tor

        :param self: self reference
        :param str dbName: DIRAC name of the database for example: 'MonitoringDB'
        :param str fullName: The DIRAC full name of the database for example: 'Monitoring/MonitoringDB'
        :param str indexPrefix: it is the indexPrefix used to load all indexes
        :param parentLogger: logger to use as parentLogger
        """
        self.fullname = fullName

        result = getElasticDBParameters(fullName)
        if not result["OK"]:
            raise RuntimeError("Cannot get database parameters: %s" %
                               result["Message"])

        dbParameters = result["Value"]
        self._dbHost = dbParameters["Host"]
        self._dbPort = dbParameters["Port"]
        # we can have db which does not have any authentication...
        self.__user = dbParameters.get("User", "")
        self.__dbPassword = dbParameters.get("Password", "")
        self.__useSSL = dbParameters.get("SSL", True)
        self.__useCRT = dbParameters.get("CRT", True)
        self.__ca_certs = dbParameters.get("ca_certs", None)
        self.__client_key = dbParameters.get("client_key", None)
        self.__client_cert = dbParameters.get("client_cert", None)

        super(ElasticDB, self).__init__(
            host=self._dbHost,
            port=self._dbPort,
            user=self.__user,
            password=self.__dbPassword,
            indexPrefix=indexPrefix,
            useSSL=self.__useSSL,
            useCRT=self.__useCRT,
            ca_certs=self.__ca_certs,
            client_key=self.__client_key,
            client_cert=self.__client_cert,
            parentLogger=parentLogger,
        )

        if not self._connected:
            raise RuntimeError("Can not connect to ES cluster %s, exiting..." %
                               self.clusterName)

        self.log.info("================= ElasticSearch ==================")
        self.log.info("Host: %s " % self._dbHost)
        if self._dbPort:
            self.log.info("Port: %d " % self._dbPort)
        else:
            self.log.info(
                "Port: Not specified, assuming URL points to right location")
        self.log.info("Connecting with %s, %s:%s" % (
            "SSL" if self.__useSSL else "no SSL",
            self.__user if self.__user else "no user",
            "with password" if self.__dbPassword else "no password",
        ))
        self.log.info("ClusterName: %s   " % self.clusterName)
        self.log.info("==================================================")
示例#2
0
  def __init__(self, dbname, fullName, indexPrefix=''):
    """ c'tor

    :param self: self reference
    :param str dbName: DIRAC name of the database for example: 'MonitoringDB'
    :param str fullName: The DIRAC full name of the database for example: 'Monitoring/MonitoringDB'
    :param str indexPrefix: it is the indexPrefix used to load all indexes
    """
    self.fullname = fullName

    result = getElasticDBParameters(fullName)
    if not result['OK']:
      raise RuntimeError('Cannot get database parameters: %s' % result['Message'])

    dbParameters = result['Value']
    self._dbHost = dbParameters['Host']
    self._dbPort = dbParameters['Port']
    # we can have db which does not have any authentication...
    self.__user = dbParameters.get('User', '')
    self.__dbPassword = dbParameters.get('Password', '')
    self.__useSSL = dbParameters.get('SSL', True)
    self.__useCRT = dbParameters.get('CRT', True)
    self.__ca_certs = dbParameters.get('ca_certs', None)
    self.__client_key = dbParameters.get('client_key', None)
    self.__client_cert = dbParameters.get('client_cert', None)

    super(ElasticDB, self).__init__(host=self._dbHost,
                                    port=self._dbPort,
                                    user=self.__user,
                                    password=self.__dbPassword,
                                    indexPrefix=indexPrefix,
                                    useSSL=self.__useSSL,
                                    useCRT=self.__useCRT,
                                    ca_certs=self.__ca_certs,
                                    client_key=self.__client_key,
                                    client_cert=self.__client_cert)

    if not self._connected:
      raise RuntimeError('Can not connect to ES cluster %s, exiting...' % self.clusterName)

    self.log.info("================= ElasticSearch ==================")
    self.log.info("Host: %s " % self._dbHost)
    if self._dbPort:
      self.log.info("Port: %d " % self._dbPort)
    else:
      self.log.info("Port: Not specified, assuming URL points to right location")
    self.log.info("Connecting with %s, %s:%s" % ('SSL' if self.__useSSL else 'no SSL',
                                                 self.__user if self.__user else 'no user',
                                                 'with password' if self.__dbPassword else 'no password'))
    self.log.info("ClusterName: %s   " % self.clusterName)
    self.log.info("==================================================")
示例#3
0
    def __init__(self, dbname, fullName, indexPrefix=''):
        """ c'tor

    :param self: self reference
    :param str dbName: name of the database for example: MonitoringDB
    :param str fullName: The full name of the database for example: 'Monitoring/MonitoringDB'
    :param str indexPrefix: it is the indexPrefix used to get all indexes
    """

        database_name = dbname
        self.log = gLogger.getSubLogger(database_name)

        result = getElasticDBParameters(fullName)
        if not result['OK']:
            raise RuntimeError('Cannot get database parameters: %s' %
                               result['Message'])

        dbParameters = result['Value']
        self.__dbHost = dbParameters['Host']
        self.__dbPort = dbParameters['Port']
        # we can have db which does not have any authentication...
        self.__user = dbParameters.get('User', '')
        self.__dbPassword = dbParameters.get('Password', '')
        self.__useSSL = dbParameters.get('SSL', True)

        super(ElasticDB, self).__init__(self.__dbHost,
                                        self.__dbPort,
                                        self.__user,
                                        self.__dbPassword,
                                        indexPrefix,
                                        useSSL=self.__useSSL)
        if not self._connected:
            raise RuntimeError('Can not connect to DB %s, exiting...' %
                               self.clusterName)

        self.log.info("==================================================")
        self.log.info("Host: %s " % self.__dbHost)
        self.log.info("Port: %d " % self.__dbPort)
        self.log.info(
            "Connecting with %s, %s:%s" %
            ('SSL' if self.__useSSL else 'no SSL',
             self.__user if self.__user else 'no user',
             'with password' if self.__dbPassword else 'no password'))
        self.log.info("ClusterName: %s   " % self.clusterName)
        self.log.info("==================================================")
示例#4
0
  def __init__( self, dbname, fullName, indexPrefix = '' ):
    """ c'tor

    :param self: self reference
    :param str dbName: name of the database for example: MonitoringDB
    :param str fullName: The full name of the database for example: 'Monitoring/MonitoringDB'
    :param str indexPrefix it is the indexPrefix used to get all indexes
    """

    database_name = dbname
    self.log = gLogger.getSubLogger( database_name )

    result = getElasticDBParameters( fullName )
    if not result['OK'] :
      raise RuntimeError( 'Cannot get database parameters: %s' % result['Message'] )

    dbParameters = result[ 'Value' ]
    self.__dbHost = dbParameters[ 'Host' ]
    self.__dbPort = dbParameters[ 'Port' ]
    #we can have db which does not have any authentication...
    self.__user = ''
    if 'User' in dbParameters:
      self.__user = dbParameters[ 'User' ]
    self.__dbPassword = ''
    if 'Password' in dbParameters:
      self.__dbPassword = dbParameters[ 'Password' ]

    super( ElasticDB, self ).__init__( self.__dbHost, self.__dbPort, self.__user, self.__dbPassword, indexPrefix )

    if not self._connected:
      raise RuntimeError( 'Can not connect to DB %s, exiting...' % self.clusterName )


    self.log.info( "==================================================" )
    self.log.info( "Host:           " + self.__dbHost )
    self.log.info( "Port:           " + str( self.__dbPort ) )
    self.log.info( "ClusterName:    " + self.clusterName )
    self.log.info( "==================================================" )