OpenStack Ussuri : Neutron Network (VXLAN)2020/06/08 |
Configure virtual networking by OpenStack Network Service (Neutron).
For example, configure VXLAN type of networking on here.
Before it, Configure basic settings on Control Node, Network Node, Compute Node.
Furthermore, this example is based on the environment that Network Node has 2 network interfaces.
------------+---------------------------+---------------------------+------------ | | | eth0|10.0.0.30 eth0|10.0.0.50 eth0|10.0.0.51 +-----------+-----------+ +-----------+-----------+ +-----------+-----------+ | [ Control Node ] | | [ Network Node ] | | [ Compute Node ] | | | | | | | | MariaDB RabbitMQ | | Open vSwitch | | Libvirt | | Memcached httpd | | L2 Agent | | Nova Compute | | Keystone Glance | | L3 Agent | | Open vSwitch | | Nova API | | Metadata Agent | | L2 Agent | | Neutron Server | | | | | | Metadata Agent | | | | | +-----------------------+ +-----------+-----------+ +-----------------------+ eth1|(UP with no IP) |
[1] | Change settings on Control Node. |
[root@dlp ~(keystone)]#
vi /etc/neutron/plugins/ml2/ml2_conf.ini # add a value to [tenant_network_types] [ml2] type_drivers = flat,vlan,gre,vxlan tenant_network_types = vxlan
# add to the end [ml2_type_flat] flat_networks = physnet1 [ml2_type_vxlan] vni_ranges = 1:1000 systemctl restart neutron-server |
[2] | Change settings on Network Node. |
# add bridge [root@network ~]# ovs-vsctl add-br br-eth1
# add [eth1] to the port of the bridge above # replace the interface name [eth1] to your own environment [root@network ~]# ovs-vsctl add-port br-eth1 eth1
[root@network ~]#
vi /etc/neutron/plugins/ml2/ml2_conf.ini # add a value to [tenant_network_types] [ml2] type_drivers = flat,vlan,gre,vxlan tenant_network_types = vxlan
# add to the end [ml2_type_flat] flat_networks = physnet1 [ml2_type_vxlan] vni_ranges = 1:1000
[root@network ~]#
vi /etc/neutron/plugins/ml2/openvswitch_agent.ini # add to the end
[agent]
tunnel_types = vxlan
prevent_arp_spoofing = True
[ovs]
# specify IP address of this host for [local_ip]
local_ip = 10.0.0.50
bridge_mappings = physnet1:br-eth1
[root@network ~]#
for service in dhcp-agent l3-agent metadata-agent openvswitch-agent; do
systemctl restart neutron-$service done # if Firewalld is running, stop it [root@network ~]# systemctl disable --now firewalld |
[3] | Change settings on Compute Node. |
[root@node01 ~]#
vi /etc/neutron/plugins/ml2/ml2_conf.ini # add a value to [tenant_network_types] [ml2] type_drivers = flat,vlan,gre,vxlan tenant_network_types = vxlan
# add to the end [ml2_type_flat] flat_networks = physnet1 [ml2_type_vxlan] vni_ranges = 1:1000
[root@node01 ~]#
vi /etc/neutron/plugins/ml2/openvswitch_agent.ini # add to the end
[agent]
tunnel_types = vxlan
prevent_arp_spoofing = True
[ovs]
# specify IP address of this host for [local_ip]
local_ip = 10.0.0.51
[root@node01 ~]#
systemctl restart neutron-openvswitch-agent
# if Firewalld is running, stop it [root@node01 ~]# systemctl disable --now firewalld |
[4] | Create a Virtual router. It's OK to work on any node. (This example is on Control Node) |
[root@dlp ~(keystone)]# openstack router create router01 +-------------------------+-------------------------------------------------------------------------+ | Field | Value | +-------------------------+-------------------------------------------------------------------------+ | admin_state_up | UP | | availability_zone_hints | | | availability_zones | | | created_at | 2020-06-05T06:33:24Z | | description | | | distributed | False | | external_gateway_info | null | | flavor_id | None | | ha | False | | id | 6cc0eb3b-5842-4e49-85c1-14797a2a6479 | | location | cloud='', project.domain_id=, project.domain_name='default', project... | | name | router01 | | project_id | 9cffeca6beec4a39ab6b076ec2bdd0c9 | | revision_number | 1 | | routes | | | status | ACTIVE | | tags | | | updated_at | 2020-06-05T06:33:24Z | +-------------------------+-------------------------------------------------------------------------+ |
[5] | Create internal network and associate with the router above. |
# create subnet in the internal network [root@dlp ~(keystone)]# openstack network create int_net --provider-network-type vxlan +---------------------------+----------------------------------------------------------------------+ | Field | Value | +---------------------------+----------------------------------------------------------------------+ | admin_state_up | UP | | availability_zone_hints | | | availability_zones | | | created_at | 2020-06-05T06:34:00Z | | description | | | dns_domain | None | | id | 5ad4fafb-24c6-4994-bfdb-7230dfcc8d8e | | ipv4_address_scope | None | | ipv6_address_scope | None | | is_default | False | | is_vlan_transparent | None | | location | cloud='', project.domain_id=, project.domain_name='default', proj... | | mtu | 1450 | | name | int_net | | port_security_enabled | True | | project_id | 9cffeca6beec4a39ab6b076ec2bdd0c9 | | provider:network_type | vxlan | | provider:physical_network | None | | provider:segmentation_id | 1 | | qos_policy_id | None | | revision_number | 1 | | router:external | Internal | | segments | None | | shared | False | | status | ACTIVE | | subnets | | | tags | | | updated_at | 2020-06-05T06:34:00Z | +---------------------------+----------------------------------------------------------------------+ # set internal network to the router above [root@dlp ~(keystone)]# openstack subnet create subnet1 --network int_net \ --subnet-range 192.168.100.0/24 --gateway 192.168.100.1 \ --dns-nameserver 10.0.0.10 +----------------------+----------------------------------------------------------------------------+ | Field | Value | +----------------------+----------------------------------------------------------------------------+ | allocation_pools | 192.168.100.2-192.168.100.254 | | cidr | 192.168.100.0/24 | | created_at | 2020-06-05T06:34:35Z | | description | | | dns_nameservers | 10.0.0.10 | | dns_publish_fixed_ip | None | | enable_dhcp | True | | gateway_ip | 192.168.100.1 | | host_routes | | | id | f0e80ef7-9b55-4ddd-a3e5-4bd98b5f93c2 | | ip_version | 4 | | ipv6_address_mode | None | | ipv6_ra_mode | None | | location | cloud='', project.domain_id=, project.domain_name='default', project.id... | | name | subnet1 | | network_id | 5ad4fafb-24c6-4994-bfdb-7230dfcc8d8e | | prefix_length | None | | project_id | 9cffeca6beec4a39ab6b076ec2bdd0c9 | | revision_number | 0 | | segment_id | None | | service_types | | | subnetpool_id | None | | tags | | | updated_at | 2020-06-05T06:34:35Z | +----------------------+----------------------------------------------------------------------------+ # set internal network to the router above [root@dlp ~(keystone)]# openstack router add subnet router01 subnet1
|
[6] | Create external network and associate with the router above. |
# create external network [root@dlp ~(keystone)]# openstack network create \ --provider-physical-network physnet1 \ --provider-network-type flat --external ext_net +---------------------------+-----------------------------------------------------------------------+ | Field | Value | +---------------------------+-----------------------------------------------------------------------+ | admin_state_up | UP | | availability_zone_hints | | | availability_zones | | | created_at | 2020-06-05T06:35:56Z | | description | | | dns_domain | None | | id | 7b251931-9a2f-456f-8041-ef27027bb58d | | ipv4_address_scope | None | | ipv6_address_scope | None | | is_default | False | | is_vlan_transparent | None | | location | cloud='', project.domain_id=, project.domain_name='default', proje... | | mtu | 1500 | | name | ext_net | | port_security_enabled | True | | project_id | 9cffeca6beec4a39ab6b076ec2bdd0c9 | | provider:network_type | flat | | provider:physical_network | physnet1 | | provider:segmentation_id | None | | qos_policy_id | None | | revision_number | 1 | | router:external | External | | segments | None | | shared | False | | status | ACTIVE | | subnets | | | tags | | | updated_at | 2020-06-05T06:35:56Z | +---------------------------+-----------------------------------------------------------------------+ # create subnet in external network [root@dlp ~(keystone)]# openstack subnet create subnet2 \ --network ext_net --subnet-range 10.0.0.0/24 \ --allocation-pool start=10.0.0.200,end=10.0.0.254 \ --gateway 10.0.0.1 --dns-nameserver 10.0.0.10 --no-dhcp +----------------------+----------------------------------------------------------------------------+ | Field | Value | +----------------------+----------------------------------------------------------------------------+ | allocation_pools | 10.0.0.200-10.0.0.254 | | cidr | 10.0.0.0/24 | | created_at | 2020-06-05T06:36:32Z | | description | | | dns_nameservers | 10.0.0.10 | | dns_publish_fixed_ip | None | | enable_dhcp | False | | gateway_ip | 10.0.0.1 | | host_routes | | | id | a7ee24b5-eb02-410d-a326-68a956aa2adb | | ip_version | 4 | | ipv6_address_mode | None | | ipv6_ra_mode | None | | location | cloud='', project.domain_id=, project.domain_name='default', project.id... | | name | subnet2 | | network_id | 7b251931-9a2f-456f-8041-ef27027bb58d | | prefix_length | None | | project_id | 9cffeca6beec4a39ab6b076ec2bdd0c9 | | revision_number | 0 | | segment_id | None | | service_types | | | subnetpool_id | None | | tags | | | updated_at | 2020-06-05T06:36:32Z | +----------------------+----------------------------------------------------------------------------+ # set gateway to the router above [root@dlp ~(keystone)]# openstack router set router01 --external-gateway ext_net |
[7] | By default, it's possible to access for all projects to external network, but for internal network, only admin projects can access to it, so grant access permission of internal network to a project you'd like to let users in the project use. |
# show network RBAC list [root@dlp ~(keystone)]# openstack network rbac list +--------------------------------------+-------------+--------------------------------------+ | ID | Object Type | Object ID | +--------------------------------------+-------------+--------------------------------------+ | 0c698996-c70f-4bf5-a9d9-b11ca2ed9317 | network | 7b251931-9a2f-456f-8041-ef27027bb58d | +--------------------------------------+-------------+--------------------------------------+ # RBAC details # all projects can access only to [access_as_external] [root@dlp ~(keystone)]# openstack network rbac show 0c698996-c70f-4bf5-a9d9-b11ca2ed9317 +-------------------+-------------------------------------------------------------------------------+ | Field | Value | +-------------------+-------------------------------------------------------------------------------+ | action | access_as_external | | id | 0c698996-c70f-4bf5-a9d9-b11ca2ed9317 | | location | cloud='', project.domain_id=, project.domain_name='default', project.id='9... | | name | None | | object_id | 7b251931-9a2f-456f-8041-ef27027bb58d | | object_type | network | | project_id | 9cffeca6beec4a39ab6b076ec2bdd0c9 | | target_project_id | * | +-------------------+-------------------------------------------------------------------------------+ # show network list [root@dlp ~(keystone)]# openstack network list +--------------------------------------+---------+--------------------------------------+ | ID | Name | Subnets | +--------------------------------------+---------+--------------------------------------+ | 5ad4fafb-24c6-4994-bfdb-7230dfcc8d8e | int_net | f0e80ef7-9b55-4ddd-a3e5-4bd98b5f93c2 | | 7b251931-9a2f-456f-8041-ef27027bb58d | ext_net | a7ee24b5-eb02-410d-a326-68a956aa2adb | +--------------------------------------+---------+--------------------------------------+ # show project list [root@dlp ~(keystone)]# openstack project list +----------------------------------+-----------+ | ID | Name | +----------------------------------+-----------+ | 03fc3b5cc0434f748ec562dd74866396 | service | | 9cffeca6beec4a39ab6b076ec2bdd0c9 | admin | | d9c8c215499949cfb249b28bdaba848a | hiroshima | +----------------------------------+-----------+ # grant [access_as_shared] permission for [int_net] to [hiroshima] project [root@dlp ~(keystone)]# netID=$(openstack network list | grep int_net | awk '{ print $2 }') [root@dlp ~(keystone)]# prjID=$(openstack project list | grep hiroshima | awk '{ print $2 }') [root@dlp ~(keystone)]# openstack network rbac create --target-project $prjID --type network --action access_as_shared $netID +-------------------+-------------------------------------------------------------------------------+ | Field | Value | +-------------------+-------------------------------------------------------------------------------+ | action | access_as_shared | | id | bf26e0c6-9b15-4fe7-a5c9-699faf1f722a | | location | cloud='', project.domain_id=, project.domain_name='default', project.id='9... | | name | None | | object_id | 5ad4fafb-24c6-4994-bfdb-7230dfcc8d8e | | object_type | network | | project_id | 9cffeca6beec4a39ab6b076ec2bdd0c9 | | target_project_id | d9c8c215499949cfb249b28bdaba848a | +-------------------+-------------------------------------------------------------------------------+ |
[8] | Login with a user who is in the project you granted access permission to internal network and Create and boot an instance. |
# show available [flavor] list [cent@dlp ~(keystone)]$ openstack flavor list +----+----------+------+------+-----------+-------+-----------+ | ID | Name | RAM | Disk | Ephemeral | VCPUs | Is Public | +----+----------+------+------+-----------+-------+-----------+ | 0 | m1.small | 2048 | 10 | 0 | 1 | True | +----+----------+------+------+-----------+-------+-----------+ # show available image list [cent@dlp ~(keystone)]$ openstack image list +--------------------------------------+---------+--------+ | ID | Name | Status | +--------------------------------------+---------+--------+ | 9e7034a0-c825-4990-8834-4a01ee920cf5 | CentOS8 | active | +--------------------------------------+---------+--------+ # show available network list [cent@dlp ~(keystone)]$ openstack network list +--------------------------------------+---------+--------------------------------------+ | ID | Name | Subnets | +--------------------------------------+---------+--------------------------------------+ | 5ad4fafb-24c6-4994-bfdb-7230dfcc8d8e | int_net | f0e80ef7-9b55-4ddd-a3e5-4bd98b5f93c2 | | 7b251931-9a2f-456f-8041-ef27027bb58d | ext_net | a7ee24b5-eb02-410d-a326-68a956aa2adb | +--------------------------------------+---------+--------------------------------------+ # create a security group for instances [cent@dlp ~(keystone)]$ openstack security group create secgroup01 +-----------------+---------------------------------------------------------------------------------+ | Field | Value | +-----------------+---------------------------------------------------------------------------------+ | created_at | 2020-06-05T06:41:43Z | | description | secgroup01 | | id | 377b746b-dde8-4029-b32f-437f520e66aa | | location | cloud='', project.domain_id=, project.domain_name='default', project.id='d9c... | | name | secgroup01 | | project_id | d9c8c215499949cfb249b28bdaba848a | | revision_number | 1 | | rules | created_at='2020-06-05T06:41:43Z', direction='egress', ethertype='IPv4', id=... | | | created_at='2020-06-05T06:41:43Z', direction='egress', ethertype='IPv6', id=... | | stateful | True | | tags | [] | | updated_at | 2020-06-05T06:41:43Z | +-----------------+---------------------------------------------------------------------------------+ # create a SSH keypair for connecting to instances [cent@dlp ~(keystone)]$ ssh-keygen -q -N "" Enter file in which to save the key (/home/cent/.ssh/id_rsa): # add public-key [cent@dlp ~(keystone)]$ openstack keypair create --public-key ~/.ssh/id_rsa.pub mykey +-------------+-------------------------------------------------+ | Field | Value | +-------------+-------------------------------------------------+ | fingerprint | 14:b6:30:aa:d6:77:e3:2a:97:0f:d7:6d:79:ee:4f:8a | | name | mykey | | user_id | 0e4117de456a4bbaa5aac2cc6507be91 | +-------------+-------------------------------------------------+[cent@dlp ~(keystone)]$ netID=$(openstack network list | grep int_net | awk '{ print $2 }')
[cent@dlp ~(keystone)]$
[cent@dlp ~(keystone)]$ openstack server create --flavor m1.small --image CentOS8 --security-group secgroup01 --nic net-id=$netID --key-name mykey CentOS_8
openstack server list +--------------------------------------+----------+--------+------------------------+---------+----------+ | ID | Name | Status | Networks | Image | Flavor | +--------------------------------------+----------+--------+------------------------+---------+----------+ | 2929c442-26c4-41cb-b95f-98c3adceb3ef | CentOS_8 | ACTIVE | int_net=192.168.100.24 | CentOS8 | m1.small | +--------------------------------------+----------+--------+------------------------+---------+----------+ |
[9] | Assign floating IP address to the Instance above. |
[cent@dlp ~(keystone)]$ openstack floating ip create ext_net +---------------------+-----------------------------------------------------------------------------+ | Field | Value | +---------------------+-----------------------------------------------------------------------------+ | created_at | 2020-06-05T06:49:56Z | | description | | | dns_domain | None | | dns_name | None | | fixed_ip_address | None | | floating_ip_address | 10.0.0.247 | | floating_network_id | 7b251931-9a2f-456f-8041-ef27027bb58d | | id | 5c219ba8-552a-42bb-aeb5-4aff21586137 | | location | Munch({'cloud': '', 'region_name': '', 'zone': None, 'project': Munch({'... | | name | 10.0.0.247 | | port_details | None | | port_id | None | | project_id | d9c8c215499949cfb249b28bdaba848a | | qos_policy_id | None | | revision_number | 0 | | router_id | None | | status | DOWN | | subnet_id | None | | tags | [] | | updated_at | 2020-06-05T06:49:56Z | +---------------------+-----------------------------------------------------------------------------+[cent@dlp ~(keystone)]$ openstack server add floating ip CentOS_8 10.0.0.247 # confirm settings [cent@dlp ~(keystone)]$ openstack floating ip show 10.0.0.247 +---------------------+-----------------------------------------------------------------------------+ | Field | Value | +---------------------+-----------------------------------------------------------------------------+ | created_at | 2020-06-05T06:49:56Z | | description | | | dns_domain | None | | dns_name | None | | fixed_ip_address | 192.168.100.24 | | floating_ip_address | 10.0.0.247 | | floating_network_id | 7b251931-9a2f-456f-8041-ef27027bb58d | | id | 5c219ba8-552a-42bb-aeb5-4aff21586137 | | location | cloud='', project.domain_id=, project.domain_name='default', project.id=... | | name | 10.0.0.247 | | port_details | admin_state_up='True', device_id='2929c442-26c4-41cb-b95f-98c3adceb3ef',... | | port_id | 35f17910-bad5-4d89-bb2b-6d132a533af1 | | project_id | d9c8c215499949cfb249b28bdaba848a | | qos_policy_id | None | | revision_number | 2 | | router_id | 6cc0eb3b-5842-4e49-85c1-14797a2a6479 | | status | ACTIVE | | subnet_id | None | | tags | [] | | updated_at | 2020-06-05T06:50:55Z | +---------------------+-----------------------------------------------------------------------------+[cent@dlp ~(keystone)]$ openstack server list +--------------------------------------+----------+--------+------------------------------------+---------+----------+ | ID | Name | Status | Networks | Image | Flavor | +--------------------------------------+----------+--------+------------------------------------+---------+----------+ | 2929c442-26c4-41cb-b95f-98c3adceb3ef | CentOS_8 | ACTIVE | int_net=192.168.100.24, 10.0.0.247 | CentOS8 | m1.small | +--------------------------------------+----------+--------+------------------------------------+---------+----------+ |
[10] | Configure security settings for the security group you created above to access with SSH and ICMP. |
# permit ICMP [cent@dlp ~(keystone)]$ openstack security group rule create --protocol icmp --ingress secgroup01 +-------------------+-------------------------------------------------------------------------------+ | Field | Value | +-------------------+-------------------------------------------------------------------------------+ | created_at | 2020-06-05T06:52:25Z | | description | | | direction | ingress | | ether_type | IPv4 | | id | abb95b2c-29d1-48b8-a26f-bb9c71490dee | | location | cloud='', project.domain_id=, project.domain_name='default', project.id='d... | | name | None | | port_range_max | None | | port_range_min | None | | project_id | d9c8c215499949cfb249b28bdaba848a | | protocol | icmp | | remote_group_id | None | | remote_ip_prefix | 0.0.0.0/0 | | revision_number | 0 | | security_group_id | 377b746b-dde8-4029-b32f-437f520e66aa | | tags | [] | | updated_at | 2020-06-05T06:52:25Z | +-------------------+-------------------------------------------------------------------------------+ # permit SSH [cent@dlp ~(keystone)]$ openstack security group rule create --protocol tcp --dst-port 22:22 secgroup01 +-------------------+-------------------------------------------------------------------------------+ | Field | Value | +-------------------+-------------------------------------------------------------------------------+ | created_at | 2020-06-05T06:53:18Z | | description | | | direction | ingress | | ether_type | IPv4 | | id | eccc9503-cd4e-4ab9-bff3-5f696471babf | | location | cloud='', project.domain_id=, project.domain_name='default', project.id='d... | | name | None | | port_range_max | 22 | | port_range_min | 22 | | project_id | d9c8c215499949cfb249b28bdaba848a | | protocol | tcp | | remote_group_id | None | | remote_ip_prefix | 0.0.0.0/0 | | revision_number | 0 | | security_group_id | 377b746b-dde8-4029-b32f-437f520e66aa | | tags | [] | | updated_at | 2020-06-05T06:53:18Z | +-------------------+-------------------------------------------------------------------------------+[cent@dlp ~(keystone)]$ openstack security group rule list +--------------------------------------+-------------+-----------+-----------+------------+---------+ | ID | IP Protocol | Ethertype | IP Range | Port Range | Remote | +--------------------------------------+-------------+-----------+-----------+------------+---------+ | 30297cb4-6a7d-4005-be3e-65be23306e60 | None | IPv4 | 0.0.0.0/0 | | 248e... | | 60bb9a1b-8d65-4bd3-8f03-76fd224b134c | None | IPv6 | ::/0 | | None | | 74821382-b5e4-4716-beb1-4df25ce565ae | None | IPv4 | 0.0.0.0/0 | | None | | ab907343-88ec-42ac-a380-f05cd6dfe61b | None | IPv4 | 0.0.0.0/0 | | None | | abb95b2c-29d1-48b8-a26f-bb9c71490dee | icmp | IPv4 | 0.0.0.0/0 | | None | | ca0d5ad8-8514-4dd0-b0ef-bcb0782f7035 | None | IPv6 | ::/0 | | 248e... | | cf8fe2e0-3f79-4cf9-a087-b9f58ebff9df | None | IPv6 | ::/0 | | None | | eccc9503-cd4e-4ab9-bff3-5f696471babf | tcp | IPv4 | 0.0.0.0/0 | 22:22 | None | +--------------------------------------+-------------+-----------+-----------+------------+---------+ |
[11] | It's possible to login to the Instance to connect to the floating IP address with SSH like follows. |
[cent@dlp ~(keystone)]$ openstack server list +--------------------------------------+----------+--------+------------------------------------+---------+----------+ | ID | Name | Status | Networks | Image | Flavor | +--------------------------------------+----------+--------+------------------------------------+---------+----------+ | 2929c442-26c4-41cb-b95f-98c3adceb3ef | CentOS_8 | ACTIVE | int_net=192.168.100.24, 10.0.0.247 | CentOS8 | m1.small | +--------------------------------------+----------+--------+------------------------------------+---------+----------+[cent@dlp ~(keystone)]$ ssh centos@10.0.0.247 The authenticity of host '10.0.0.247 (10.0.0.247)' can't be established. ECDSA key fingerprint is SHA256:hD1ZD9t33s/u9T8QCNh0/mLP7PVSFsgdL62Z2PTFpq0. Are you sure you want to continue connecting (yes/no/[fingerprint])? yes Warning: Permanently added '10.0.0.247' (ECDSA) to the list of known hosts. [centos@centos-8 ~]$ # logined |
Sponsored Link |
|