OpenStack Train版双节点安装(十三)启动实例
admin
2023-03-27 05:21:20
0

第十三部分 启动实例


预备知识:Linux Bridge网络模式

由于上节最后验证网络和这节启动实例需要使用到Linux Bridge,所以这里介绍下Linux Bridge的基本概念

假设宿主机上有一块与外网连接的物理网卡eth0 ,上面跑了一个虚拟机VM1,那么使用Linux Bridge,宿主机会创建一个Linux Bridge的bridge br0将物理网卡eth0和实例的虚拟网卡桥接起来。如下图所示,br0可以看成是一个虚拟交换机,vnet0可以看成是虚拟交换机上的一个端口。

OpenStack Train版双节点安装(十三)启动实例

具体的连接方式是:虚拟机的虚拟网卡(如果虚拟机的操作系统是linux,它的虚拟网卡名称也是eth0)——vnet0——br0——物理网卡eth0

在下面的安装中,我们会使用计算节点(可以看成是是实例的宿主机)的网卡eth2来桥接实例的虚拟网卡(实例如果安装的是linux系统,则其虚拟网卡名称是eth0)。

类似上面的架构,br0由neutron创建,使用的名称是类brq8c8dcd81-d3这样的,端口vnet0也由neutron创建,其名称类似tapfdf3a9b5-f8这样的其中包含有由neutron service plugin、agent创建的ip地址等信息。实例启动后,neutron会将该端口分配给实例。

这样,brq8c8dcd81-d3把宿主机的eth2,端口tapfdf3a9b5-f8和实例的虚拟网卡桥接起来,从而为实例提供网络访问。

OpenStack Train版双节点安装(十三)启动实例

具体来说就是这样连接的实例(实例的操作系统是linux系统的话)的虚拟网卡eth0——tapfdf3a9b5-f8——brq8c8dcd81-d3——宿主机(计算节点)的eth2

同理,如果再启动一个新实例,则neutron会在brq8c8dcd81-d3创建一个新的端口,tapxxxxxxx-xx,将其分配给该实例。

OpenStack Train版双节点安装(十三)启动实例

可见,类比vSphere,brq8c8dcd81-d3其实就是一个标准虚拟交换机,tapfdf3a9b5-f8就是上面的端口(端口组),eth2就是上行链路。


控制节点的网络底层配置

如上节最后所述,控制节点在创建虚拟网络时,会创建类似以上所说的brqxxxxx(xxxxx为虚拟网络ID的前11位)网桥,并且会创建一个dhcp-agent使用的端口tapxxxxx(xxxx为dhcp-agent的前几位),将物理网卡eth2和tap设备桥接起来。

在控制节点,使用brctl show 查看

brctl show

OpenStack Train版双节点安装(十三)启动实例

类似图上的显示才是正确的,如果后面没有eth2,后面创建实例将得不到ip地址。
请按如下步骤排查

(1)确认已经停止或者删除了NetworkManager软件包

systemctl stop NetworkManager
systemctl disable NetworkManager
yum remove NetworkManager -y

(2)重启网络

systemctl restart network


创建实例前的准备工作

创建实例类型

. admin-openrc
openstack flavor create --id 0 --vcpus 1 --ram 64 --disk 1 m1.nano

openstack flavor list


建立普通项目、用户,并赋予普通用户user角色。

openstack project create --domain default --description "ygj Project" ygj-project

openstack user create --domain default --password 123456 ygj

openstack role add --project ygj-projec --user ygj user


建立普通用户的环境变量脚本

vim ygj-openrc

加入:

export OS_PROJECT_DOMAIN_NAME=Default

export OS_USER_DOMAIN_NAME=Default

export OS_PROJECT_NAME=ygj-project

export OS_USERNAME=ygj

export OS_PASSWORD=123456

export OS_AUTH_URL=http://ct:5000/v3

export OS_IDENTITY_API_VERSION=3

export OS_IMAGE_API_VERSION=2


创建密钥对

 . ygj-openrc

ssh-keygen -q -N ""

openstack keypair create --public-key ~/.ssh/id_rsa.pub ygjkey

openstack keypair list


创建安全组规则

openstack security group rule create --proto icmp default

openstack security group rule create --proto tcp --dst-port 22 default


检查openstack的相关服务和配置

. ygj-openrc

openstack flavor list

openstack image list

openstack network list(复制下网络ID,后面使用)

OpenStack Train版双节点安装(十三)启动实例
记下的网络ID为:3903994e-3f22-4677-8c3a-5ea4edd90afb


openstack security group list


修改计算节点上的nova配置文件,避免创建实例时报无法分配网络的错误

vim /etc/nova/nova.conf

[DEFAULT]

vif_plugging_is_fatal = false

vif_plugging_timeout = 0

OpenStack Train版双节点安装(十三)启动实例


确认开启2个节点的eth2的混杂模式,使虚拟机能连接除本宿主机外的网络

yum install net-tools -y

ifconfig eth2 promisc

OpenStack Train版双节点安装(十三)启动实例


确认已经停止2个节点上的networkmanager服务,否则会影响桥接网络的建立。

systemctl stop NetworkManager

systemctl disable NetworkManager


再次检查控制节点上neutron的桥接网络配置是否正确

yum install bridge-utils -y

brctl show

OpenStack Train版双节点安装(十三)启动实例

一定要确认eth2已经桥接到brq上面。


创建并启动实例
创建实例的命令
openstack server create --flavor 实例类型 --image 来源的镜像 --nic net-id=PROVIDER_NET_ID --security-group 安全组名 --key-name 密钥对 实例名称

其中PROVIDER_NET_ID:上面openstack network list命令查到的网络ID

