Example #1
0
    def record_metering_data(self, data):
        """Write the data to the backend storage system.

        :param data: a dictionary such as returned by
          report.meter.meter_message_from_counter
        """
        with self.conn_pool.connection() as conn:
            resource_table = conn.table(self.RESOURCE_TABLE)
            meter_table = conn.table(self.METER_TABLE)

            resource_metadata = data.get('resource_metadata', {})
            # Determine the name of new meter
            rts = hbase_utils.timestamp(data['timestamp'])
            new_meter = hbase_utils.prepare_key(rts, data['source'],
                                                data['counter_name'],
                                                data['counter_type'],
                                                data['counter_unit'])

            # TODO(nprivalova): try not to store resource_id
            resource = hbase_utils.serialize_entry(
                **{
                    'source': data['source'],
                    'meter': {
                        new_meter: data['timestamp']
                    },
                    'resource_metadata': resource_metadata,
                    'resource_id': data['resource_id'],
                    'project_id': data['project_id'],
                    'user_id': data['user_id']
                })
            # Here we put entry in HBase with our own timestamp. This is needed
            # when samples arrive out-of-order
            # If we use timestamp=data['timestamp'] the newest data will be
            # automatically 'on the top'. It is needed to keep metadata
            # up-to-date: metadata from newest samples is considered as actual.
            ts = int(time.mktime(data['timestamp'].timetuple()) * 1000)
            resource_table.put(hbase_utils.encode_unicode(data['resource_id']),
                               resource, ts)

            # Rowkey consists of reversed timestamp, meter and a
            # message uuid for purposes of uniqueness
            row = hbase_utils.prepare_key(data['counter_name'], rts,
                                          data['message_id'])
            record = hbase_utils.serialize_entry(
                data, **{
                    'source': data['source'],
                    'rts': rts,
                    'message': data,
                    'recorded_at': timeutils.utcnow()
                })
            meter_table.put(row, record)
Example #2
0
def migrate_resource_table(conn, table):
    """Migrate table 'resource' in HBase.

    Change qualifiers format from "%s+%s+%s!%s!%s" %
    (rts, source, counter_name, counter_type,counter_unit)
    in columns with meters f:m_*
    to new separator format "%s:%s:%s:%s:%s" %
    (rts, source, counter_name, counter_type,counter_unit)
    """
    resource_table = conn.table(table)
    resource_filter = ("QualifierFilter(=, "
                       "'regexstring:m_\\d{19}\\+"
                       "[\\w-\\._]*\\+[\\w-\\._!]')")
    gen = resource_table.scan(filter=resource_filter)
    for row, data in gen:
        columns = []
        updated_columns = dict()
        column_prefix = "f:"
        for column, value in data.items():
            if column.startswith('f:m_'):
                columns.append(column)
                parts = column[2:].split("+", 2)
                parts.extend(parts.pop(2).split("!"))
                column = hbase_utils.prepare_key(*parts)
                updated_columns[column_prefix + column] = value
        resource_table.put(row, updated_columns)
        resource_table.delete(row, columns)
Example #3
0
def migrate_resource_table(conn, table):
    """Migrate table 'resource' in HBase.

    Change qualifiers format from "%s+%s+%s!%s!%s" %
    (rts, source, counter_name, counter_type,counter_unit)
    in columns with meters f:m_*
    to new separator format "%s:%s:%s:%s:%s" %
    (rts, source, counter_name, counter_type,counter_unit)
    """
    resource_table = conn.table(table)
    resource_filter = ("QualifierFilter(=, "
                       "'regexstring:m_\\d{19}\\+"
                       "[\\w-\\._]*\\+[\\w-\\._!]')")
    gen = resource_table.scan(filter=resource_filter)
    for row, data in gen:
        columns = []
        updated_columns = dict()
        column_prefix = "f:"
        for column, value in data.items():
            if column.startswith('f:m_'):
                columns.append(column)
                parts = column[2:].split("+", 2)
                parts.extend(parts.pop(2).split("!"))
                column = hbase_utils.prepare_key(*parts)
                updated_columns[column_prefix + column] = value
        resource_table.put(row, updated_columns)
        resource_table.delete(row, columns)
Example #4
0
    def record_metering_data(self, data):
        """Write the data to the backend storage system.

        :param data: a dictionary such as returned by
          report.meter.meter_message_from_counter
        """
        with self.conn_pool.connection() as conn:
            resource_table = conn.table(self.RESOURCE_TABLE)
            meter_table = conn.table(self.METER_TABLE)

            resource_metadata = data.get('resource_metadata', {})
            # Determine the name of new meter
            rts = hbase_utils.timestamp(data['timestamp'])
            new_meter = hbase_utils.prepare_key(
                rts, data['source'], data['counter_name'],
                data['counter_type'], data['counter_unit'])

            # TODO(nprivalova): try not to store resource_id
            resource = hbase_utils.serialize_entry(**{
                'source': data['source'],
                'meter': {new_meter: data['timestamp']},
                'resource_metadata': resource_metadata,
                'resource_id': data['resource_id'],
                'project_id': data['project_id'], 'user_id': data['user_id']})
            # Here we put entry in HBase with our own timestamp. This is needed
            # when samples arrive out-of-order
            # If we use timestamp=data['timestamp'] the newest data will be
            # automatically 'on the top'. It is needed to keep metadata
            # up-to-date: metadata from newest samples is considered as actual.
            ts = int(time.mktime(data['timestamp'].timetuple()) * 1000)
            resource_table.put(hbase_utils.encode_unicode(data['resource_id']),
                               resource, ts)

            # Rowkey consists of reversed timestamp, meter and a
            # message uuid for purposes of uniqueness
            row = hbase_utils.prepare_key(data['counter_name'], rts,
                                          data['message_id'])
            record = hbase_utils.serialize_entry(
                data, **{'source': data['source'], 'rts': rts,
                         'message': data, 'recorded_at': timeutils.utcnow()})
            meter_table.put(row, record)
