• 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'),

  • 相关阅读:
    git连接远程GitHub仓库详细总结 for HTTPS协议
    软工课程总结&小黄衫获奖感言
    Yum项目上线实战(网站运维)
    MySQL基础
    Shell基础
    Linux网络基础
    Linux的权限管理操作
    linux自有服务(2)
    Linux自有服务
    Linux基本指令
  • 原文地址:https://www.cnblogs.com/allcloud/p/4939110.html
Copyright © 2020-2023  润新知