清理过期token使Openstack提速

本文介绍如何通过定期清理OpenStack Keystone中的过期Token来优化数据库性能,并提供了具体的方法及建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有时候你会发现使用Horizon创建或查询数据的速度变慢了,或者mysql占用CPU过高,亦或是备份数据库尤其是备份keystone数据库时耗时太长,这时候你就要考虑清理keystone数据库中的token表了。

Keystone默认使用SQL数据库存储token,在keystone.conf可以看到相关信息。token默认有效期为1天。

[plain]  view plain  copy
  1. [token]  
  2. # Provides token persistence.  
  3. driver = keystone.token.backends.sql.Token  

token的存放还有两个选择。

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

Keystone实现了一个小功能就是清理过期的token,命令非常简单,如下:
[plain]  view plain  copy
  1. keystone-manage token_flush  
把这条命令加入到crontab里,根据需要运行就可以了,例如每周运行一次。
[plain]  view plain  copy
  1. 0 1 * * 7 keystone-manage token_flush  

在token上我再补充一些内容,鉴于PKI过于庞大,不仅对Keystone,对Horizon上的HTTP的负载也会加大,所以在私有云环境下我们完全可以用UUID来代替默认的PKI。

配置非常简单,在keystone.conf中设置如下内容并重启keystone服务。

[plain]  view plain  copy
  1. [signing]  
  2. # Deprecated in favor of provider in the [token] section  
  3. # Allowed values are PKI or UUID  
  4. token_format = UUID  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值