005-OpenStack-网络服务

OpenStack-网络服务

【基于此文章的环境】点我快速打开文章

1、控制节点(controller)

1.1 创库授权 neutron

mysql

CREATE DATABASE neutron;

GRANT ALL PRIVILEGES ON neutron.* TO 'neutron'@'localhost' \
  IDENTIFIED BY 'NEUTRON_DBPASS';

GRANT ALL PRIVILEGES ON neutron.* TO 'neutron'@'%' \
  IDENTIFIED BY 'NEUTRON_DBPASS';

1535493-20190722194355243-463135339.gif

1535493-20190722194357363-1497281507.jpg

1.2 创建服务证书

1. 创建 neutron 用户
openstack user create --domain default --password NEUTRON_PASS neutron

用合适的密码代替  NEUTRON_PASS

1535493-20190722194403551-1592663534.gif

1535493-20190722194405669-1122159829.jpg

2. 给 neutron 用户添加 admin 角色
openstack role add --project service --user neutron admin

1535493-20190722194412934-1038192287.gif

1535493-20190722194415414-396913829.jpg

3. 创建 neutron 服务实体
openstack service create --name neutron \
  --description "OpenStack Networking" network

1535493-20190722194422687-110537421.gif

1535493-20190722194424931-1266914804.jpg

4. 创建 Compute 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

1535493-20190722194432641-26193210.gif

1535493-20190722194434848-1977552106.png

1.3 配置网络选项

1. 安装其软件包
yum install openstack-neutron openstack-neutron-ml2 \
  openstack-neutron-linuxbridge ebtables -y &>/dev/null
  
echo $?

1535493-20190722194444178-1952056925.gif

1535493-20190722194502769-1247027761.jpg

2. 修改配置文件
1. 备份初始配置文件,然后重定向写入配置文件
cp /etc/neutron/neutron.conf{,.bak}

egrep -v '^$|#' /etc/neutron/neutron.conf.bak >/etc/neutron/neutron.conf

1535493-20190722194509478-1159692139.gif

1535493-20190722194511795-589619158.jpg

2. 编辑文件 /etc/neutron/neutron.conf 并完成如下动作:
vim /etc/neutron/neutron.conf
  • 在 [database] 部分,配置数据库访问
[database]
# ...
connection = mysql+pymysql://neutron:NEUTRON_DBPASS@controller/neutron

用你设置的数据库密码替换 NEUTRON_DBPASS 。

  • DEFAULT] 部分,启用 ML2 插件并禁用其他插件
[DEFAULT]
# ...
core_plugin = ml2
service_plugins =
  • [DEFAULT] 部分,配置 RabbitMQ 消息队列访问权限
[DEFAULT]
# ...
transport_url = rabbit://openstack:RABBIT_PASS@controller

用你在 RabbitMQ 中为 openstack 选择的密码替换 RABBIT_PASS

  • [DEFAULT][keystone_authtoken] 部分中,配置身份服务访问
[DEFAULT]
# ...
auth_strategy = keystone

[keystone_authtoken]
# ...
auth_uri = http://controller:5000
auth_url = http://controller:35357
memcached_servers = controller:11211
auth_type = password
project_domain_name = default
user_domain_name = default
project_name = service
username = neutron
password = NEUTRON_PASS

将 NEUTRON_PASS 替换为你在认证服务中为 neutron 用户选择的密码。

  • [DEFAULT][nova] 部分,配置网络服务来通知计算节点的网络拓扑变化:
[DEFAULT]
# ...
notify_nova_on_port_status_changes = true
notify_nova_on_port_data_changes = true

[nova]
# ...
auth_url = http://controller:35357
auth_type = password
project_domain_name = default
user_domain_name = default
region_name = RegionOne
project_name = service
username = nova
password = NOVA_PASS

使用你在身份认证服务中设置的 nova 用户的密码替换 NOVA_PASS

  • [oslo_concurrency] 部分,配置锁路径:
[oslo_concurrency]
# ...
lock_path = /var/lib/neutron/tmp

1535493-20190722194531287-1543840864.gif

1535493-20190722194535598-123111039.png

3. 备份初始配置文件,然后重定向写入配置文件
cp /etc/neutron/plugins/ml2/ml2_conf.ini{,.bak}

egrep -v '^$|#' /etc/neutron/plugins/ml2/ml2_conf.ini.bak >/etc/neutron/plugins/ml2/ml2_conf.ini

1535493-20190722194544793-1762915936.gif

1535493-20190722194547491-1400596510.jpg

