声明:
本博客欢迎转发,但请保留原作者信息!
新浪微博:@孔令贤HW;
博客地址:http://blog.csdn.net/lynn_kong
内容系本人学习、研究和总结,如有雷同,实属荣幸!
对比版本:
Folsom 2012.2 release版Grizzly 2013.6.3 master分支
Availability Zone的概念在Folsom和Grizzly中,在使用上有很大的不同。怎么确定一个host属于哪个Availability Zone呢?分别看一下F版和G版的实现。
1. F版
之前很多人问,在命令行界面通过nova-manage service list看到有些服务状态(比如nova-compute)不是笑脸,而是XXX,为什么?回答这个问题之前,我们必须知道服务状态是如何确定的?在F版中,每一个服务启动时都会有一个循环任务report_state,在循环任务中,会向数据库(确切的说是Service表)写入一些信息,比如一个计数report_count以及更新该记录的时间。还是贴点代码以示诚意吧:
def report_state(self):
"""Update the state of this service in the datastore."""
ctxt = context.get_admin_context()
zone = FLAGS.node_availability_zone
state_catalog = {}
try:
try:
service_ref = db.service_get(ctxt, self.service_id)