openstack
時間:2016年11月28日
Neutron介紹
neutron是openstack重要組件之一,在以前是時候沒有neutron
項目
早期的時候是沒有neutron,早期所使用的網(wǎng)絡(luò)的nova-network,經(jīng)過版本改變才有個neutron
Openstack Networking網(wǎng)絡(luò):
在實際的物理環(huán)境下,我們使用交換機或者集線器把多個計算機連接起來形成了網(wǎng)絡(luò)。在Neutron的世界里,網(wǎng)絡(luò)也是將多個不同的云主機連接起來。子網(wǎng):
在實際的物理環(huán)境下,在一個網(wǎng)絡(luò)中。我們可以將網(wǎng)絡(luò)劃分成多為邏輯子網(wǎng)。在Neutron的世界里,子網(wǎng)也是隸屬于網(wǎng)絡(luò)下的。端口:
是實際的物理環(huán)境下,每個子網(wǎng)或者網(wǎng)絡(luò),都有很多的端口,比如交換機端口來供計算機連接。在Neutron的世界端口也是隸屬于子網(wǎng)下,云主機的網(wǎng)卡會對應(yīng)到一個端口上。路由器:
在實際的網(wǎng)絡(luò)環(huán)境下,不同網(wǎng)絡(luò)或者不同邏輯子網(wǎng)之間如果需要進行通信,需要通過路由器進行路由。在Neutron的實際里路由也是這個作用。用來連接不同的網(wǎng)絡(luò)或者子網(wǎng)。
Neutron 架構(gòu)介紹
Neutron也分為控制節(jié)點
和計算節(jié)點
openstack默認的網(wǎng)絡(luò)是單一扁平網(wǎng)絡(luò)(虛擬機跟宿主機在同一個網(wǎng)段)在官方文檔上稱為提供者網(wǎng)絡(luò)
安裝
數(shù)據(jù)庫我們在一開始就已經(jīng)創(chuàng)建完成
keystone用戶我們也已經(jīng)創(chuàng)建完成
配置網(wǎng)絡(luò)選項
您可以部署網(wǎng)絡(luò)服務(wù)使用選項1和選項2兩種架構(gòu)中的一種來部署網(wǎng)絡(luò)服務(wù)。
選項1采用盡可能簡單的架構(gòu)進行部署,只支持實例連接到公有網(wǎng)絡(luò)(外部網(wǎng)絡(luò))。沒有私有網(wǎng)絡(luò)(個人網(wǎng)絡(luò)),路由器以及浮動IP地址。只有admin
或者其他特權(quán)用戶才可以管理公有網(wǎng)絡(luò)
選項2在選項1的基礎(chǔ)上多了layer-3服務(wù),支持實例連接到私有網(wǎng)絡(luò)。demo
或者其他沒有特權(quán)的用戶可以管理自己的私有網(wǎng)絡(luò),包含連接公網(wǎng)和私網(wǎng)的路由器。另外,浮動IP地址可以讓實例使用私有網(wǎng)絡(luò)連接到外部網(wǎng)絡(luò),例如互聯(lián)網(wǎng)
典型的私有網(wǎng)絡(luò)一般使用覆蓋網(wǎng)絡(luò)。覆蓋網(wǎng)絡(luò),例如VXLAN包含了額外的數(shù)據(jù)頭,這些數(shù)據(jù)頭增加了開銷,減少了有效內(nèi)容和用戶數(shù)據(jù)的可用空間。在不了解虛擬網(wǎng)絡(luò)架構(gòu)的情況下,實例嘗試用以太網(wǎng) 大傳輸單元 (MTU) 1500字節(jié)發(fā)送數(shù)據(jù)包。網(wǎng)絡(luò)服務(wù)會自動給實例提供正確的MTU的值通過DHCP的方式。但是,一些云鏡像并沒有使用DHCP或者忽視了DHCP MTU選項,要求使用元數(shù)據(jù)或者腳本來進行配置
我們先進行配置公共網(wǎng)絡(luò)
在控制節(jié)點
安裝組件
提示:neutron
和其他組件的小區(qū)別是配置完數(shù)據(jù)庫之后不可以馬上進行同步,它還依賴其他配置文件
編輯/etc/neutron/neutron.conf
文件并完成如下操作
提示:不需要同步數(shù)據(jù)庫,684為684行
在 [DEFAULT]
和 [keystone_authtoken]
部分,配置認證服務(wù)訪問
rabbitmq
(消息隊列)配置
neutron
核心配置有2
個
啟動ML2
插件并禁用其他插件
配置網(wǎng)絡(luò)服務(wù)來通知計算節(jié)點的網(wǎng)絡(luò)拓撲變化:(配置nova
相關(guān))
提示:簡單的來說就是端口發(fā)生變化通知nova
[nova]nova標簽的配置其實就是keystone的配置auth_url = http://192.168.56.11:35357auth_type = passwordproject_domain_name = defaultuser_domain_name = defaultregion_name = RegionOneproject_name = serviceusername = novapassword = nova配置鎖路徑
[oslo_concurrency]lock_path = /var/lib/neutron/tmpneutron配置小結(jié):
[root@linux-node1 ~]# grep '^[a-z]' /etc/neutron/neutron.confauth_strategy = keystone #使用keystone進行驗證core_plugin = ml2 #使用ml2插件service_plugins = #不使用其他插件notify_nova_on_port_status_changes = true #端口改變通知novanotify_nova_on_port_data_changes = true #端口改變通知novarpc_backend = rabbit #使用rabbitconnection = mysql+pymysql://neutron:neutron@192.168.56.11/neutron #數(shù)據(jù)庫連接地址auth_uri = http://192.168.56.11:5000 #neutron keystone的配置auth_url = http://192.168.56.11:35357 #neutron keystone的配置memcached_servers = 192.168.56.11:11211 #neutron keystone的配置auth_type = password #neutron keystone的配置project_domain_name = default #neutron keystone的配置user_domain_name = default #neutron keystone的配置project_name = service #neutron keystone的配置username = neutron #neutron keystone的配置password = neutron #neutron keystone的配置auth_url = http://192.168.56.11:35357 #neutron nova的配置auth_type = password #neutron nova的配置project_domain_name = default #neutron nova的配置user_domain_name = default #neutron nova的配置region_name = RegionOne #neutron nova的配置project_name = service #neutron nova的配置username = nova #neutron nova的配置password = nova #neutron nova的配置lock_path = /var/lib/neutron/tmp #鎖路徑rabbit_host = 192.168.56.11 #rabbitmq配置rabbit_userid = openstack #rabbitmq配置rabbit_password = openstack #rabbitmq配置配置Modular Layer 2
(ML2
)
ML2插件使用Linuxbridge
機制來為實例創(chuàng)建layer-2
虛擬網(wǎng)絡(luò)基礎(chǔ)設(shè)施
編輯配置文件/etc/neutron/plugins/ml2/ml2_conf.ini
驅(qū)動的選擇
[ml2]type_drivers = flat,vlan,gre,vxlan,geneve設(shè)置使用那幾個插件來創(chuàng)建網(wǎng)絡(luò)
[ml2]mechanism_drivers = linuxbridge,openvswitch提示:我們可以寫多個,不管用不用都可以寫上去
禁用私有網(wǎng)絡(luò)
[ml2]tenant_network_types =啟動端口安全擴展驅(qū)動
[ml2]extension_drivers = port_security在[ml2_type_flat]
部分,配置公共虛擬網(wǎng)絡(luò)為flat網(wǎng)絡(luò)
在 [securitygroup]
部分,啟用 ipset
增加安全組規(guī)則的高效性:
提示:ml2_conf
里面的網(wǎng)絡(luò)類型很多,我們需要那種網(wǎng)絡(luò)類型配置即可
ML2插件配置小結(jié):
[root@linux-node1 ~]# grep '^[a-z]' /etc/neutron/plugins/ml2/ml2_conf.initype_drivers = flat,vlan,gre,vxlan,geneve #驅(qū)動類型tenant_network_types = #租戶的網(wǎng)絡(luò)類型mechanism_drivers = linuxbridge,openvswitch #創(chuàng)建網(wǎng)絡(luò)插件extension_drivers = port_security #打開端口安全flat_networks = public #網(wǎng)絡(luò)類型publicenable_ipset = true #開啟ipset配置Linuxbridge
代理
編輯/etc/neutron/plugins/ml2/linuxbridge_agent.ini
文件并且完成以下操作
在[vxlan]
部分,禁止VXLAN覆蓋網(wǎng)絡(luò):
在[securitygroup]
部分,啟用安全組并配置 Linuxbridge iptables firewall driver
:
Linuxbridge
代理總結(jié)如下:
配置DHCP代理
編輯/etc/neutron/dhcp_agent.ini
文件并完成下面的操作:
在[DEFAULT]部分,配置Linuxbridge驅(qū)動接口,DHCP驅(qū)動并啟用隔離元數(shù)據(jù),這樣在公共網(wǎng)絡(luò)上的實例就可以通過網(wǎng)絡(luò)來訪問元數(shù)據(jù)
[DEFAULT]…interface_driver = neutron.agent.linux.interface.BridgeInterfaceDriver#虛擬接口驅(qū)動,使用Linuxbridgedhcp_driver = neutron.agent.linux.dhcp.Dnsmasq#dhcp驅(qū)動,默認使用Dnsmasq(是一個小的開源項目)來提供dhcp服務(wù)enable_isolated_metadata = false#刷新路由使用DHCP配置小結(jié)
[root@linux-node1 ~]# grep '^[a-z]' /etc/neutron/dhcp_agent.iniinterface_driver = neutron.agent.linux.interface.BridgeInterfaceDriver #底層插件Linuxbridgedhcp_driver = neutron.agent.linux.dhcp.Dnsmasq #DHCPenable_isolated_metadata = false #推送路由使用配置元數(shù)據(jù)代理
負責提供配置信息,例如:訪問實例的憑證
編輯/etc/neutron/metadata_agent.ini
文件并完成以下操作:
在[DEFAULT]
部分,配置元數(shù)據(jù)主機以及共享密碼:
提示:這個共享密鑰就是一個字符串
配置網(wǎng)絡(luò)服務(wù)(nova-api)
編輯/etc/nova/nova.conf
文件并完成以下操作:
在[neutron]
部分,配置訪問參數(shù),啟用元數(shù)據(jù)代理并設(shè)置密碼:
提示:9696
是neutron-server
的端口
網(wǎng)絡(luò)服務(wù)初始化腳本需要一個超鏈接 /etc/neutron/plugin.ini
指向ML2插件配置文件/etc/neutron/plugins/ml2/ml2_conf.ini
如果超鏈接不存在,使用下面的命令創(chuàng)建它:
提示:這里我們使用那個插件就用它做一個軟連接即可
同步數(shù)據(jù)庫
[root@linux-node1 ~]# su -s /bin/sh -c "neutron-db-manage --config-file /etc/neutron/neutron.conf \ --config-file /etc/neutron/plugins/ml2/ml2_conf.ini upgrade head" neutron注:數(shù)據(jù)庫的同步發(fā)生在 Networking
之后,因為腳本需要完成服務(wù)器和插件的配置文件。
重啟計算API 服務(wù):
[root@linux-node1 ~]# systemctl restart openstack-nova-api.service當系統(tǒng)啟動時,啟動Networking
服務(wù)并配置它啟動。
對于兩
種網(wǎng)絡(luò)選項:
現(xiàn)在還需要將neutron
在keystone
上進行注冊
創(chuàng)建neutron
服務(wù)實體:
創(chuàng)建網(wǎng)絡(luò)服務(wù)API
端點:
檢查neutron
是否安裝成功
配置neutron
計算節(jié)點
安裝組件,安裝的服務(wù)器在192.168.56.12
linux-node2.com
上面
因為控制節(jié)點跟計算節(jié)點配置幾乎一樣,我們直接復(fù)制控制節(jié)點的文件進行修改控制節(jié)點拷貝
[root@linux-node1 ~]# scp /etc/neutron/neutron.conf root@192.168.56.12:/etc/neutron在計算節(jié)點進行修改配置文件權(quán)限
[root@linux-node2 ~]# chown -R root:neutron /etc/neutron/neutron.conf[root@linux-node2 ~]# ll /etc/neutron/neutron.conf-rw-r----- 1 root neutron 53140 Nov 21 15:13 /etc/neutron/neutron.conf計算節(jié)點設(shè)置
[root@linux-node2 ~]# vim /etc/neutron/neutron.conf#connection = #刪除mysql連接路徑[nova] #刪除nova標簽下所有配置#notify_nova_on_port_status_changes = true #注釋#notify_nova_on_port_data_changes = true #注釋#core_plugin = ml2 #注釋插件#service_plugins = #注釋計算節(jié)點跟控制節(jié)點進行對比
[root@linux-node2 ~]# diff /etc/neutron/neutron.conf /tmp/neutron.conf 30c30< #core_plugin = ml2---> core_plugin = ml233c33< #service_plugins =---> service_plugins =137c137< #notify_nova_on_port_status_changes = true---> notify_nova_on_port_status_changes = true141c141< #notify_nova_on_port_data_changes = true---> notify_nova_on_port_data_changes = true684c684< #connection = ---> connection = mysql+pymysql://neutron:neutron@192.168.56.11/neutron936a937,944> 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 = nova> password = nova提示:不注釋也沒有問題,但是為了環(huán)境保持一致還是注釋掉比較好
為計算節(jié)點配置網(wǎng)絡(luò)服務(wù)
我們可以直接復(fù)制控制節(jié)點的配置進行修改
提示:在控制節(jié)點的時候我們在nova的配置文件中配置了neutron的節(jié)點選項,在neutron配置文件中配置了nova的選項。在計算節(jié)點的nova上要配置neutron
在計算節(jié)點配置Linuxbridge
配置網(wǎng)絡(luò)選項
友情提示:這里的配置和控制節(jié)點配置一模一樣
這里我們還是直接拷貝控制節(jié)點的/etc/neutron/plugins/ml2/linuxbridge_agent.ini
拷貝
[root@linux-node1 ~]# scp /etc/neutron/plugins/ml2/linuxbridge_agent.ini 192.168.56.12:/etc/neutron/plugins/ml2/root@192.168.56.12's password: linuxbridge_agent.ini查看
[root@linux-node2 ~]# ll /etc/neutron/plugins/ml2/linuxbridge_agent.ini-rw-r----- 1 root root 7924 Nov 21 16:26 /etc/neutron/plugins/ml2/linuxbridge_agent.ini[root@linux-node2 ~]# grep '^[a-z]' /etc/neutron/plugins/ml2/linuxbridge_agent.iniphysical_interface_mappings = public:eth0firewall_driver = neutron.agent.linux.iptables_firewall.IptablesFirewallDriverenable_security_group = trueenable_vxlan = false[root@linux-node2 ~]# chown -R root:neutron /etc/neutron/plugins/ml2/linuxbridge_agent.ini重啟計算節(jié)點nova-compute
啟動Linuxbridge
代理并設(shè)置開啟啟動
進入控制節(jié)點,進行檢查
[root@linux-node1 ~]# source admin-openstack.sh [root@linux-node1 ~]# neutron agent-list+---------------------+--------------------+---------------------+-------------------+-------+----------------+-------------------------+| id | agent_type | host | availability_zone | alive | admin_state_up | binary |+---------------------+--------------------+---------------------+-------------------+-------+----------------+-------------------------+| b41a9731-2bff-4257- | DHCP agent | linux- | nova | :-) | True | neutron-dhcp-agent || a3e9-91b13f568932 | | node1.abcdocker.com | | | | || de108bab-f33a-4319 | Linux bridge agent | linux- | | :-) | True | neutron-linuxbridge- || -8caf-dd5fbda74d7e | | node1.abcdocker.com | | | | agent || eb879cc3-ca1d-470b- | Linux bridge agent | linux- | | :-) | True | neutron-linuxbridge- || 9fe6-b0e5c2fedf2a | | node2.abcdocker.com | | | | agent || f8286325-19ad-43ae- | Metadata agent | linux- | | :-) | True | neutron-metadata-agent || a25a-c7c2ceca7aed | | node1.abcdocker.com | | | | |+---------------------+--------------------+---------------------+-------------------+-------+----------------+-------------------------+提示:如果網(wǎng)絡(luò)接口不是eth0
,你的配置文件沒有修改就會啟動不起來
故障解決套路:
1、netstat -lntup
確認端口是否監(jiān)聽
2、openstack service list
確保服務(wù)創(chuàng)建openstack endpoint list
確保三個endpoint
創(chuàng)建無誤
3、vim
修改配置文件debug=true
重啟 – 執(zhí)行命令 – 看日志
M版本中文文檔:http://docs.openstack.org/mitaka/zh_CN/install-guide-rdo/keystone-install.html
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。