**本方案中是模擬環境,由六個OpenStack節點與NFS存儲后端和YUM服務器組成。**
# 部署架構設計
- 第一部分是三個控制節點,控制節點上承載著NTP集群、Mariadb Galera集群、RabbitMQ集群、haproxy集群的主要工作。當某個服務宕機或服務中斷之后,集群也將會自定切換,保證服務高可用性。另外控制節點上安裝了對應的OpenStack組件,在云端起到了身份驗證、鏡像存儲管理和部分計算節點控制,網絡代理和后臺管理界面等功能。
- 第二部分是計算節點,計算節點上承載著KVM虛擬化模塊,起到計算資源虛擬化的作用,供給云端運行虛擬機實例。另外計算節點上安裝了對應的OpenStack組件,在云端起到了接受和響應總段用戶有關虛擬機的請求、網絡代理連接虛擬網絡等功能。可以通過橫行擴展或是豎向擴展進行安裝添加資源池,且新增計算節點配置部署方便快捷。
- 第三部分是后端存儲。根據實際情況放棄了安裝swift組件,在控制節點和計算節點上安裝了鏡像存儲和塊存儲存儲服務。后端存儲使用NFS。NFS主要起到存儲VM鏡像、存儲實例的功能;Cinder主要起到為實例掛載硬盤的作用。
- 第四部分是yum源的配置,OpenStack版本眾多且版本的配置參數標準不統一,通過在阿里云上拷貝centos7.2、epel、OpenStack Newton版、Mariadb的rpm數據包。減低linux軟件更新安裝出現的各種不穩定因素。

# 節點資源分析
根據方案設計的模型,需要安裝8個centos mini 7.2系統,
| 節點 | 系統 | 數量 | CPU | 內存 | 硬盤(GB) | 網卡(千兆) | 支持虛擬化 |
| --- | --- | --- | --- | --- | --- | --- | --- |
| Controller | Centos 7.2 | 3 | 4c | 8GB | 150 | 3 | 不支持 |
| Compute | Centos 7.2 | 2 | 4c+ | 8GB+ | 100 | 3 | 支持 |
| Cinder | Centos 7.2 | 1 | 4c | 4GB | 100+300 | 3 | 不支持 |
| Nfs | Centos 7.2 | 1 | 4c | 4GB | 100+ | 2 | 不支持 |
| Yum | Centos 7.2 | 1 | 4c | 512MB | 100 | 1 | 不支持 |
控制節點是私有云的控制節點,安裝所有節點控制組件,負責私有云的調度、管理。每個節點CPU需要至少4核,內存至少8G,150GB硬盤。
計算節點是私有云的計算節點,負責創建,存儲虛擬機,所有的實例都要支持虛擬化,并且CPU需要至少4核,內存8G+,100GB硬盤。
塊存儲節點是私有云的塊設備存儲節點,負責給虛擬機掛載使用,向虛擬機提供存儲數據的磁盤空間。Cinder節點CPU需要4核,內存8G+,100GB+300GB硬盤。
NFS節點是私有云后端存儲的節點,提供給glance組件存儲鏡像和nova 組件提供存儲實例。所以該節點的CPU需要4核,內存4G,100GB硬盤。
YUM節點提供給其他節點安裝軟件,包含著centos7.2、epel、OpenStack Newton版、Mariadb的rpm數據包。所以該節點的CPU需要4核,內存512M,100GB硬盤。
各節點最低硬件需求:

# 網絡需求
集群中控制節點和計算節點都需要連接3張網卡:exrernal網絡,admin網絡,tunnel網絡。塊存儲節點不需要與外部網絡聯系,只需通過管理網絡與核心節點交互數據即可。所以集群節點默認使用3張網卡,存儲節點默認使用2張網卡。NFS和Yum只需要給內部計算節點和控制節點使用,只需內部網絡。如果內網的電腦需要連接互聯網,那么外部網絡必須設置為flat模式,且該VLAN必須是外部網絡,不然所有VM都不能訪問互聯網。
邏輯拓撲網絡:

- 獻給我的朋友們
- 一、個人對學習的看法
- 二、運維技能圖譜
- 三、運維常用技能
- 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實戰