4. 编辑文件 /etc/neutron/plugins/ml2/ml2_conf.ini 并完成如下动作:
vim /etc/neutron/plugins/ml2/ml2_conf.ini
  • [ml2] 部分,启用 flatVLAN 网络:
[ml2]
# ...
type_drivers = flat,vlan
  • [ml2] 部分,禁用私有网络:
[ml2]
# ...
tenant_network_types =
  • [ml2] 部分,启用 Linuxbridge 机制:
[ml2]
# ...
mechanism_drivers = linuxbridge
  • [ml2] 部分,启用端口安全扩展驱动:
[ml2]
# ...
extension_drivers = port_security
  • [ml2_type_flat] 部分,配置公共虚拟网络为 flat 网络:
[ml2_type_flat]
# ...
flat_networks = provider
  • [securitygroup] 部分,启用 ipset 增加安全组的方便性:
[securitygroup]
# ...
enable_ipset = true

1535493-20190722194558404-213047390.gif

1535493-20190722194601059-1579766299.jpg

5. 备份初始配置文件,然后重定向写入配置文件
cp /etc/neutron/plugins/ml2/linuxbridge_agent.ini{,.bak}

egrep -v '^$|#' /etc/neutron/plugins/ml2/linuxbridge_agent.ini.bak >/etc/neutron/plugins/ml2/linuxbridge_agent.ini

1535493-20190722194612375-230517212.gif

1535493-20190722194617138-712960711.jpg

6. 编辑文件 /etc/neutron/plugins/ml2/linuxbridge_agent.ini 并完成如下动作:
vim /etc/neutron/plugins/ml2/linuxbridge_agent.ini
  • [linux_bridge] 部分,将公共虚拟网络和公共物理网络接口对应起来:
[linux_bridge]
physical_interface_mappings = provider:eth0
  • [vxlan] 部分,禁止 VXLAN 覆盖网络:
[vxlan]
enable_vxlan = false

[securitygroup] 部分,启用安全组并配置 Linux 桥接 iptables 防火墙驱动:

[securitygroup]
# ...
enable_security_group = true
firewall_driver = neutron.agent.linux.iptables_firewall.IptablesFirewallDriver

1535493-20190722194625580-390467295.gif

1535493-20190722194628979-691901120.jpg

9. 备份初始配置文件,然后重定向写入配置文件
cp /etc/neutron/dhcp_agent.ini{,.bak}

egrep -v '^$|#' /etc/neutron/dhcp_agent.ini.bak >/etc/neutron/dhcp_agent.ini

1535493-20190722194635349-1941268077.gif

1535493-20190722194639931-224051455.jpg

10. 编辑文件 /etc/neutron/dhcp_agent.ini 并完成如下动作:
vim /etc/neutron/dhcp_agent.ini
  • [DEFAULT] 部分,配置 Linuxbridge 驱动接口,DHCP 驱动并启用隔离元数据,这样在公共网络上的实例就可以通过网络来访问元数据
[DEFAULT]
# ...
interface_driver = linuxbridge
dhcp_driver = neutron.agent.linux.dhcp.Dnsmasq
enable_isolated_metadata = true

1535493-20190722194648513-292723102.gif

1535493-20190722194652268-381202272.jpg

1.4 配置元数据代理

1. 修改配置文件
1. 备份初始配置文件,然后重定向写入配置文件
cp /etc/neutron/metadata_agent.ini{,.bak}

egrep -v '^$|#' /etc/neutron/metadata_agent.ini.bak >/etc/neutron/metadata_agent.ini

1535493-20190722194700960-1725639485.gif

1535493-20190722194704185-2088410988.jpg

2. 编辑文件 /etc/neutron/metadata_agent.ini 并完成如下动作:
vim /etc/neutron/metadata_agent.ini
  • [DEFAULT] 部分,配置元数据主机以及共享密码:
[DEFAULT]
# ...
nova_metadata_ip = controller
metadata_proxy_shared_secret = METADATA_SECRET

用你为元数据代理设置的密码替换 METADATA_SECRET。

1535493-20190722194715598-973250832.gif

1535493-20190722194719923-644881423.jpg

3. 编辑文件 /etc/nova/nova.conf 并完成如下动作:
vim /etc/nova/nova.conf
  • [neutron] 部分,配置访问参数,启用元数据代理并设置密码:
[neutron]
# ...
url = http://controller:9696
auth_url = http://controller:35357
auth_type = password
project_domain_name = default
user_domain_name = default
region_name = RegionOne
project_name = service
username = neutron
password = NEUTRON_PASS
service_metadata_proxy = true
metadata_proxy_shared_secret = METADATA_SECRET