Example #5
0
def migrate_alarm_history_table(conn, table):
    """Migrate table 'alarm_h' in HBase.

    Change row format from ""%s_%s" % alarm_id, rts,
    to new separator format "%s:%s" % alarm_id, rts
    """
    alarm_h_table = conn.table(table)
    alarm_h_filter = "RowFilter(=, 'regexstring:\\w*_\\d{19}')"
    gen = alarm_h_table.scan(filter=alarm_h_filter)
    for row, data in gen:
        row_parts = row.rsplit('_', 1)
        alarm_h_table.put(hbase_utils.prepare_key(*row_parts), data)
        alarm_h_table.delete(row)
Example #6
0
def migrate_alarm_history_table(conn, table):
    """Migrate table 'alarm_h' in HBase.

    Change row format from ""%s_%s" % alarm_id, rts,
    to new separator format "%s:%s" % alarm_id, rts
    """
    alarm_h_table = conn.table(table)
    alarm_h_filter = "RowFilter(=, 'regexstring:\\w*_\\d{19}')"
    gen = alarm_h_table.scan(filter=alarm_h_filter)
    for row, data in gen:
        row_parts = row.rsplit('_', 1)
        alarm_h_table.put(hbase_utils.prepare_key(*row_parts), data)
        alarm_h_table.delete(row)
Example #7
0
def migrate_meter_table(conn, table):
    """Migrate table 'meter' in HBase.

    Change row format from "%s_%d_%s" % (counter_name, rts, message_signature)
    to new separator format "%s:%s:%s" % (counter_name, rts, message_signature)
    """
    meter_table = conn.table(table)
    meter_filter = ("RowFilter(=, " "'regexstring:[\\w\\._-]*_\\d{19}_\\w*')")
    gen = meter_table.scan(filter=meter_filter)
    for row, data in gen:
        parts = row.rsplit('_', 2)
        new_row = hbase_utils.prepare_key(*parts)
        meter_table.put(new_row, data)
        meter_table.delete(row)
Example #8
0
def migrate_event_table(conn, table):
    """Migrate table 'event' in HBase.

    Change row format from ""%d_%s" % timestamp, event_id,
    to new separator format "%s:%s" % timestamp, event_id
    Also change trait columns from %s+%s % trait.name, trait.dtype
    to %s:%s % trait.name, trait.dtype
    """
    event_table = conn.table(table)
    event_filter = "RowFilter(=, 'regexstring:\\d*_\\w*')"
    gen = event_table.scan(filter=event_filter)
    trait_pattern = re.compile("f:[\w\-_]*\+\w")
    column_prefix = "f:"
    for row, data in gen:
        row_parts = row.split("_", 1)
        update_data = {}
        for column, value in data.items():
            if trait_pattern.match(column):
                trait_parts = column[2:].rsplit('+', 1)
                column = hbase_utils.prepare_key(*trait_parts)
            update_data[column_prefix + column] = value
        new_row = hbase_utils.prepare_key(*row_parts)
        event_table.put(new_row, update_data)
        event_table.delete(row)
Example #9
0
def migrate_meter_table(conn, table):
    """Migrate table 'meter' in HBase.

    Change row format from "%s_%d_%s" % (counter_name, rts, message_signature)
    to new separator format "%s:%s:%s" % (counter_name, rts, message_signature)
    """
    meter_table = conn.table(table)
    meter_filter = ("RowFilter(=, "
                    "'regexstring:[\\w\\._-]*_\\d{19}_\\w*')")
    gen = meter_table.scan(filter=meter_filter)
    for row, data in gen:
        parts = row.rsplit('_', 2)
        new_row = hbase_utils.prepare_key(*parts)
        meter_table.put(new_row, data)
        meter_table.delete(row)
Example #10
0
def migrate_event_table(conn, table):
    """Migrate table 'event' in HBase.

    Change row format from ""%d_%s" % timestamp, event_id,
    to new separator format "%s:%s" % timestamp, event_id
    Also change trait columns from %s+%s % trait.name, trait.dtype
    to %s:%s % trait.name, trait.dtype
    """
    event_table = conn.table(table)
    event_filter = "RowFilter(=, 'regexstring:\\d*_\\w*')"
    gen = event_table.scan(filter=event_filter)
    trait_pattern = re.compile("f:[\w\-_]*\+\w")
    column_prefix = "f:"
    for row, data in gen:
        row_parts = row.split("_", 1)
        update_data = {}
        for column, value in data.items():
            if trait_pattern.match(column):
                trait_parts = column[2:].rsplit('+', 1)
                column = hbase_utils.prepare_key(*trait_parts)
            update_data[column_prefix + column] = value
        new_row = hbase_utils.prepare_key(*row_parts)
        event_table.put(new_row, update_data)
        event_table.delete(row)