• ceilometer alarm 创建过程中的DB操作及优化


    创建一个ceilometer alarm需要4次DB操作:

    api/controllers/v2/alarms.py

    1. is_over_quota 每一次都需要查询该user/project的所有alarms

    2. 判断alarm name是否已经存在于DB中,也需要查询该user/project的所有alarms
            # make sure alarms are unique by name per project.
            alarms = list(conn.get_alarms(name=data.name,
                                          project=data.project_id))
    3. 添加alarm行
            alarm = conn.create_alarm(alarm_in)

    4.添加一个alarm历史记录
            self._record_creation(conn, change, alarm.alarm_id, now)

    优化考虑:

    1. is_over_quota,可以创建一个全局计算数据结构并为多API workers加锁,服务启动时从DB的获得初始化值。

    2. 判断alarm name是否已经存在于DB中,把name作为该table的键值,就不需要先取得user/project的所有alarms。

     同时可以看到alarm表是建了user_id/project_id的索引以提高以上2步的效率。

    class Alarm(Base):
        """Define Alarm data."""
        __tablename__ = 'alarm'
        __table_args__ = (
            Index('ix_alarm_user_id', 'user_id'),
            Index('ix_alarm_project_id', 'project_id'),

  • 相关阅读:
    MapReduce in MongoDB
    MongoDB的一些基本操作
    谈谈NOSQL
    Java中的反射(1)
    Mybatisの常见面试题
    关于Lombok和自动生成get set方法
    订Pizza(Java)
    美化Div的边框
    爱,死亡和机器人(Love,Death&Robots)
    session与cookie的介绍和两者的区别之其相互的关系
  • 原文地址:https://www.cnblogs.com/allcloud/p/4939110.html
Copyright © 2020-2023  润新知