Nova是openstack最早的兩塊模塊之一,另一個是對象存儲swift
。在openstack體系中一個叫做計算節(jié)點(diǎn)
,一個叫做控制節(jié)點(diǎn)
。這個主要和nova相關(guān),我們把安裝為計算節(jié)點(diǎn)nova-compute
,把除了nova-compute叫做控制節(jié)點(diǎn)。nova-compute是創(chuàng)建虛擬機(jī)的,只是創(chuàng)建虛擬機(jī),所有的控制都在另一臺上。
Nova組件介紹
API:實現(xiàn)了RESTful API功能,是外部訪問Nova的唯一途徑。
接收外部的請求并通過Message Queue將請求發(fā)送給其他的服務(wù)組件,同時也兼容EC2 API,所以也可以用EC2的管理工具對nova進(jìn)行日常管理。
Scheduler:模塊在OpenStack中負(fù)責(zé)決策虛擬機(jī)創(chuàng)建在那臺主機(jī)(計算節(jié)點(diǎn))上。
決策一個虛擬機(jī)應(yīng)該調(diào)度到某物理節(jié)點(diǎn),需要分兩個步驟:
過濾(Fliter) 首先獲取過未過濾的主機(jī)列表,根據(jù)過濾屬性,選擇服務(wù)條件的計算節(jié)點(diǎn)主機(jī)。
計算權(quán)值(Weight) 經(jīng)過主機(jī)過濾,需要對主機(jī)進(jìn)行權(quán)值的計算,根據(jù)策略選擇相應(yīng)的某一臺主機(jī)。
Cert:負(fù)責(zé)身份認(rèn)證
Conductor:計算節(jié)點(diǎn)訪問數(shù)據(jù)庫的中間件
Consoleauth:用于控制臺的授權(quán)驗證
Novncproxy:VNC代理
[root@linux-node1 ~]# vim /etc/nova/nova.conf
打開3052 enabled_apis=osapi_compute,metadata注釋 <-只啟用計算和元數(shù)據(jù)API ->
3649 [api_database]
3661 connection=mysql+pymysql://nova:nova@192.168.56.11/nova_api <-數(shù)據(jù)庫 ->
4651 [database]
4678connection=mysql+pymysql://nova:nova@192.168.56.11/nova <-數(shù)據(jù)庫 ->
default下 transport_url=rabbit://openstack:openstack@192.168.56.11 <-消息隊列 ->
打開14 auth_strategy=keystone注釋 <-連接keystone ->
5429 [keystone_authtoken]下面添加
5430 auth_uri = http://192.168.56.11:5000
5431 auth_url = http://192.168.56.11:35357
5432 memcached_servers = 192.168.56.11:11211
5433 auth_type = password
5434 project_domain_name = default
5435 user_domain_name = default
5436 project_name = service
5437 username = nova
5438 password = nova
2062 use_neutron=true <-啟用網(wǎng)絡(luò)服務(wù)支持 ->
3265 firewall_driver =nova.virt.firewall.NoopFirewallDriver
8384 vncserver_listen=0.0.0.0 <-配置VNC代理使用控制節(jié)點(diǎn)的管理接口IP地址 ->
8396 vncserver_proxyclient_address=192.168.56.11
4813 api_servers=http://192.168.56.11:9292 <-配置鏡像服務(wù) API 的位置 ->
打開6705 lock_path=/var/lib/nova/tmp注釋 <-配置鎖路徑 ->
[root@linux-node1 ~]# grep '^[a-z]' /etc/nova/nova.conf
auth_strategy=keystone
use_neutron=True
enabled_apis=osapi_compute,metadata
firewall_driver = nova.virt.firewall.NoopFirewallDriver
connection=mysql+pymysql://nova:nova@192.168.56.11/nova_api
connection=mysql+pymysql://nova:nova@192.168.56.11/nova
api_servers=http://192.168.56.11:9292
auth_uri = http://192.168.56.11:5000
auth_url = http://192.168.56.11:35357
memcached_servers = 192.168.56.11:11211
auth_type = password
project_domain_name = default
user_domain_name = default
project_name = service
username = nova
password = nova
lock_path=/var/lib/nova/tmp
transport_url=rabbit://openstack:openstack@192.168.56.11
vncserver_listen=0.0.0.0
vncserver_proxyclient_address=192.168.56.11
[root@linux-node1 ~]# su -s /bin/sh -c "nova-manageapi_db sync" nova
[root@linux-node1 ~]# su -s /bin/sh -c "nova-managedb sync" nova
[root@linux-node1 ~]# mysql -h292.168.56.11 -unova-pnova -e "use nova;show tables;" <-如果表存在證明同步成功 ->
[root@linux-node1 ~]# systemctl enableopenstack-nova-api.service \
openstack-nova-consoleauth.serviceopenstack-nova-scheduler.service \
openstack-nova-conductor.service openstack-nova-novncproxy.service
[root@linux-node1 ~]# systemctl startopenstack-nova-api.service \
openstack-nova-consoleauth.serviceopenstack-nova-scheduler.service \
openstack-nova-conductor.serviceopenstack-nova-novncproxy.service
[root@linux-node1 ~]# openstack service create --namenova \
--description "OpenStack Compute" compute <-創(chuàng)建nova服務(wù)實體 ->
[root@linux-node1 ~]# openstack endpoint create --regionRegionOne \
compute publichttp://192.168.56.11:8774/v2.1/%\(tenant_id\)s
[root@linux-node1 ~]# openstack endpoint create --regionRegionOne \
compute internalhttp://192.168.56.11:8774/v2.1/%\(tenant_id\)s
[root@linux-node1 ~]# openstack endpoint create --regionRegionOne \
compute adminhttp://192.168.56.11:8774/v2.1/%\(tenant_id\)s
<-配置API端點(diǎn) ->
[root@linux-node1 ~]# openstack host list
[root@linux-node1 ~]# scp /etc/nova/nova.conf192.168.56.12:/tmp/ <-將控制節(jié)點(diǎn)配置文件發(fā)送到計算節(jié)點(diǎn)->
[root@linux-node2 ~]# cp /tmp/nova.conf /etc/nova/ <-替換計算節(jié)點(diǎn)配置文件 ->
[root@linux-node2 ~]# vim /etc/nova/nova.conf <-編輯配置文件 ->
3661connection=mysql+pymysql://nova:nova@192.168.56.11/nova_api
4678connection=mysql+pymysql://nova:nova@192.168.56.11/nova
<-刪除以上兩條連接數(shù)據(jù)庫的配置,上文講過計算節(jié)點(diǎn)連接數(shù)據(jù)庫通過conductor->
8394 vncserver_proxyclient_address=192.168.56.12 <-改為計算節(jié)點(diǎn)IP ->
8413 novncproxy_base_url=http://192.168.56.11:6080/vnc_auto.html
8359 enabled=true <-打開注釋,允許VNC ->
8375 keymap=en-us <-打開注釋,允許鍵盤 ->
5672 virt_type=kvm <-打開注釋,CPU支持虛擬化 ->
注:這一步首先要確定計算節(jié)點(diǎn)CPU是否支持虛擬化、支持硬件加速
egrep -c '(vmx|svm)' /proc/cpuinfo執(zhí)行此命令來查看,如果返回值為1,或者大于1則不需要修改,如果返回值為0則必須配置libvirt 來使用 QEMU 去代替 KVM
3601transport_url=rabbit://openstack:openstack@192.168.56.11
[root@linux-node2 ~]# diff /tmp/nova.conf/etc/nova/nova.conf
3661d3660
< connection=mysql+pymysql://nova:nova@192.168.56.11/nova_api
4678d4676
5674c5672 < #virt_type=kvm --- > virt_type=kvm 6469a6468,6477 > url = http://192.168.56.11:9696 > auth_url = http://192.168.56.11:35357 > auth_type = password > project_domain_name = default > user_domain_name = default > region_name = RegionOne > project_name = service > username = neutron > password = neutron > 8361c8369 < #enabled=true --- > enabled=true 8377c8385 < #keymap=en-us --- > keymap=en-us 8396c8404 < vncserver_proxyclient_address=192.168.56.11 --- > vncserver_proxyclient_address=192.168.56.12 8415c8423 <#novncproxy_base_url=http://127.0.0.1:6080/vnc_auto.html --- >novncproxy_base_url=http://192.168.56.11:6080/vnc_auto.html [root@linux-node2~]# systemctl enable libvirtd.service openstack-nova-compute.service [root@linux-node2~]# systemctl start libvirtd.service openstack-nova-compute.service 另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。1.3.3啟動服務(wù)
當(dāng)前名稱:【N版】openstack——計算服務(wù)nova(五)-創(chuàng)新互聯(lián)
當(dāng)前網(wǎng)址:http://weahome.cn/article/dssppe.html