分享

openstack keystone token flush 自动清理【分享】

xuanxufeng 发表于 2015-12-23 08:16:34 [显示全部楼层] 回帖奖励 阅读模式 关闭右栏 0 14655
发现使用Horizon创建或查询数据速度变慢,或者mysql占用CPU过高,亦或备份数据库尤其是备份keystone数据库时耗时太长,这时候要考虑清理keystone数据库中token表。
Keystone默认使用SQL数据库存储token,在keystone.conf可看到相关信息。token默认有效期为1天。
[mw_shl_code=bash,true][token]
# Provides token persistence.
driver = keystone.token.backeds.sql.Token[/mw_shl_code]

token存放还有两个选择。
keystone.token.backends.memcache:内存数据库
keystone.token.backends.kvs:二元组(键对)
使用memcache虽速度加快,但耗内存。使用键对速度相对较慢。固最好还是使用关系数据库,例如mysql。
但是Openstack中每个组件执行的每次命令(请求),都需要token来验证,这就造成keystone创建了大量的token,随着时间的推移,无效的记录越来越多,企业私有云几天的量就可以几万条、几十万条。这么多无效的token导致针对token表的SQL语句变慢。可以打开mysql的debug选项然后运行Openstack命令,如果token表非常大,对它的操作会占用大量时间。
Keystone实现了一个小功能就是清理过期的token,命令非常简单,如下:

[mw_shl_code=bash,true]keystone-manage token_flush[/mw_shl_code]

把这条命令加入到crontab里,根据需要运行就可以了,例如每分运行一次。
*/1 * * * * /usr/bin/keystone-manage token_flush >/dev/null 2>&1
在token上我再补充一些内容,鉴于PKI过于庞大,不仅对Keystone,对Horizon上的HTTP的负载也会加大,所以在私有云环境下我们完全可以用UUID来代替默认的PKI。
配置非常简单,在keystone.conf中设置如下内容并重启keystone服务。

[mw_shl_code=bash,true][signing]
# Deprecated in favor of provider in the [token] section
# Allowed values are PKI or UUID
token_format = UUID[/mw_shl_code]
















没找到任何评论,期待你打破沉寂

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

推荐上一条 /2 下一条