报错代码如下:
File "./ga_web/lib/meta_data.py", line 94, in instance_list_ip_port
return [x.get('ip')+':'+str(x.get('port')) for x in self.instance_list(filter)]
File "./ga_web/lib/meta_data.py", line 82, in instance_list
for d in instance_list:
File "/usr/local/lib/python2.7/site-packages/Django-1.8.7-py2.7.egg/django/db/models/query.py", line 1312, in __iter__
setattr(instance, column, values[pos])
AttributeError: can't set attribute
可以看到出错地方是在 迭代instance_list 对象的时候报错的。
sql = "select i.* ,i.business_id,b.name as business,i.owner as owner_id,u.name as owner from instance i " \
"left join business b on i.business_id=b.id left join user u on i.owner=u.id where 1=1 "
return Instance.objects.raw(sql)
而model Instance 有一个属性是“business”,sql语句的返回结果里也有个“business”字段,两个字段同名,导致数据从数据库查出来后,映射到model上正对上这个名称,所以instance_list(集合)中对象的“business”属性无法赋值或设置。解决办法是:要么重命名Instance中的“business”,要么修改sql语句中的“business”为其他名称,都可以解决。
这个报错其实很大众,可能大家出错的地方都不同,但最终根源问题还都是一样的。