一、实验目的
- 熟悉Linux基本服务配置;
- 理解OpenStack基本环境中各组件用途。
二、实验环境
- 实验资源 云主机Vultr、DigitalOCean等
- 软件环境 CentOS 7
三、实验内容
6.2.在 keystone 数据库中注册 neutron 相关服务
1)创建 neutron 数据库,授予权限 mysql -p123456 CREATE DATABASE neutron; GRANT ALL PRIVILEGES ON neutron.* TO ‘neutron’@‘localhost’ IDENTIFIED BY ‘neutron’; GRANT ALL PRIVILEGES ON neutron.* TO ‘neutron’@’%’ IDENTIFIED BY ‘neutron’; exit data:image/s3,"s3://crabby-images/e82e9/e82e99d9d6d08ae0d9ddb0e9409e84c71a6173d4" alt="在这里插入图片描述" 2)在 keystone 上创建 neutron 用户 source admin-openrc openstack user create --domain default --password=neutron neutron openstack user list data:image/s3,"s3://crabby-images/2b90a/2b90a79ba951217e5a933fa0aaaff550bd891757" alt="在这里插入图片描述" 3)将 neutron 添加到 service 项目并授予 admin 角色 该命令无输出 openstack role add --project service --user neutron admin data:image/s3,"s3://crabby-images/ac22d/ac22dcb6fd754b30c466ccee8a69621dbb580e1e" alt="在这里插入图片描述" 4)创建 neutron service openstack service create --name neutron --description “OpenStack Networking” network openstack service list data:image/s3,"s3://crabby-images/e9fd4/e9fd4fa5972ac3688b76507cdf08058a57fe781a" alt="在这里插入图片描述" 5)创建 neutron 网络服务的 API 端点 openstack endpoint create --region RegionOne network public http://controller:9696 openstack endpoint create --region RegionOne network internal http://controller:9696 openstack endpoint create --region RegionOne network admin http://controller:9696 openstack endpoint list data:image/s3,"s3://crabby-images/54b16/54b16ad90ba7620fbcf9b04b6b9a39e66102a8d4" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/500ba/500ba6c7fe71a3cd4bb694583c872a83ba984dbc" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f3fcd/f3fcd6942093a021a5a41a9488c2c6ced3cefacc" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/36a6f/36a6f2a98d8c32fdee80de7ef88410cb9d541e80" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/eb0c5/eb0c593757ac2fe9a56f5e4c2c29c0c58a07d358" alt="在这里插入图片描述"
6.3.在控制节点安装 neutron 网络组件 neutron 的网络提供了两种方式
https://docs.openstack.org/neutron/rocky/install/controller-install-option1-rdo.html 以下为第一种 Networking Option 1: Provider networks 1)安装 neutron 软件包 yum install openstack-neutron openstack-neutron-ml2 openstack-neutron-linuxbridge ebtables -y data:image/s3,"s3://crabby-images/75bce/75bce96d477948f6a30acc24ef54f9b1920ae2a3" alt="在这里插入图片描述" 2)快速配置 /etc/neutron/neutron.conf openstack-config --set /etc/neutron/neutron.conf database connection mysql+pymysql://neutron:neutron@controller/neutron openstack-config --set /etc/neutron/neutron.conf DEFAULT core_plugin ml2 openstack-config --set /etc/neutron/neutron.conf DEFAULT service_plugins openstack-config --set /etc/neutron/neutron.conf DEFAULT transport_url rabbit://openstack:openstack@controller openstack-config --set /etc/neutron/neutron.conf DEFAULT auth_strategy keystone openstack-config --set /etc/neutron/neutron.conf keystone_authtoken www_authenticate_uri http://controller:5000 openstack-config --set /etc/neutron/neutron.conf keystone_authtoken auth_url http://controller:5000 openstack-config --set /etc/neutron/neutron.conf keystone_authtoken memcached_servers controller:11211 openstack-config --set /etc/neutron/neutron.conf keystone_authtoken auth_type password openstack-config --set /etc/neutron/neutron.conf keystone_authtoken project_domain_name default openstack-config --set /etc/neutron/neutron.conf keystone_authtoken user_domain_name default openstack-config --set /etc/neutron/neutron.conf keystone_authtoken project_name service openstack-config --set /etc/neutron/neutron.conf keystone_authtoken username neutron openstack-config --set /etc/neutron/neutron.conf keystone_authtoken password neutron openstack-config --set /etc/neutron/neutron.conf DEFAULT notify_nova_on_port_status_changes True openstack-config --set /etc/neutron/neutron.conf DEFAULT notify_nova_on_port_data_changes True openstack-config --set /etc/neutron/neutron.conf nova auth_url http://controller:5000 openstack-config --set /etc/neutron/neutron.conf nova auth_type password openstack-config --set /etc/neutron/neutron.conf nova project_domain_name default openstack-config --set /etc/neutron/neutron.conf nova user_domain_name default openstack-config --set /etc/neutron/neutron.conf nova region_name RegionOne openstack-config --set /etc/neutron/neutron.conf nova project_name service openstack-config --set /etc/neutron/neutron.conf nova username nova openstack-config --set /etc/neutron/neutron.conf nova password nova openstack-config --set /etc/neutron/neutron.conf oslo_concurrency lock_path /var/lib/neutron/tmp 查看配置 egrep -v ‘($|#)’ /etc/neutron/neutron.conf data:image/s3,"s3://crabby-images/9dd8b/9dd8b71b869f9bbc2054860f1728ddf97da3ac37" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/09426/09426d9d86884bab411082ba36ca1308d08b3095" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/ba71a/ba71abd3ab8e1d88fada8ef1bd61e6c67bc55042" alt="在这里插入图片描述"
3)快速配置/etc/neutron/plugins/ml2/ml2_conf.ini openstack-config --set /etc/neutron/plugins/ml2/ml2_conf.ini ml2 type_drivers flat,vlan openstack-config --set /etc/neutron/plugins/ml2/ml2_conf.ini ml2 tenant_network_types openstack-config --set /etc/neutron/plugins/ml2/ml2_conf.ini ml2 mechanism_drivers linuxbridge openstack-config --set /etc/neutron/plugins/ml2/ml2_conf.ini ml2 extension_drivers port_security openstack-config --set /etc/neutron/plugins/ml2/ml2_conf.ini ml2_type_flat flat_networks provider openstack-config --set /etc/neutron/plugins/ml2/ml2_conf.ini securitygroup enable_ipset True 查看配置 egrep -v ‘($|#)’ /etc/neutron/plugins/ml2/ml2_conf.ini data:image/s3,"s3://crabby-images/bbf3c/bbf3c76c3d820db510c2c146ff640113382eab3e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f8c81/f8c816a676a72fcc3592558a41245ee7a8adca5c" alt="在这里插入图片描述"
4)快速配置/etc/neutron/plugins/ml2/linuxbridge_agent.ini openstack-config --set /etc/neutron/plugins/ml2/linuxbridge_agent.ini linux_bridge physical_interface_mappings provider:enp0s8 openstack-config --set /etc/neutron/plugins/ml2/linuxbridge_agent.ini vxlan enable_vxlan False openstack-config --set /etc/neutron/plugins/ml2/linuxbridge_agent.ini securitygroup enable_security_group True openstack-config --set /etc/neutron/plugins/ml2/linuxbridge_agent.ini securitygroup firewall_driver neutron.agent.linux.iptables_firewall.IptablesFirewallDriver 查看配置 egrep -v ‘($|#)’ /etc/neutron/plugins/ml2/linuxbridge_agent.ini
参数在启动 neutron-linuxbridge-agent.service 的时候会自动设置为 1 sysctl net.bridge.bridge-nf-call-iptables sysctl net.bridge.bridge-nf-call-ip6tables data:image/s3,"s3://crabby-images/a4311/a43111c88bdf3f1bb523e0d0bc9cb00cc1d0b8e0" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0ce2d/0ce2dc1ee4ad1bc665882f386ea8ac47918a3630" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/b53c2/b53c28265b4fd74de7cd6b75dda2f18dcca3668b" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/38e3c/38e3cb64b9f091d5ded1ccad6f886726e314effc" alt="在这里插入图片描述" 5)快速配置/etc/neutron/dhcp_agent.ini openstack-config --set /etc/neutron/dhcp_agent.ini DEFAULT interface_driver linuxbridge openstack-config --set /etc/neutron/dhcp_agent.ini DEFAULT dhcp_driver neutron.agent.linux.dhcp.Dnsmasq openstack-config --set /etc/neutron/dhcp_agent.ini DEFAULT enable_isolated_metadata True 查看配置 egrep -v ‘($|#)’ /etc/neutron/dhcp_agent.ini data:image/s3,"s3://crabby-images/d5837/d583759560cb5adbcba93890a2d9e4b9777f7538" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/03a3d/03a3de2754297daf6a82d355017da3e3022f681e" alt="在这里插入图片描述"
6)快速配置/etc/neutron/metadata_agent.ini openstack-config --set /etc/neutron/metadata_agent.ini DEFAULT nova_metadata_host controller openstack-config --set /etc/neutron/metadata_agent.ini DEFAULT metadata_proxy_shared_secret neutron 查看配置 egrep -v ‘($|#)’ /etc/neutron/metadata_agent.ini data:image/s3,"s3://crabby-images/abd6b/abd6b5c073d6d7dd85b2a8036650e191bac67354" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d76dc/d76dc3a5e7584d37581a803cbd3a86da07611392" alt="在这里插入图片描述"
7)配置计算服务使用网络服务 快速配置/etc/nova/nova.conf,将 neutron 添加到计算节点中 openstack-config --set /etc/nova/nova.conf neutron url http://controller:9696 openstack-config --set /etc/nova/nova.conf neutron auth_url http://controller:5000 openstack-config --set /etc/nova/nova.conf neutron auth_type password openstack-config --set /etc/nova/nova.conf neutron project_domain_name default openstack-config --set /etc/nova/nova.conf neutron user_domain_name default openstack-config --set /etc/nova/nova.conf neutron region_name RegionOne openstack-config --set /etc/nova/nova.conf neutron project_name service openstack-config --set /etc/nova/nova.conf neutron username neutron openstack-config --set /etc/nova/nova.conf neutron password neutron openstack-config --set /etc/nova/nova.conf neutron service_metadata_proxy true openstack-config --set /etc/nova/nova.conf neutron metadata_proxy_shared_secret neutron 查看配置 egrep -v ‘($|#)’ /etc/nova/nova.conf data:image/s3,"s3://crabby-images/55942/55942935d8e4ba10737129c622a608a72db441b3" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/b0682/b0682ca5bd7e4060f94363491d91b1b60301f09c" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f2323/f2323c3ae17638722f9a44218307006a641ab2bb" alt="在这里插入图片描述" 8)初始化安装网络插件 创建网络插件的链接,初始化网络的脚本插件会用到/etc/neutron/plugin.ini,需要使用 ML2 的插件进行提供 ln -s /etc/neutron/plugins/ml2/ml2_conf.ini /etc/neutron/plugin.ini data:image/s3,"s3://crabby-images/1f020/1f0205a5ad7f28221efde91a2f753e05adadf689" alt="在这里插入图片描述" 9)同步数据库 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 data:image/s3,"s3://crabby-images/55d0f/55d0fe47ad19a6e2c1f175ca66cdc9bde900a46f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/942d3/942d398e52f65ba6fce30bbc9f54f77717fa4d19" alt="在这里插入图片描述" 10)重启 nova_api 服务 systemctl restart openstack-nova-api.service data:image/s3,"s3://crabby-images/cab07/cab07e423dbecbb50da5f4b0f5d5419d6fa2595d" alt="在这里插入图片描述" 11)启动 neutron 服务并设置开机启动 启动 4 个服务 systemctl start neutron-server.service neutron-linuxbridge-agent.service neutron-dhcp-agent.service neutron-metadata-agent.service systemctl status neutron-server.service neutron-linuxbridge-agent.service neutron-dhcp-agent.service neutron-metadata-agent.service systemctl enable neutron-server.service neutron-linuxbridge-agent.service neutron-dhcp-agent.service neutron-metadata-agent.service systemctl list-unit-files |grep neutron* |grep enabled data:image/s3,"s3://crabby-images/b1797/b1797d81fe8a9a0981c0bb78d7a8a81aa4cbcb30" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/4c401/4c401e3e32411211f60e56c125bd6303416ceedf" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c620d/c620dc9d46f2e1a34eb1247d6889f290c6d8c675" alt="在这里插入图片描述"
6.4.在计算节点安装 neutron 网络组件
#Install and configure compute node https://docs.openstack.org/neutron/rocky/install/compute-install-rdo.html 1)安装 neutron 组件 yum install openstack-neutron-linuxbridge ebtables ipset -y data:image/s3,"s3://crabby-images/c9147/c9147b8fb4a710bd71233fa31d73a65949620569" alt="在这里插入图片描述" 2)快速配置/etc/neutron/neutron.conf openstack-config --set /etc/neutron/neutron.conf DEFAULT transport_url rabbit://openstack:openstack@controller openstack-config --set /etc/neutron/neutron.conf DEFAULT auth_strategy keystone openstack-config --set /etc/neutron/neutron.conf keystone_authtoken www_authenticate_uri http://controller:5000 openstack-config --set /etc/neutron/neutron.conf keystone_authtoken auth_url http://controller:5000 openstack-config --set /etc/neutron/neutron.conf keystone_authtoken memcached_servers controller:11211 openstack-config --set /etc/neutron/neutron.conf keystone_authtoken auth_type password openstack-config --set /etc/neutron/neutron.conf keystone_authtoken project_domain_name default openstack-config --set /etc/neutron/neutron.conf keystone_authtoken user_domain_name default openstack-config --set /etc/neutron/neutron.conf keystone_authtoken project_name service openstack-config --set /etc/neutron/neutron.conf keystone_authtoken username neutron openstack-config --set /etc/neutron/neutron.conf keystone_authtoken password neutron openstack-config --set /etc/neutron/neutron.conf oslo_concurrency lock_path /var/lib/neutron/tmp 查看配置 egrep -v ‘($|#)’ /etc/neutron/neutron.conf data:image/s3,"s3://crabby-images/0ee9f/0ee9f11fc25cb61f1dff993b66966cde1b5c0cfe" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/e7a14/e7a14e909eb839bd30e12cad88aa78b72c794fd9" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/8dbdd/8dbdd15d1aee43325f09d96f8724f7ced488af73" alt="在这里插入图片描述"
3)快速配置/etc/neutron/plugins/ml2/linuxbridge_agent.ini openstack-config --set /etc/neutron/plugins/ml2/linuxbridge_agent.ini linux_bridge physical_interface_mappings provider:enp0s8 openstack-config --set /etc/neutron/plugins/ml2/linuxbridge_agent.ini vxlan enable_vxlan false openstack-config --set /etc/neutron/plugins/ml2/linuxbridge_agent.ini securitygroup enable_security_group true openstack-config --set /etc/neutron/plugins/ml2/linuxbridge_agent.ini securitygroup firewall_driver neutron.agent.linux.iptables_firewall.IptablesFirewallDriver 第一个选项 physical_interface_mappings 选项要配置计算节点自身的网卡名称 provider:enp0s8 查看配置 egrep -v ‘($|#)’ /etc/neutron/plugins/ml2/linuxbridge_agent.ini data:image/s3,"s3://crabby-images/828fa/828fa59ca5294b6b13b2fd253f8195ae942f5965" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/bd397/bd39747758248a553f386d0b15c524c445d3370f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/12447/124479fe421aa01bbb3e3959ed432191bc74aa14" alt="在这里插入图片描述"
4)配置 nova 计算服务与 neutron 网络服务协同工作 快速配置/etc/nova/nova.conf openstack-config --set /etc/nova/nova.conf neutron url http://controller:9696 openstack-config --set /etc/nova/nova.conf neutron auth_url http://controller:5000 openstack-config --set /etc/nova/nova.conf neutron auth_type password openstack-config --set /etc/nova/nova.conf neutron project_domain_name default openstack-config --set /etc/nova/nova.conf neutron user_domain_name default openstack-config --set /etc/nova/nova.conf neutron region_name RegionOne openstack-config --set /etc/nova/nova.conf neutron project_name service openstack-config --set /etc/nova/nova.conf neutron username neutron openstack-config --set /etc/nova/nova.conf neutron password neutron 查看配置 egrep -v ‘($|#)’ /etc/nova/nova.conf data:image/s3,"s3://crabby-images/ec9ec/ec9ecabbac7503234cc0d2a224808e0a15e9c941" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/77fac/77fac16b283e195d5614bf3cd47768cc158ed16e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/87eaf/87eaf75a71b3d3b875b96ad17eb3437beb8662be" alt="在这里插入图片描述" 5)重启计算节点 systemctl restart openstack-nova-compute.service systemctl status openstack-nova-compute.service data:image/s3,"s3://crabby-images/d3dd2/d3dd2905a1eb973e77e190e86987c65e791210ea" alt="在这里插入图片描述" 6)启动 neutron 网络组件,并配置开机自启动 需启动 1 个服务 systemctl start neutron-linuxbridge-agent.service systemctl status neutron-linuxbridge-agent.service systemctl enable neutron-linuxbridge-agent.service systemctl list-unit-files |grep neutron* |grep enabled data:image/s3,"s3://crabby-images/8c291/8c2917114faf118fcc71947599b1b04dc96f2ade" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/3b28f/3b28f420b1c0ce79c2aa99630af00551824f62dd" alt="在这里插入图片描述"
6.5.在控制节点检查确认 neutron 服务安装成功
#Verify operation https://docs.openstack.org/neutron/rocky/install/verify.html 以下命令在控制节点执行 1)获取管理权限 source admin-openrc data:image/s3,"s3://crabby-images/73944/739443017bb26552941c333a4a31447e6870ccc9" alt="在这里插入图片描述" 2)列表查看加载的网络插件 openstack extension list --network data:image/s3,"s3://crabby-images/1b84a/1b84a332fd25fe8414ede11dbd1b6223f5f1d682" alt="在这里插入图片描述" 3)查看网络代理列表 openstack network agent list data:image/s3,"s3://crabby-images/72811/7281118ce072c098ae755ee4241736b00960f451" alt="在这里插入图片描述" 正常情况下:控制节点有 3 个服务,计算节点有 1 个服务
总结
一、Neutron概述 ??Neutron是 OpenStack项目中负责提供网络服务的组件,它基于软件定义网络的思想,实现了网络虚拟化下的资源管理。Neutron 的设计目标是实现“网络即服务(Networking as a Service)”,在设计上遵循了基于 SDN 实现网络虚拟化的原则,在实现上充分利用了 Linux 系统上的各种网络相关的技术。 二、Neutron功能
- 二层交换
Neutron支持多种虚拟交换机,一般使用Linux Bridge和Open vSwitch创建传统的VLAN网络,以及基于隧道技术的Overlay网络,如VxLAN和GRE(Linux Bridge 目前只支持 VxLAN)。 - 三层路由
Neutron从Juno版开始正式加入的DVR(Distributed Virtual Router)服务,它将原本集中在网络节点的部分服务分散到了计算节点上。可以通过namespace中使用ip route或者iptables实现路由或NAT,也可以通过openflow给OpenvSwitch下发流表来实现。 - 负载均衡
LBaaS 支持多种负载均衡产品和方案,不同的实现以 Plugin 的形式集成到 Neutron,通过HAProxy来实现。 - 防火墙
Neutron有两种方式来保障instance和网络的安全性,分别是安全组以及防火墙功能,均可以通过iptables来实现,前者是限制进出instance的网络包,后者是进出虚拟路由器的网络包。 三、Network - Local
Local网络,本地的一个Linux Bridge,除了虚拟机的虚拟网卡不连接其他的网络设备,实际场景很少使用,可以忽略。 - Flat
Flat网络,不带vlan tag的网络,相当于Local网络的Linux Bridge连接到一个物理网卡,该网络中的instance能与同网络的instance通信,且可以跨多个节点,实际场景也很少用到。 - VLAN
VlAN网络,可以跨节点,目前是私有云网络应用较多。 - VXALN
VXLAN网络,是基于隧道技术的 overlay 网络,通过唯一的VNI区分于其他 vxlan 网络。vxlan中数据包通过VNI封装成UPD包进行传输,因为二层的包通过封装在三层传输,能够克服vlan和物理网络基础设施的限制。 - GRE
GRE网络,与vxlan类似的一种overlay网络,使用IP包进行封装。 四、Neutron架构 Neutron采用分布式架构,由多个组件共同对外提供网络服务,如下图所示: data:image/s3,"s3://crabby-images/f37b1/f37b187d14e5879ceba94ead88390e34a6de7cbe" alt="在这里插入图片描述" 由上图可以看到Neutron有以下组件构成: 1.Neutron Server:对外提供OpenStack网络API,接收请求,并调用Plugin处理请求。 2.Plugin:处理Neutron Server发来的请求,维护OpenStack逻辑网络的状态,并调用Agent处理请求。 3.Agent:处理Plugin的请求,负责在Network Provider上真正实现各种网络功能。 4.Network Provider:提供网络服务的虚拟或者物理网络设备,比如Linux Bridge,OpenVSwitch或者其他支持Neutron的物理交换机。 5.Queue:Neutron Server,Plugin和Agent之间通过Messaging Queue通信和调用。 6.Database:存放OpenStack的网络状态信息,包括Network,Subnet,Port,Router等。 data:image/s3,"s3://crabby-images/b401a/b401a731a48ee01cb9337f38a484013362493cdb" alt="在这里插入图片描述" 1.Neutron通过Plugin和Agent提供的网络服务。 2.Plugin位于Neutron Server,包括Core Plugin和Service Plugin。 3.Agent位于各个节点,负责实现网络服务。 4.Core Plugin提供L2功能,ML2是推荐的plugin。 5.使用最广泛的L2 Agent是Linux Bridage和OpenvSwitch。 6.Service Plugin和Agent提供扩展功能,包括DHCP, Routing, Load Balancer, Firewall, VPN等。
|