目录
一、实验
1.环境
(1) 主机
表1 主机
|------------|-------|-----------------|-----|
| 主机 | 架构 | IP | 备注 |
| controller | 控制节点 | 192.168.204.210 | 已部署 |
| compute01 | 计算节点1 | 192.168.204.211 | 已部署 |
| compute02 | 计算节点2 | 192.168.204.212 | 已部署 |
| storage01 | 存储节点1 | 192.168.204.221 | 已部署 |
| storage02 | 存储节点2 | 192.168.204.222 | 已部署 |
| nas | nfs节点 | 192.168.204.229 | 已部署 |
(2)官网
OpenStack Docs: OpenStack Installation Guide for Red Hat Enterprise Linux and CentOS
2.各节点新增网卡准备VXLAN网络
(1)控制节点修改eth1网卡
data:image/s3,"s3://crabby-images/6be1d/6be1d5922ba6e6260a249eb6cf21b738e1eece40" alt=""
(2)计算节点1修改eth1网卡
data:image/s3,"s3://crabby-images/a8a47/a8a473f4dfe0c0e41a2ce861dfbda45d4daa8062" alt=""
(3)计算节点2修改eth1网卡
data:image/s3,"s3://crabby-images/a551d/a551d5a53e6fb4891efe5e1b08a3258a6f7b116d" alt=""
(4)控制节点新增网络 ping 计算节点新增网络
data:image/s3,"s3://crabby-images/0d344/0d344a034f3687cec8d6ad965cba86e1a18ce5c4" alt=""
data:image/s3,"s3://crabby-images/30a68/30a685803c4118f866a26388fd79a7bb2a25256c" alt=""
3.控制节点配置私有网络
(1)编辑/etc/neutron/neutron.conf 文件
① 在[DEFAULT]部分,启用Modular Layer 2 (ML2)插件,路由服务和重叠的IP地址
bash
[DEFAULT]
...
service_plugins = router
allow_overlapping_ips = True
②备份修改
(2)配置 Modular Layer 2 (ML2) 插件,编辑/etc/neutron/plugins/ml2/ml2_conf.ini文件
① 在[ml2]部分,启用flat,VLAN以及VXLAN网络:
bash
[ml2]
...
type_drivers = flat,vlan,vxlan
② 在[ml2]部分,启用VXLAN私有网络
bash
[ml2]
...
tenant_network_types = vxlan
③ 在[ml2]部分,启用Linuxbridge和layer-2机制
bash
[ml2]
...
mechanism_drivers = linuxbridge,l2population
④ 在[ml2]部分,启用端口安全扩展驱动:
bash
[ml2]
...
extension_drivers = port_security
⑤ 在[ml2_type_vxlan]部分,为私有网络配置VXLAN网络识别的网络范围:
bash
[ml2_type_vxlan]
...
vni_ranges = 20000:30000
⑥备份修改
(3)配置Linuxbridge代理,编辑/etc/neutron/plugins/ml2/linuxbridge_agent.ini文件
① 在[vxlan]部分,启用VXLAN覆盖网络,配置覆盖网络的物理网络接口的IP地址,启用layer-2 population:
bash
[vxlan]
enable_vxlan = True
local_ip = 192.168.199.210
l2_population = True
② 直接修改
(4)配置layer-3代理,编辑/etc/neutron/l3_agent.ini文件
① 在[DEFAULT]部分,配置Linuxbridge接口驱动和外部网络网桥:
bash
[DEFAULT]
...
interface_driver = neutron.agent.linux.interface.BridgeInterfaceDriver
external_network_bridge =
② 直接修改
data:image/s3,"s3://crabby-images/fc65d/fc65d2763be16c4a961581e06977fa73dd98cd70" alt=""
data:image/s3,"s3://crabby-images/b5cc4/b5cc4cdba83229742a9765313fc5814b696885dc" alt=""
4.计算节点1配置私有网络
(1)配置Linuxbridge代理,编辑/etc/neutron/plugins/ml2/linuxbridge_agent.ini文件
①在[vxlan]部分,启用VXLAN覆盖网络,配置覆盖网络的物理网络接口的IP地址,启用layer-2 population:
bash
[vxlan]
enable_vxlan = True
local_ip = 192.168.199.211
l2_population = True
② 直接修改
data:image/s3,"s3://crabby-images/376ef/376ef6d8dcb41dcb43bd38c960b891cf1c5b2b3f" alt=""
data:image/s3,"s3://crabby-images/73620/736206eee6b15de9c436b653715615120975c634" alt=""
5.计算节点2配置私有网络
(1)配置Linuxbridge代理,编辑/etc/neutron/plugins/ml2/linuxbridge_agent.ini文件
① 在[vxlan]部分,启用VXLAN覆盖网络,配置覆盖网络的物理网络接口的IP地址,启用layer-2 population:
bash
[vxlan]
enable_vxlan = True
local_ip = 192.168.199.212
l2_population = True
② 直接修改
data:image/s3,"s3://crabby-images/72d88/72d880332d170eae8d64edeedaab0085b2df0d2b" alt=""
data:image/s3,"s3://crabby-images/c3966/c3966982e3c0b29fc4862d358a00bf9cf75139f5" alt=""
6.重启服务
(1)控制节点重启服务
bash
[root@controller network-scripts]# systemctl restart neutron-server.service \
> neutron-linuxbridge-agent.service neutron-dhcp-agent.service \
> neutron-metadata-agent.service
[root@controller network-scripts]# systemctl enable neutron-l3-agent.service
Created symlink from /etc/systemd/system/multi-user.target.wants/neutron-l3-agent.service to /usr/lib/systemd/system/neutron-l3-agent.service.
[root@controller network-scripts]# systemctl start neutron-l3-agent.service
data:image/s3,"s3://crabby-images/3d528/3d52866a8fc689ccf3985751ce68b9f77cd574a3" alt=""
(2)计算节点1重启服务
bash
[root@compute01 network-scripts]# systemctl restart neutron-linuxbridge-agent.service
data:image/s3,"s3://crabby-images/c2346/c234690b8210b80fff01a60ebcabc07cdec1bd61" alt=""
(3)计算节点2重启服务
bash
[root@compute02 network-scripts]# systemctl restart neutron-linuxbridge-agent.service
data:image/s3,"s3://crabby-images/7caf1/7caf108f742ab3441dea04cb343ce281193d615c" alt=""
(4)新增L3代理
bash
[root@controller network-scripts]# neutron agent-list
data:image/s3,"s3://crabby-images/f2ecb/f2ecbdd5d1742ad063c38d84a25c4fd51072317b" alt=""
7.修改Dashboard
(1)查看系统网络功能,目前暂无路由功能
data:image/s3,"s3://crabby-images/dd09b/dd09bb1076b35671d8b5fbe004560e723eb705bd" alt=""
(2)控制节点编辑文件 /etc/openstack-dashboard/local_settings
bash
[root@controller ~]# vim /etc/openstack-dashboard/local_settings
① 修改前
data:image/s3,"s3://crabby-images/68e5a/68e5aae48972f8bf236c5d43f053338b0671c357" alt=""
②修改后
data:image/s3,"s3://crabby-images/1d6b9/1d6b9516b2109cc703cd1d973fcb19a7d4a9b2a7" alt=""
(3)重启服务
bash
[root@controller ~]# systemctl restart httpd.service memcached.service
data:image/s3,"s3://crabby-images/e431d/e431d555cc72b3a83b59df54fe6cdb5c932f3e7c" alt=""
(4)重新登录
data:image/s3,"s3://crabby-images/a73fa/a73fac546add67d46dfbf763e20cf04042c189cf" alt=""
(5)网络新增路由器功能
data:image/s3,"s3://crabby-images/eb708/eb708e56d85b1570d9de2c71f77e523f87442398" alt=""
data:image/s3,"s3://crabby-images/3e8d5/3e8d50ededceaaefb3a8da8444d9809519b28850" alt=""
8.新建项目(租户)及用户
(1)新建项目
bash
[root@controller ~]# openstack project create --domain default devops03
data:image/s3,"s3://crabby-images/6d1a4/6d1a4b3f6a24d462f13bafeb00ca14ff5467594c" alt=""
(2)新建用户
bash
[root@controller ~]# openstack user create --domain default --password Admin@123 --project devops03 user01
data:image/s3,"s3://crabby-images/700dd/700dd1d6d433e99a32ca47e3543f7e865af4f3c8" alt=""
(3)修改配置文件
bash
[root@controller ~]# vim keystone_user01
(4)创建角色并关联
bash
[root@controller ~]# openstack role create user
[root@controller ~]# openstack role add --project devops03 --user user01 user
data:image/s3,"s3://crabby-images/681f1/681f15799fdb131bd1d63d68193304b7f535bb35" alt=""
(5)浏览器新建Private窗口
data:image/s3,"s3://crabby-images/2d95a/2d95a918225ca9393595cb20ccef5fba98cb9289" alt=""
(6)用户user01登录
data:image/s3,"s3://crabby-images/ddc51/ddc51f6b70f2432e6b59e5689e58f237d01ef259" alt=""
(7)登录成功
data:image/s3,"s3://crabby-images/b7c90/b7c906dfa7f847a52bffb6899a8fdbcb0d311ab1" alt=""
9.新建网络与子网
(1)查看网络
data:image/s3,"s3://crabby-images/e2116/e2116a87fafced9f494939f90575599d9e5b93b2" alt=""
(2)查看网络拓扑
data:image/s3,"s3://crabby-images/58173/581735cb2a438ec77fee65461f66f62fac324407" alt=""
(3)创建测试网络
data:image/s3,"s3://crabby-images/7783b/7783b3514109fe70869c8a1cffc1572d10fc1ffa" alt=""
(4)完成创建
data:image/s3,"s3://crabby-images/9a103/9a1032f7c295f06634322aa255d7bd2ad2a48f9a" alt=""
(5)控制节点查看网络
bash
[root@controller ~]# neutron net-show test_user_network | grep provider
data:image/s3,"s3://crabby-images/cfd20/cfd2027592cee51867da76436cf256e0c56b1cea" alt=""
(6)修改网络名称
data:image/s3,"s3://crabby-images/d083a/d083a3d8717f330f893f4da4880b7537299636f8" alt=""
(7)完成更新
data:image/s3,"s3://crabby-images/24e88/24e886c635c1eb2b0cb338ebd949271f58e34751" alt=""
(8)新建子网(切换user01用户所在项目环境)
bash
[root@controller ~]# source keystone_user01
[root@controller ~]# neutron subnet-create --name vxlan_subnet_01 \
> --allocation-pool start=172.16.100.50,end=172.16.100.59 \
> --dns-nameserver 8.8.8.8 \
> --gateway 172.16.100.254 \
> Vxlan_user_network01 172.16.100.0/24
data:image/s3,"s3://crabby-images/cb65d/cb65d29b132f9d8bbf0df242cffe005f03fb30f1" alt=""
(9)查看
data:image/s3,"s3://crabby-images/c02a8/c02a87a8a2240eb847beef616a0eaab18ff411b8" alt=""
10.新建实例
(1)控制节点新建实例cloud-server-vxlan01-01
bash
[root@controller ~]# nova boot --flavor m2.micro --image cirros --nic net-name=Vxlan_user_network01 --security-group default cloud-server-vxlan01-01
(2)新建实例cloud-server-vxlan01-03
bash
[root@controller ~]# nova boot --flavor m2.micro --image cirros --nic net-name=Vxlan_user_network01 --security-group default cloud-server-vxlan01-03
data:image/s3,"s3://crabby-images/f2bcd/f2bcd4ed478ecca2233cd12da9f9c74ccadda4f7" alt=""
(3) 查看云主机列表
bash
[root@controller ~]# nova list
data:image/s3,"s3://crabby-images/c710d/c710d3ad9ae2389dc17cc6b33c2af16c78452a9f" alt=""
(4)查看
data:image/s3,"s3://crabby-images/94231/942319e145bfb1652c09fd93812dcf588faf01bf" alt=""
11.新建路由
(1)查看当前网络
data:image/s3,"s3://crabby-images/ea248/ea24841a2330c31117aa5d75555a239a51e6668b" alt=""
(2)查看当前网络拓扑
data:image/s3,"s3://crabby-images/93e8b/93e8babd31dcc9083870d4592cb3f81721edf0a8" alt=""
(3)admin管理员修改flat网络为外部网络
data:image/s3,"s3://crabby-images/f5f27/f5f272d7df8084e8216df42fb7ce82b7780adb80" alt=""
(4)再次查看网络拓扑
data:image/s3,"s3://crabby-images/ad731/ad7315a84c5120e6c431a5134f21045e0f3d2826" alt=""
(5)新建路由
bash
[root@controller ~]# neutron router-create router01
data:image/s3,"s3://crabby-images/67ccf/67ccf4bd6d3a5439064e5a8ba85c71b075b08c2f" alt=""
(6)查看路由器
data:image/s3,"s3://crabby-images/eb7fb/eb7fbef5ca96673c6d128c72d958fed5a14fd529" alt=""
(7)查看网络拓扑
data:image/s3,"s3://crabby-images/14473/14473e546caeaa6ca80df1672c7c18c964ab070e" alt=""
(8)查看网络列表
bash
[root@controller ~]# neutron net-list
data:image/s3,"s3://crabby-images/5f83e/5f83e22bbe2905ecdac11fd5e42965abc679db07" alt=""
(9)路由器添加外部网关
bash
[root@controller ~]# neutron router-gateway-set router01 flat_network_01
data:image/s3,"s3://crabby-images/0cd93/0cd93f94b6827ae004022b6ce32ee2d195bee797" alt=""
(10)查看网络拓扑
data:image/s3,"s3://crabby-images/f6c3a/f6c3a310a353e7383cdf4b01504326f1bb46925c" alt=""
(11)查看子网信息
bash
[root@controller ~]# neutron subnet-list
data:image/s3,"s3://crabby-images/d042f/d042f8728649c89c9e2adf808981521e7781c338" alt=""
(12)路由器添加内部网关
bash
[root@controller ~]# neutron router-interface-add router01 vxlan_subnet_01
data:image/s3,"s3://crabby-images/4f5ed/4f5ed4882c3760de6ad152b15d833366e73ec71b" alt=""
(13)查看网络拓扑
data:image/s3,"s3://crabby-images/6dc29/6dc29f408a1e541c9152821683b5f8cc38ead5e7" alt=""
(14)查看路由列表
bash
[root@controller ~]# neutron router-list
data:image/s3,"s3://crabby-images/62b73/62b733517b410675103d6026e98e6d38b404d775" alt=""
(15)查看路由器
data:image/s3,"s3://crabby-images/1cb42/1cb42d28c43d9c0ddfe1b1e0841f02bd0baf26e9" alt=""
(16)user01查看接口(devops03项目下用户只能看到内部接口)
data:image/s3,"s3://crabby-images/e8a22/e8a220f6a7403b9ddf2fa01cbc6520c4609f3705" alt=""
(17)admin查看接口(管理员用户能看到内外部接口)
data:image/s3,"s3://crabby-images/685d3/685d3e59f983a37650b86d22ee78cd9bfedd4fd5" alt=""
(18)查看交换机
data:image/s3,"s3://crabby-images/00f0d/00f0db32b150836cd54d7437524a869d4f69e0ad" alt=""
12.新增浮动IP关联云主机实例
(1)新增浮动IP
bash
[root@controller ~]# neutron floatingip-create flat_network_01
data:image/s3,"s3://crabby-images/2df68/2df686eada24e3e2ea5189715e1edeadee15759c" alt=""
(2)查看
bash
[root@controller ~]# neutron floatingip-list
data:image/s3,"s3://crabby-images/8688b/8688bdfac76adeedbfd5047756fbb4e1a0e2b072" alt=""
(3)查看云主机列表
bash
[root@controller ~]# nova list
data:image/s3,"s3://crabby-images/c57fa/c57fa701a7cbb512bb29d16a44d1bbacb065c6d9" alt=""
(4)查看端口列表
bash
[root@controller ~]# neutron port-list
data:image/s3,"s3://crabby-images/ac3b8/ac3b8465630f071dd6856a71a1286c1457f9552d" alt=""
(5)浮动IP关联云主机实例cloud-server-vxlan01-01(通过id绑定)
bash
[root@controller ~]# neutron floatingip-associate b4289c34-6cf4-4f16-abb4-303ed987ed0e 362c9a97-9ded-46bc-b16b-1b32f5da8e9b
data:image/s3,"s3://crabby-images/4b089/4b08973decf92abf9b6fb0dc95cd7cfd87dba840" alt=""
(6)查看
bash
[root@controller ~]# neutron floatingip-list
data:image/s3,"s3://crabby-images/74002/740024eec4c1a5e5484f1d4735dcb05eb90125e4" alt=""
(7)可视化界面查看实例(1台云主机都绑定浮动IP)
data:image/s3,"s3://crabby-images/5e49e/5e49e729956261abccc9c0f373925dca959cbc65" alt=""
(8)查看当前安全组
data:image/s3,"s3://crabby-images/2f62f/2f62f918154230b834d92d8360fbe0e58f161ddd" alt=""
data:image/s3,"s3://crabby-images/bc617/bc617bae69333bbc2de2721e0e4dd13e77eff388" alt=""
(9)新增安全组入口规则
bash
[root@controller ~]# openstack security group rule create --proto icmp default
[root@controller ~]# openstack security group rule create --proto tcp --dst-port 22 default
data:image/s3,"s3://crabby-images/bb38c/bb38c87838cc9fb6ef6de2225099fd7b62afed5a" alt=""
(10)查看安全组规则
data:image/s3,"s3://crabby-images/0680b/0680b48d5c611dc0ee626b24ef214e9e5874480f" alt=""
(11)新增浮动IP
bash
[root@controller ~]# neutron floatingip-create flat_network_01
data:image/s3,"s3://crabby-images/88ac0/88ac08ec9ea64c9a1fbcf7a1acfb03891a865a79" alt=""
(12)查看
bash
[root@controller ~]# neutron floatingip-list
data:image/s3,"s3://crabby-images/55e0f/55e0f54aad78c438577fa445fe034b25f5f8c53b" alt=""
(13)浮动IP关联云主机实例cloud-server-vxlan01-03(通过id绑定)
bash
[root@controller ~]# neutron floatingip-associate f9b14337-02c8-48d6-af95-1f36760c5742 fa224427-aa68-451b-bd12-708d6ac1ec84
data:image/s3,"s3://crabby-images/59687/596878c30cd187f7b94917e643f0692cc98360d1" alt=""
(14)查看
bash
[root@controller ~]# neutron floatingip-list
data:image/s3,"s3://crabby-images/9e42a/9e42a25ae7e19988e4ad060d8d9f35d9bb3efb9a" alt=""
(15)可视化界面查看实例(2台云主机都已绑定浮动IP)
data:image/s3,"s3://crabby-images/ed32c/ed32c346a90bf0434cf875ad443031689f0dc11b" alt=""
二、问题
1.私有网络主要组件相互关系
(1) Modular Layer 2 (ML2) 插件
bash
ML2插件使用Linuxbridge机制来为实例创建layer-2虚拟网络基础设施。
(2)Linuxbridge代理
bash
Linuxbridge代理为实例建立layer-2虚拟网络并且处理安全组规则。
(3)layer-3代理
bash
Layer-3代理为私有虚拟网络提供路由和NAT服务。
(4)DHCP代理
bash
DHCP代理为虚拟网络提供DHCP服务。
2.VXLAN底层如何实现
(1)查看实例cloud-server-vxlan01-01详细信息
bash
[root@controller ~]# nova show cloud-server-vxlan01-01
(2)查看实例cloud-server-vxlan01-03详细信息
bash
[root@controller ~]# nova show cloud-server-vxlan01-03
(3)查看各计算节点实例
data:image/s3,"s3://crabby-images/86538/865386a68fb6b9b6d1b2c627320bba8d6a18a8ba" alt=""
data:image/s3,"s3://crabby-images/35930/35930234468123ad9f8904fd0aa48dc2fb7f6112" alt=""
(4)获取2个云主机实例信息
data:image/s3,"s3://crabby-images/50895/5089523202a2c3abdb0de9660cd17269f26ccda8" alt=""
(5)查看交换机
data:image/s3,"s3://crabby-images/f751b/f751b8b5419bd60adadd1f6f50a6bb81aac68ab7" alt=""
(6)计算节点2查看交换机
data:image/s3,"s3://crabby-images/53c06/53c06e95784529e8f29498346e5b46d0eb1bd697" alt=""
(7)查看实例cloud-server-vxlan01-01配置文件
data:image/s3,"s3://crabby-images/71cb5/71cb529fdf3b3174581571a332a2ac380e1c48fd" alt=""
关键信息
data:image/s3,"s3://crabby-images/4bcf7/4bcf72a63e04c55bfa67bee0fe14edd66006c78a" alt=""
(8)查看实例cloud-server-vxlan01-03配置文件
关键信息