多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
部署一台大容量后端存储节点 采用nfs共享镜像池 结合linux硬链接技术 结合openstack hash值镜像ID生成代码 优点:快速启动、镜像备份、适合快速开发测试私有云环境 难点:环境要稳定、快速孵化、网络带宽、计算资源、存储资源要足 注析: 1、`/var/lib/nova/instances`目录是计算节点虚拟机文件目录 2、`/var/lib/nova/instance/_base`下面是存在的cache,这个本质是镜像,只是权限和宿舍用户不一样而已,同时,我们可以通过ln硬链接生成放在这个目录下,`_base`目录下的文件不能丢失,否则依赖cache创建的虚拟机将无法启动,如果想要重新使用这个虚拟机就需要将cache重新放回到目录下并在对于的计算节点执行如下命令:`nova restet-state --active error-vm-id`。如果删除了原来的镜像需要定期清理ln,防止撑爆磁盘! 3、`/var/lib/glance/images`是控制节点上存镜像的目录 如果要孵化一个很大的虚拟机(孵化时间长容易造成孵化失败),在dashboard创建的话速度会很慢(首次创建很慢) 查看流量的工具nload 使用命令:nload 查看流量 如果在生产环境中我们可以预先把镜像的ln(镜像ID值)移动到`/var/lib/nova/instances/_base`下,再创建虚拟机的时候会非常快,快的原因是不需要再下载虚拟机镜像了 总结: 0、nfs-backend节点 install build 网卡最好万兆 1、每个计算节点`/var/lib/nova/instance/_base` 都要预先有`image cache(ln硬链接生成的)` 2、`/var/lib/glance/images ---ln---> /var/lib/glance/imagecache` 这两个目录是在一个`nfs-backend`节点上的,而且都是一个文件系统下的 3、定时,自动,无缝隙(间隔时间要非常小) 做ln,写脚本:python脚本 脚本代码如下: ``` import os import logging import logging.handlers import hashlib import commands LOG_FILE = ‘ln_all_images.log’ handler = logging.handlers.RotatingFileHandler(LOG_FILE, maxBytes = 1024*1024, backupCount = 5) fmt = '%(asctime)s - %(filename)s:%(lineno)s - %(name)s - %(message)s' formatter = logging.Formatter(fmt) handler.setFormatter(formatter) logger = logging.getLogger('images') logger.addHandler(handler) logger.setLevel(logging.DEBUG) #imges_list = commands.getoutput("ls -l tr /var/lib/glance/images | awk 'NR>1{ print $NF }‘").strip().split('\n') imges_list = commands.getoutput("""glance image-list | awk -F"|" '{print $2}' |grep -v -E '(ID|^$'""").strip().split() status = commands.getoutput("""openstack image list | awk 'NR>2{ print $6} |grep -v -E '(ID|^$'""").strip().split() queued = "queued" saving = "saving" #print status #print type(staus) if queued in status or saving in stauts:                   image_list_1 = commands.getoutput(ls -l tr /var/lib/glance/images | awk 'NR>1 {1[NR]=$0} END {for (i=1;i<=NR-3;i++)print l[i]}' | awk '{print $9}' | awk '{ print $9}' |grep -v ^$").strip().split() logger.info('new snapshoot is creating now...') for ida in image_list_1:                                  image_id = ida.strip() image_id_hash = hashlib.sha1() image_id_hash.update(ida) newid1 = image_id_hash.hexdigest() commands.getoutput('ln /var/lib/glance/images/{0} /var/lib/glance/imagecache/{1}'.format(ida,newid1)) commands.getoutput('chown qemu:qemu /var/lib/glance/imagecache/{0}'.format(newid1)) commands.getoutput('chmod 644 /var/lib/glance/imagecache/{0}').format(newid1)) else: image_list_2 = commands.getoutput("ls -l tr /var/lib/glance/images | awk 'NR>1{ print $NF }'").strip().split() logger.info('no image take snapshoot, ln all images...') for ida in image_list_2:                                   image_id = ida.strip() image_id_hash = hashlib.sha1() image_id_hash.update(ida) newid2 = image_id_hash.hexdigest() commands.getoutput('ln /var/lib/glance/images/{0} /var/lib/glance/imagecache/{1}'.format(ida,newid2)) commands.getoutput('chown qemu:qemu /var/lib/glance/imagecache/{0}'.format(newid2)) commands.getoutput('chmod 644 /var/lib/glance/imagecache/{0}').format(newid2)) #logger.info('in %s successful...' %(idb)) ``` 4、定时可以通过linux的crontab,自动用脚本`ln_all_images.py`,无缝隙定时执行,每10秒执行一次`* * * * * sleep 10`; ``` * * * * * source /root/admin-openrc && /usr/bin/python /root/ln_all_images.py * * * * * sleep 10; source /root/admin-openrc && /usr/bin/python /root/ln_all_images.py * * * * * sleep 20; source /root/admin-openrc && /usr/bin/python /root/ln_all_images.py * * * * * sleep 30; source /root/admin-openrc && /usr/bin/python /root/ln_all_images.py * * * * * sleep 40; source /root/admin-openrc && /usr/bin/python /root/ln_all_images.py * * * * * sleep 50; source /root/admin-openrc && /usr/bin/python /root/ln_all_images.py ```