以前没有写过python脚本,于是找了一个简易的教程过了一遍于是就是干了。
这两天测试mysql archive引擎的性能,于是用python向archive表中插入10亿条数据,python大致是如下写的:
for i in range(0,100000000)
insert into ....
结果执行之后系统就死机了,求助“伟哥”,最后发现再执行脚本的时候,for in range将内存吃完了,去python的文档中搜索了一下,得到下面的:
range ( [ start ], stop [, step ] )
This is a versatile function to create lists containing arithmetic progressions. It is most often used in for loops.
原来python直接给创建了一个list里面包含了10亿个整数,10亿*4byte=40 000 0000byte=400g,直接就把系统内存给吃干了
修改成while i<100000000之后就ok了,看来“陷阱”很多,以后得小心了,感谢“伟哥”,看来姜还是老的辣,而且辣多了。