NEUTRON_PASS 替换为你在认证服务中为 neutron 用户选择的密码。

使用你为元数据代理设置的密码替换 METADATA_SECRET

1535493-20190722194728637-1842805384.gif

1535493-20190722194731586-236237910.jpg

1.5 同步数据库(创表)

ln -s /etc/neutron/plugins/ml2/ml2_conf.ini /etc/neutron/plugin.ini

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

1535493-20190722194745759-2051445671.gif

1535493-20190722194753869-1548606246.png

1.6 启动和自启动

systemctl restart openstack-nova-api.service

systemctl enable neutron-server.service \
  neutron-linuxbridge-agent.service neutron-dhcp-agent.service \
  neutron-metadata-agent.service

systemctl start neutron-server.service \
  neutron-linuxbridge-agent.service neutron-dhcp-agent.service \
  neutron-metadata-agent.service

1535493-20190722194803574-524454175.gif

1535493-20190722194806919-678115693.jpg

1.7 验证操作

openstack network agent list

1535493-20190722194813241-239836303.gif

1535493-20190722194816181-594133340.jpg

2、计算节点(compute1)

2.1 安装组件

1. 安装其软件包
yum install openstack-neutron-linuxbridge ebtables ipset -y &>/dev/null

echo $?

1535493-20190722194835344-1488039712.gif

1535493-20190722194839199-1428699728.jpg

2. 修改配置文件
1. 备份初始配置文件,然后重定向写入配置文件
cp /etc/neutron/neutron.conf{,.bak}

egrep -v '^$|#' /etc/neutron/neutron.conf.bak >/etc/neutron/neutron.conf

1535493-20190722194853920-549427848.gif

1535493-20190722194856451-17742618.jpg

2. 编辑文件 /etc/neutron/neutron.conf 并完成如下动作:
vim /etc/neutron/neutron.conf
  • [DEFAULT] 部分,配置 RabbitMQ 消息队列访问权限
[DEFAULT]
# ...
transport_url = rabbit://openstack:RABBIT_PASS@controller

用你在 RabbitMQ 中为 openstack 选择的密码替换 RABBIT_PASS

  • [DEFAULT][keystone_authtoken] 部分中,配置身份服务访问
[DEFAULT]
# ...
auth_strategy = keystone

[keystone_authtoken]
# ...
auth_uri = http://controller:5000
auth_url = http://controller:35357
memcached_servers = controller:11211
auth_type = password
project_domain_name = default
user_domain_name = default
project_name = service
username = neutron
password = NEUTRON_PASS

将 NEUTRON_PASS 替换为你在认证服务中为 neutron 用户选择的密码。

  • [oslo_concurrency] 部分,配置锁路径:
[oslo_concurrency]
# ...
lock_path = /var/lib/neutron/tmp

1535493-20190722194908599-1116325698.gif

1535493-20190722194925066-1723008265.png

2.2 配置网络选项

1. 复制配置文件
scp -rp 10.0.0.11:/etc/neutron/plugins/ml2/linuxbridge_agent.ini /etc/neutron/plugins/ml2/linuxbridge_agent.ini

1535493-20190722194932671-1382176893.gif

1535493-20190722194937090-1008197840.jpg

2. 修改配置文件
1. 编辑文件 /etc/nova/nova.conf 并完成如下动作:
vim /etc/nova/nova.conf
  • [neutron] 部分,配置访问参数:
[neutron]
# ...
url = http://controller:9696
auth_url = http://controller:35357
auth_type = password
project_domain_name = default
user_domain_name = default
region_name = RegionOne
project_name = service
username = neutron
password = NEUTRON_PASS

NEUTRON_PASS 替换为你在认证服务中为 neutron 用户选择的密码。

1535493-20190722194947747-671175055.gif

1535493-20190722194951386-1987545507.jpg

2.3 启动和自启动

systemctl restart openstack-nova-compute.service

systemctl enable neutron-linuxbridge-agent.service

systemctl start neutron-linuxbridge-agent.service

1535493-20190722195000532-1223680155.gif

1535493-20190722195007958-2074913734.jpg

【后续文章】点我快速打开文章

【本文图片下载地址】【002-OpenStack】点我快速打开分享(若异常,请私信,万分感谢) 【提取码:kse1 】

今天你学习了吗?若有疑问,请留言、私信或加QQ群:647033350,大家一起进步吧!

转载于:https://www.cnblogs.com/wjcLinux/p/11228016.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值