部署一臺大容量后端存儲節點
采用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
```
- 獻給我的朋友們
- 一、個人對學習的看法
- 二、運維技能圖譜
- 三、運維常用技能
- 3.1 Vim(最好用的編輯器)
- 3.2 Nginx & Tengine(Web服務)
- 1. Nginx介紹和部署
- 2. Nginx配置解析
- 3. Nginx常用模塊
- 4. Nginx 的session 一致性問題
- 3.3 Tomcat(Web中間件)
- 3.4 Keepalived(負載均衡高可用)
- 3.5 Memcache(分布式緩存)
- 3.6 Zookeeper(分布式協調系統)
- 3.7 KVM(開源虛擬化)
- 1. 虛擬化介紹
- 2. KVM基礎
- 3. 設置VNC和時間同步
- 4. kvm虛擬機快照備份
- 5. kvm虛擬機在線擴展磁盤
- 6. kvm虛擬機靜態遷移
- 7. kvm虛擬機動態遷移
- 8. kvm虛擬機存儲池配置
- 9. cpu添加虛擬化功能
- 3.8 GitLab(版本控制)
- 3.8.1 GitLab安裝與漢化
- 3.9 Jenkins(運維自動化)
- 3.10 WAF(Web防火墻)
- 3.10.1初探WAF
- 四、常用數據庫
- 4.1 MySQL(關系型數據庫)
- 1. MySQL源碼安裝
- 4.2 Mongodb(適用與大數據分析的數據庫)
- 4.3 Redis(非關系數據庫)
- 五、自動化運維工具
- 5.1 Cobbler(系統自動化部署)
- 5.2 Ansible(自動化部署)
- 5.3 Puppet(自動化部署)
- 5.4 SaltStack(自動化運維)
- 六、存儲
- 6.1 GFS(文件型存儲)
- 6.2 Ceph(后端存儲)
- 七、運維監控工具
- 7.1 對監控的理解
- 7.2 Zabbix(運維監控)
- 7.2.1 Zabbix簡介
- 7.2.2 Zabbix服務部署
- 1. Zabbix服務端部署
- 2. Zabbix客服端部署
- 3. 配置前端展示
- 4. zabbix告警配置
- 7.2.3 Zabbix監控服務
- 1. 監控網絡設備
- 2. 自定義Nginx監控
- 7.3 云鏡(安全監控)
- 7.4 ELK(日志收集展示)
- 八、運維云平臺
- 8.1 OpenStack(開源云操作系統)
- 8.1.1 OpenStack簡介
- 8.1.2 實驗架構設計
- 8.1.3 集群環境準備
- 8.1.4 controller節點部署
- 1. 安裝Mariadb Galera Cluster集群
- 2. 安裝RabbitMQ Cluster集群
- 3. 安裝Pacemaker
- 4. 安裝HAProxy
- 5. 安裝配置Keystone
- 6. 安裝配置glance
- 1. 制作鏡像模板
- 7. 安裝配置nova
- 8. 安裝配置neutron
- 1. 配置虛擬機網絡
- 9. 安裝Dashboard
- 10. 安裝配置cinder
- 8.1.5 compute節點部署
- 1. 安裝相關軟件包
- 2. 安裝Neutron
- 3. 配置cinder
- 4. 創建第一個虛擬機
- 8.1.6 OpenStack報錯處理
- 1. cinder僵尸卷刪除
- 8.1.7 快速孵化虛擬機方案
- 8.1.8 Kolla容器化部署OpenStack
- 1. 單點部署
- 2. 多節點部署
- 8.2 Tstack(騰訊云平臺)
- 8.3 K8s(微服務容器化)
- 九、運維編程技能
- 9.1 Shell(運維必會語言)
- 9.2 Python(萬能的膠水語言)
- 十、Devops運維
- 10.1 理念
- 10.2 Devops實戰