具体来说可以如下面的命令:

. ygj-openrc

openstack server create --flavor m1.nano --image cirros --nic net-id=3903994e-3f22-4677-8c3a-5ea4edd90afb --security-group default --key-name ygjkey cirros-instance1


命令成功执行后,稍等片刻,使用openstack server list 查看实例的创建状况

OpenStack Train版双节点安装(十三)启动实例

确认其Status为“ACTIVE”,Networks下面不为空

如果实例的Status一直为BULID或者ERROR,则需要检查计算节点nova的日志文件中的报错信息,然后加以解决,日志文件的路径为:/var/log/nova/nova-compute.log


计算节点的检查

上述命令创建实例后,计算节点的网络会发生如下变化

ip a

OpenStack Train版双节点安装(十三)启动实例

可以看到会多出一个brq的网桥和一个tap设备
其中brq的网桥和控制节点的同名,意味着它们的端口接在了同一个虚拟交换机上

tap设备即刚才创建的实例使用的端口(可以看成是)。

再使用brctl查看

brctl show

OpenStack Train版双节点安装(十三)启动实例

发现tap设备桥接到了网桥上。

但是,计算节点的eth2此时并没有桥接到这个brq上,但是再重启下网络和实例即可桥接,至于其具体原因不明(可能是openstack的bug或者是实验环境是vmware-workstation的原因)。

(1)重启计算节点网络

systemctl restart network

(2)在控制节点重启实例

openstack server reboot cirros-instance1

重启好之后再在计算节点使用brctl show查看

OpenStack Train版双节点安装(十三)启动实例

可以看到计算节点的eth2已经桥接到brq上。

检查下和实例的网络连接:

ping 10.8.20.53

OpenStack Train版双节点安装(十三)启动实例

说明实例已经能够获取ip地址。


在计算节点访问实例的控制台
查看正在运行的实例

virsh list

OpenStack Train版双节点安装(十三)启动实例

记下其id是2


进入实例的控制台

virsh console 2

这里的2就是上面记下的id

按回车,会出现实例的登录提示符,使用cirros用户和提示的密码登录

OpenStack Train版双节点安装(十三)启动实例

出现$提示符表明登录成功

OpenStack Train版双节点安装(十三)启动实例

使用ip a查看实例的ip

OpenStack Train版双节点安装(十三)启动实例

获取到了正确的ip。

还可以使用sudo passwd修改root密码,使用mount查看器磁盘挂载情况,其他操作不再赘述。

OpenStack Train版双节点安装(十三)启动实例

最后再检查下网络访问情况

ping 10.8.20.42

ping 10.8.20.41

ping www.baidu.com

OpenStack Train版双节点安装(十三)启动实例


按键盘上的“ctrl+]”键返回到计算节点的命令提示符。


再创建一个实例

在控制节点执行以下操作

. ygj-openrc

openstack server create --flavor m1.nano --image cirros --nic net-id=3903994e-3f22-4677-8c3a-5ea4edd90afb --security-group default --key-name ygjkey cirros-instance2

OpenStack Train版双节点安装(十三)启动实例

openstack server list

OpenStack Train版双节点安装(十三)启动实例

可以看到,新的实例已经是ACTIVE。获得的ip地址为10.8.20.51,并且可以ping通,说明实例创建成功。


使用dashboard查看实例的状态

使用前面建立普通用户ygj 密码123456登录dashboard(不要使用admin登录,将看不到任何实例),在实例处可以查看到创建的2个实例。
OpenStack Train版双节点安装(十三)启动实例

2个实例

OpenStack Train版双节点安装(十三)启动实例


也可以访问实例的控制台

OpenStack Train版双节点安装(十三)启动实例


至此,启动实例完成,下节将介绍怎么安装和配置centos7的实例。

相关内容

热门资讯

北京-东盟科技产业推介洽谈会举... 5月8日下午,由北京市贸促会主办的第二十八届科博会北京-东盟科技产业推介洽谈会在国家会议中心二期举办...
“氢能心脏”破解无人机续航难题 (来源:天津日报) 转自:天津日报 据新华社大连5月10日电(记者 蔡拥军 张博群)记者10日从中...
原创 4... 近日,根据多家科技媒体的消息,国内手机评测机构安兔兔公布了2026年4月份安卓手机好评榜TOP10。...
伊朗提议美方在30天内撤销对伊... 据伊朗方面10日消息,知情人士表示,伊朗在其向美方的提议中,要求美国财政部外国资产控制办公室在30天...
特朗普:伊朗的回应“完全不可接... 当地时间5月10日,美国总统特朗普在其社交媒体“真实社交”发文表示,他刚刚读了伊朗那些所谓的“代表”...
训练运行模式缺陷或致AI提供危... 据新华社伦敦5月9日电 英国《自然》杂志网站日前发表文章说,人工智能(AI)聊天机器人可能向用户提供...
原创 都... 其实也很简单,很大一部分人就是找不到成就感。 只能去信这些,几乎没有认知门槛啊。 智商75以上的人,...
“宇宙超级快递小哥”即将出发 ... 新一单“太空快递”即将发货! 近日 天舟十号完成转运和全区合练 各项发射准备工作全部就绪 我国第十艘...
美媒证实一艘美国商船遭伊朗无人... 新华社华盛顿5月10日电 (记者徐剑梅 黄强)据美国福克斯新闻数字网报道,一艘美国商船10日在波斯湾...
特朗普声称伊朗47年来一直在“... 美国总统特朗普于当地时间5月10日在社交媒体发文,“猛烈抨击”伊朗长期“玩弄”美国和世界,同时还痛批...