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'),
- 关于教育
- 关于Cisco HSRP
- win8自带的PC语点在哪里?怎么使用?
- Opencv Mat理解
- 选择排序
- 自己遇到的几个问题,跟大家分享一下
- hdu 5534 Partial Tree(完全背包)
- linux 内核大牛-谢宝友
- 如何向VISUAL SVN SERVER上传文件
- Ajax status状态说明
- 如何处理SQL Server数据库出现“可疑”情况
- 单例模式的三种写法
- storeIpAddresses
- HDOJ 3501 Calculation 2 (欧拉函数)
- UITableView中没有数据时,让其不显示下划线的两种方法
- leetcode-Remove Duplicates from Sorted Array
- webapp通过JS代码与移动APP交互
- 第10周项目2- 二叉树遍历的递归算法
- Codeforces Round #329 (Div. 2)B. Anton and Lines 贪心
- 强烈推荐android studio用的几个插件