如何在OpenStack环境中实现定制化功能

写这篇文章的目的是介绍一个在线修改openstack工程文件以实现对某些功能的测试(或其他一些目的)的方法。可能是我自己的水平问题,亦或者是大牛们不屑于回答这样的问题,我几乎在网上(国内)找不到类似的方法。于是研究了一点时间并最终实验成功后,不敢保留,稍作总结,希望能帮助与我有同样困惑的朋友们。

1      文件在哪

现在网上的安装方法基本都是通过配置安装源安装,那么安装后的openstack工程的程序文件在哪呢?以nova为例:

如何在OpenStack环境中实现定制化功能

这个目录下的结构是不是十分熟悉,对,基本跟在eclipse下浏览工程的结构一模一样,这就是安装openstack后源代码路径。再看下面的目录:

如何在OpenStack环境中实现定制化功能

这里就是nova工程经过编译后的文件,其中的py文件是上面那个目录中对应文件的链接而已。

2      动手修改python文件

知道了源文件和编译文件的位置,那么我们就能很容易的修改程序以满足我们自己的要求。以修改nova操作权限判断流程为例。nova创建虚拟机时,会调用nova/compute/api.py中API类的_check_create_policies方法根据policy.json文件内容进行操作权限的判断,而该方法最终会调用nova/policy.py中的enforce方法:

如何在OpenStack环境中实现定制化功能

如果我们想知道程序运行到此时,context中到底有什么内容,那么我们可以修改文件如下,注意对比上面代码新增的4行:

如何在OpenStack环境中实现定制化功能

需要注意是:要在文件的开头处将logging引入,同时,定义:

LOG = logging.getLogger(__name__)

我们打印两行*号以便快速定位日志,同时将context内容打印出来,并显式的抛出一个异常让本次处理停止。

相关推荐