openstack云计算管理平台

cloud:
css

    IaaS(Infrastructure as a Service),基础设施即服务html

            openstack、cloudstack
node

    PaaS(Platform-as-a-Service),平台即服务python

            docker
mysql

   SaaS(Software-as-a-Service),软件即服务linux


云计算之openstackweb

云的愿景:使用计算资源使用网络资源像使用自来水同样按需自由有偿。sql


云计算是一种按使用量付费的模式,这种模式提供可用的、便捷的、按需的网络访问,进入可配置的计算资源共享池(资源包括网络,服务器,存储,应用软件,服务),这些资源可以被快速提供,只需投入不多的管理工做,或与服务提供商进行不多的交互。docker


用途分类:数据库

私有云:侧重点:兼容性、安全性、定制化

公有云:侧重点:容量、弹性、成本

混合云


供给角度分类:

IAAS基础设施即服务         厂家表明:腾讯云   阿里云  AWS

PAAS平台即服务             厂家表明:新浪云   

SAAS软件即服务            厂家表明:微软云-office365


云平台管理选择标准:

一、API接口的普遍性

二、使用何种的开源协议进行编写

三、平台的成熟度


openstack版本选择:Juno

组件说明:

nova:计算服务,compute

glance:镜像服务,image service

swift:对象存储,object storage

cinder:块存储,block storage

neutron:网络服务,networking

horizon:仪表板,dashboard

keystone:认证服务,identity service

heat:编排,orchestration

ceilometer:监控,telemetry

trove:数据库服务,database service

sahara:数据处理,data processing


安装结构说明:

操做系统:centos 7

openstack版本:juno

关闭防火墙和selinux

资源配置状况:

controller node:1cpu、1GB、1网卡(管理网络)、100GB

compute node:尽可能多cpu、尽可能多内存、2网卡(管理网络、实例网络)、100GB

network node:2cpu、2GB、3网卡(管理网络、实例网络、外部网络)、20GB系统盘

block node:2cpu、1.5GB、1网卡(管理网络)、20GB系统盘、100GB


image.png

系统初始化部署:

一、关闭防火墙和selinux、NetworkManager

# systemctl stop firewalld NetworkManager

# systemctl disable firewalld NetworkManager

# vim /etc/selinux/config

    SELINUX=disabled


二、设置主机名、dns解析、时间同步

测试环境规划以下:

controller.nice.com    192.168.222.5

network.nice.com      192.168.222.6

compute1.nice.com   192.168.222.10

block1.nice.com         192.168.222.20    


# hostnamectl set-hostname  XXXX

# vim /etc/hosts

192.168.222.5    controller.nice.com    

192.168.222.6    network.nice.com   

192.168.222.10  compute1.nice.com   

192.168.222.20  block1.nice.com         

    

# yum install chrony -y

# systemctl start chronyd

# systemctl enable chronyd


三、安装yum-plugin-priorities、epel源、openstack源

# yum install yum-plugin-priorities epel-release -y

# vim /etc/yum.repos.d/openstack.repo

        [openstack-juno]

        name=openstack-juno

        baseurl=https://repos.fedorapeople.org/repos/openstack/EOL/openstack-juno/epel-7/

        #metalink=https://mirrors.fedoraproject.org/metalink?repo=epel-7&arch=$basearch&infra=$infra&content=$contentdir

        failovermethod=priority

        enabled=1

        gpgcheck=0

        gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-7

四、更新系统并重启

# yum update -y && reboot




各组件安装:

1、keystone(认证服务):是openstack identity service的项目名称,是一个负责身份管理与受权的组件;其主要功能:实现用户的身份认证,基于角色的权限管理,及openstack其余组件的访问地址和安全策略管理。

image.png

在controller节点配置:

 一、数据库:mariadb软件包     注意:生产环境中,应该独立作mysql集群

# yum install mariadb mariadb-server MySQL-python -y

# vim /etc/my.cnf    添加

       [mysqld]

        bind-address=192.168.222.5

        default-storage=innodb

        innodb_file_per_table

        collation-server=utf8_general_ci

        init-connect='SET NAMES utf8'

        character-set-server=utf8

# systemctl start mariadb

# systemctl enable mariadb

# mysql_secure_installation 

        

二、消息队列:rabbitmq     注意:生产环境中,应该独立作rabbitmq集群

# yum install rabbitmq-server -y

# systemctl start rabbitmq-server

# systemctl enable rabbitmq-server

# rabbitmqctl change_password guest guest123      修改默认的guest用户密码为guest123


三、时间同步服务器

# vim /etc/chrony.conf

        allow 192.168.222.0/24

# systemctl restart chronyd


四、keystone数据库

# mysql -uroot -p

MariaDB [(none)]> CREATE DATABASE keystone;

MariaDB [(none)]> GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'localhost' IDENTIFIED BY 'keystone123';

MariaDB [(none)]> GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'%' IDENTIFIED BY 'keystone123';

# openssl rand -hex 10             建立随机值做为管理员的token

    275d75ff789937d7003d

# yum install openstack-keystone python-keystoneclient -y

# vim /etc/keystone/keystone.conf    修改以下参数

        [DEFAULT]             定义管理员令牌

        admin_token=275d75ff789937d7003d      

        [database]             配置数据库访问

        connection=mysql://keystone:keystone123@controller.nice.com/keystone

        [token]                  配置UUID提供者和SQL驱动

        provider=keystone.token.providers.uuid.Provider

        driver=keystone.token.persistence.backends.sql.Token

        verbose=True     开启详细日志,协助故障排查

# keystone-manage pki_setup --keystone-user keystone --keystone-group keystone     设置用户和组都为keystone

# chown -R keystone:keystone /var/log/keystone

# chown -R keystone:keystone /etc/keystone/ssl

# chmod -R o-rwx /etc/keystone/ssl

# su -s /bin/sh -c "keystone-manage db_sync" keystone      初始化keystone数据库

# mysql -uroot -p -e "show tables from keystone;"               验证keystone数据库

# systemctl start openstack-keystone

# systemctl enable openstack-keystone

# (crontab -l -u keystone 2>&1 | grep -q token_flush) || echo '@hourly /usr/bin/keystone-manage token_flush > /var/log/keystone/keystone-tokenflush.log 2>&1' >> /var/spool/cron/keystone              每小时定时删除过时的token

# crontab -l -ukeystone                                               验证计划任务

        @hourly /usr/bin/keystone-manage token_flush > /var/log/keystone/keystone-tokenflush.log 2>&1


五、建立租户、用户和角色

# export OS_SERVICE_TOKEN=275d75ff789937d7003d

# export OS_SERVICE_ENDPOINT=http://controller.nice.com:35357/v2.0

a、建立admin租户

# keystone tenant-create --name admin --description "Admin Tenant"

b、建立admin用户

# keystone user-create --name admin --pass admin123

c、建立admin角色

# keystone role-create --name admin

d、连接admin租户和用户到admin角色

# keystone user-role-add --tenant admin --user admin --role admin

e、建立用于dashboard访问的“_member_”角色

# keystone role-create --name _member_

f、连接admin租户和用户到_member_角色

# keystone user-role-add --tenant admin --user admin --role _member_

g、建立service租户

# keystone tenant-create --name service --description "Service Tenant"


建立一个用于演示的demo租户和用户

# keystone tenant-create --name demo --description "Demo Tenant"

# keystone user-create --name demo --pass demo123

# keystone user-role-add --tenant demo --user demo --role _member_


建立服务实体和API端点

一、为identity服务建立一个服务实体

# keystone service-create --name keystone --type identity --description "OpenStack Identity"

二、为identity服务建立三个API端点:admin(管理)、internal(内部)、public(公共);

# keystone endpoint-create --service-id $(keystone service-list | awk '/ identity / {print $2}') --publicurl http://controller.nice.com:5000/v2.0 --internalurl http://controller.nice.com:5000/v2.0 --adminurl http://controller.nice.com:35357/v2.0 --region regionOne


确认操做

一、删除临时变量  OS_SERVICE_TOKEN、OS_SERVICE_ENDPOINT

# unset OS_SERVICE_TOKEN OS_SERVICE_ENDPOINT

二、使用admin租户和用户请求认证令牌

# keystone --os-tenant-name admin --os-username admin --os-password admin123 --os-auth-url http://controller.nice.com:35357/v2.0 token-get

三、以admin租户和用户的身份查看租户列表

# keystone --os-tenant-name admin --os-username admin --os-password admin123 --os-auth-url http://controller.nice.com:35357/v2.0 tenant-list

四、以admin租户和用户的身份查看用户列表

# keystone --os-tenant-name admin --os-username admin --os-password admin123 --os-auth-url http://controller.nice.com:35357/v2.0 user-list

五、以admin租户和用户的身份查看角色列表

# keystone --os-tenant-name admin --os-username admin --os-password admin123 --os-auth-url http://controller.nice.com:35357/v2.0 role-list

六、以demo租户和用户的身份请求认证令牌

# keystone --os-tenant-name demo --os-username demo --os-password demo123 --os-auth-url http://controller.nice.com:35357/v2.0 token-get

七、以demo租户和用户的身份查看用户列表

# keystone --os-tenant-name demo --os-username demo --os-password demo123 --os-auth-url http://controller.nice.com:35357/v2.0 user-list


建立openstack客户端环境脚本(避免重复输入租户帐号密码等信息)

一、admin用户的环境脚本

# vim admin-openrc.sh

        export OS_TENANT_NAME=admin

        export OS_USERNAME=admin

        export OS_PASSWORD=admin123

        export OS_AUTH_URL=http://controller.nice.com:35357/v2.0

# source admin-openrc.sh                                                 

二、demo用户的环境脚本

# vim demo-openrc.sh

            export OS_TENANT_NAME=demo

            export OS_USERNAME=demo

            export OS_PASSWORD=demo123

            export OS_AUTH_URL=http://controller.nice.com:5000/v2.0

# source admin-openrc.sh      


在controller节点验证

# keystone tenant-list

image.png



2、glance(镜像服务):使用户可以发现、注册并检索虚拟机镜像(.img文件),提供了一个REST API接口,使用户能够查询虚拟机镜像元数据和检索一个实际的镜像文件,默认虚拟机镜像存储路径为/var/lib/glance/images/

image.pngimage.pngimage.png

在controller节点配置:

一、glance数据库

# mysql -uroot -p

MariaDB [(none)]> CREATE DATABASE glance;

MariaDB [(none)]> GRANT ALL PRIVILEGES ON glance.* TO 'glance'@'localhost' IDENTIFIED BY 'glance123';

MariaDB [(none)]> GRANT ALL PRIVILEGES ON glance.* TO 'glance'@'%' IDENTIFIED BY 'glance123';

二、启动管理员admin脚本

# source admin-openrc.sh

三、建立认证用户凭证

a、建立glance用户

# keystone user-create --name glance --pass glance123

b、将glance用户连接到service租户和admin角色

# keystone user-role-add --user glance --tenant service --role admin

c、建立glance服务

# keystone service-create --name glance --type image --description "OpenStack Image service"

四、为openstack镜像服务建立认证服务端点

keystone endpoint-create --service-id $(keystone service-list | awk '/ image / {print $2}') --publicurl http://controller.nice.com:9292 --internalurl http://controller.nice.com:9292 --adminurl http://controller.nice.com:9292 --region regionOne


安装并配置镜像服务组件

# yum install openstack-glance python-glance -y

# vim /etc/glance/glance-api.conf 

        [DEFAULT]

        verbose=True

        [database]

        connection=mysql://glance:glance123@controller.nice.com/glance

        [keystone_authtoken]

        auth_host=controller.nice.com

        auth_port=35357

        auth_protocol=http

        admin_tenant_name=service

        admin_user=glance

        admin_password=glance123

        auth_uri=http://controller.nice.com:5000

        [paste_deploy]

        flavor=keystone

# vim /etc/glance/glance-registry.conf 

        [DEFAULT]

        verbose=True

        [database]

        connection=mysql://glance:glance123@controller.nice.com/glance

        [keystone_authtoken]

        auth_host=controller.nice.com

        auth_port=35357

        auth_protocol=http

        admin_tenant_name=service

        admin_user=glance

        admin_password=glance123

        auth_uri=http://controller.nice.com:5000

        [paste_deploy]

        flavor=keystone

        [glance_store]

        default_store=file

        file_store_datadir=/var/lib/glance/images/

# su -s /bin/sh -c "glance-manage db_sync" glance            初始化镜像服务的数据库

# systemctl start openstack-glance-api openstack-glance-registry

# systemctl enable openstack-glance-api openstack-glance-registry


验证安装(使用cirros验证镜像服务是否安装成功)

# mkdir -pv /tmp/images

# cd /tmp/images

# wget http://download.cirros-cloud.net/0.3.3/cirros-0.3.3-x86_64-disk.img

# source /root/admin-openrc.sh

# glance image-create --name "cirros-0.3.3-x86_64" --file /tmp/images/cirros-0.3.3-x86_64-disk.img --disk-format qcow2 --container-format bare --is-public True --progress

# rm -rf /tmp/images


在controller节点验证

# glance image-list 

image.png




3、nova(云计算服务):提供虚拟化管理服务。

在controller节点配置:

配置先决条件

一、nova数据库

# mysql -uroot -p

MariaDB [(none)]> CREATE DATABASE nova;

MariaDB [(none)]> GRANT ALL PRIVILEGES ON nova.* TO 'nova'@'localhost' IDENTIFIED BY 'nova123';

MariaDB [(none)]> GRANT ALL PRIVILEGES ON nova.* TO 'nova'@'%' IDENTIFIED BY 'nova123';

二、执行admin环境脚本

# source admin-openrc.sh 

三、在认证服务中建立计算服务的认证信息

a、建立nova用户

# keystone user-create --name nova --pass nova123

b、连接nova到service租户和admin角色

# keystone user-role-add --tenant service --role admin --user nova

c、建立nova服务

# keystone service-create --name nova --type compute --description "OpenStack Compute"

d、建立计算机服务端点

# keystone endpoint-create --service-id $(keystone service-list | awk '/ compute / {print $2}') --publicurl http://controller.nice.com:8774/v2/%\(tenant_id\)s --internalurl http://controller.nice.com:8774/v2/%\(tenant_id\)s --adminurl http://controller.nice.com:8774/v2/%\(tenant_id\)s --region regionOne


安装和配置计算控制组件

# yum install openstack-nova-api openstack-nova-cert openstack-nova-conductor openstack-nova-console openstack-nova-novncproxy openstack-nova-scheduler python-novaclient -y

# vim /etc/nova/nova.conf 

        [DEFAULT]                               配置rabbit消息队列访问

        rabbit_host=controller.nice.com

        rabbit_password=guest123

        rpc_backend=rabbit

        auth_strategy=keystone

        my_ip=192.168.222.5               controller节点的管理接口IP

        vncserver_listen=192.168.222.5                           

        vncserver_proxyclient_address=192.168.222.5

        verbose=True

        [keystone_authtoken]             配置认证服务

        auth_uri=http://controller.nice.com:5000/v2.0

        identity_uri=http://controller.nice.com:35357

        admin_user=nova

        admin_password=nova123

        admin_tenant_name=service

        [glance]

        host=controller.nice.com

        [database]

        connection=mysql://nova:nova123@controller.nice.com/nova       配置数据库访问

# su -s /bin/sh -c "nova-manage db sync" nova                           初始化nova数据库

# systemctl start openstack-nova-api openstack-nova-cert openstack-nova-conductor openstack-nova-consoleauth openstack-nova-novncproxy openstack-nova-scheduler 

# systemctl enable openstack-nova-api openstack-nova-cert openstack-nova-conductor openstack-nova-consoleauth openstack-nova-novncproxy openstack-nova-scheduler


在compute节点配置:

同controller,进行系统初始化部署(包含主机名、时间同步、yum repo等等)

安装配置nova

# yum install openstack-nova-compute sysfsutils -y

# vim /etc/nova/nova.conf 

        [DEFAULT]                               配置rabbit消息队列访问

        rabbit_host=controller.nice.com

        rabbit_password=guest123

        rpc_backend=rabbit

        auth_strategy=keystone

        my_ip=192.168.222.10               compute节点的管理接口IP

        vnc_enabled=true

        vncserver_listen=0.0.0.0

        vncserver_proxyclient_address=192.168.222.10

        novncproxy_base_url=http://controller.nice.com:6080/vnc_auto.html

        verbose=True

        [keystone_authtoken]             配置认证服务

        auth_uri=http://controller.nice.com:5000/v2.0

        identity_uri=http://controller.nice.com:35357

        admin_user=nova

        admin_password=nova123

        admin_tenant_name=service

        [glance]

        host=controller.nice.com

# egrep -c '(svm|vmx)' /proc/cpuinfo    确认是否支持硬件虚拟化,返回值为1,表示支持;如设置不支持硬件虚拟化,则需设置nova.conf中的virt_type=qemu

# systemctl enable libvirtd openstack-nova-compute

# systemctl start libvirtd 

# systemctl start openstack-nova-compute


在controller节点验证

# source admin-openrc.sh 

# nova service-list

image.png

# nova image-list

image.png




4、neutron(网络服务)

在controller节点配置:

一、neutron数据库

# mysql -uroot -p

MariaDB [(none)]> CREATE DATABASE neutron;

MariaDB [(none)]> GRANT ALL PRIVILEGES ON neutron.* TO 'neutron'@'localhost' IDENTIFIED BY 'neutron123';

MariaDB [(none)]> GRANT ALL PRIVILEGES ON neutron.* TO 'neutron'@'%' IDENTIFIED BY 'neutron123';

二、执行admin环境变量脚本

# source admin-openrc.sh

三、在认证服务中建立网络服务的认证信息

a、建立neutron用户

# keystone user-create --name neutron --pass neutron123

b、连接neutron用户到service租户和admin角色

# keystone user-role-add --tenant service --role admin --user neutron

c、建立neutron服务

# keystone service-create --name neutron --type network --description "OpenStack Networking"

d、建立neutron服务端点

# keystone endpoint-create --service-id $(keystone service-list | awk '/ network / {print $2}') --publicurl http://controller.nice.com:9696 --internalurl http://controller.nice.com:9696 --adminurl http://controller.nice.com:9696 --region regionOne


安装、配置网络服务组件

问题:python-neutron与python2-eventlet冲突:

Error: python-neutron conflicts with python2-eventlet-0.18.4-1.el7.noarch

 You could try using --skip-broken to work around the problem

 You could try running: rpm -Va --nofiles --nodigest

解决办法:

一、卸载原来的python2-eventlet包

# rpm -e --nodeps python2-eventlet

二、安装juno源中的python-eventlet包(版本0.15.2-1.el7)

# yum --disablerepo=epel install python-eventlet -y

# yum install openstack-neutron openstack-neutron-ml2 python-neutronclient which -y


配置网络服务组件

# vim /etc/neutron/neutron.conf 

a、编辑[database]小节,配置数据库访问

        [database]

        connection = mysql://neutron:neutron123@controller.nice.com/neutron

b、编辑[DEFAULT]小节,配置rabbitmq消息队列访问

        [DEFAULT]

        rabbit_host=controller.nice.com

        rabbit_password=guest123

        rpc_backend=rabbit

c、编辑[DEFAULT]和[keystone_authtoken]小节,配置认证服务访问

        [DEFAULT]

        auth_strategy = keystone

        [keystone_authtoken]

        auth_uri = http://controller.nice.com:5000/v2.0

        identity_uri = http://controller.nice.com:35357

        admin_tenant_name = service

        admin_user = neutron

        admin_password = neutron123

d、编辑[DEFAULT]小节,启用modular layer2(ML2)插件,路由服务和重叠IP地址功能

        [DEFAULT]

        core_plugin = ml2

        service_plugins = router

        allow_overlapping_ips = True

e、编辑[DEFAULT]小节,配置当前网络拓扑结构发生变化时通知计算服务

        [DEFAULT]

        notify_nova_on_port_status_changes = True

        notify_nova_on_port_data_changes = True

        nova_url = http://controller.nice.com:8774/v2

        nova_admin_auth_url = http://controller.nice.com:35357/v2.0

        nova_region_name = regionOne

        nova_admin_username = neutron

        nova_admin_tenant_id = 1b7db191c0294649b94bae666a7459fd      此处tenant_id可经过# keystone  tenant-get service获取

        nova_admin_password = neutron123

f、开启日志详细输出

        [DEFAULT]

        verbose = True

        

配置modular layer2(ML2)plug-in

# vim /etc/neutron/plugins/ml2/ml2_conf.ini

a、编辑[ml2]小节,启用flat和gre网络类型驱动,配置gre租户网络和ovs驱动机制

        [ml2]

        type_drivers = flat,gre

        tenant_network_types = gre

        mechanism_drivers = openvswitch

b、编辑[ml2_type_gre],配置隧道标识范围

        [ml2_type_gre]

        tunnel_id_ranges = 1:1000

c、编辑[securitygroup]小节,启用安全组,启用ipset并配置ovs防火墙驱动

        [securitygroup]

        enable_security_group = True

        enable_ipset = True

        firewall_driver = neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver

        

配置计算服务使用neutron,默认使用传统网络,因此须要从新配置

# vim /etc/nova/nova.conf

a、编辑[DEFAULT]小节,配置api接口和驱动程序

        [DEFAULT]

        network_api_class=nova.network.neutronv2.api.API

        security_group_api=neutron

        linuxnet_interface_driver=nova.network.linux_net.LinuxOVSInterfaceDriver

        firewall_driver=nova.virt.firewall.NoopFirewallDriver

b、编辑[neutron]小节,配置访问参数

        [neutron]

        url=http://controller.nice.com:9696

        auth_strategy=keystone

        admin_auth_url=http://controller.nice.com:35357/v2.0

        admin_tenant_name=service

        admin_username=neutron

        admin_password=neutron123


完成配置

一、为ml2插件配置文件建立连接文件

# ln -sv /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 juno" neutron

三、从新启动计算服务

# systemctl restart openstack-nova-api openstack-nova-scheduler openstack-nova-conductor

四、启动网络服务并配置开机自动启动

# systemctl enable neutron-server

# systemctl start neutron-server


在controller节点验证

一、执行admin环境变量脚本

# source admin-openrc.sh 

二、列出加载的扩展模块,确认成功启动neutron-server进程

# neutron ext-list

image.png



在network节点操做:安装并配置network节点

配置先觉条件

一、开启内核参数

# vim /etc/sysctl.conf 

        net.ipv4.ip_forward=1

        net.ipv4.conf.all.rp_filter=0

        net.ipv4.conf.default.rp_filter=0

二、使更改生效

# sysctl -p


安装配置网络组件

问题:python-neutron与python2-eventlet冲突:

Error: python-neutron conflicts with python2-eventlet-0.18.4-1.el7.noarch

 You could try using --skip-broken to work around the problem

 You could try running: rpm -Va --nofiles --nodigest

解决办法:

一、卸载原来的python2-eventlet包

# rpm -e --nodeps python2-eventlet

二、安装juno源中的python-eventlet包(版本0.15.2-1.el7)

# yum --disablerepo=epel install python-eventlet -y

# yum install openstack-neutron openstack-neutron-ml2 openstack-neutron-openvswitch  -y

# vim /etc/neutron/neutron.conf

a、编辑[database]小节,注释任何connection选项,由于network节点不能直接链接数据库。

b、编辑[DEFAULT]小节,配置rabbitmq消息队列访问

        [DEFAULT]

        rabbit_host=controller.nice.com

        rabbit_password=guest123

        rpc_backend=rabbit

c、编辑[DEFAULT]和[keystone_authtoken]小节,配置认证服务访问

        [DEFAULT]

        auth_strategy = keystone

        [keystone_authtoken]

        auth_uri = http://controller.nice.com:5000/v2.0

        identity_uri = http://controller.nice.com:35357

        admin_tenant_name = service

        admin_user = neutron

        admin_password = neutron123

d、编辑[DEFAULT]小节,启用modular layer2(ML2)插件,路由服务和重叠IP地址功能

        [DEFAULT]

        core_plugin = ml2

        service_plugins = router

        allow_overlapping_ips = True

e、开启日志详细输出

        [DEFAULT]

        verbose = True


配置modular layer2(ML2)plug-in

# vim /etc/neutron/plugins/ml2/ml2_conf.ini

a、编辑[ml2]小节,启用flat和gre网络类型驱动,配置gre租户网络和ovs驱动机制

        [ml2]

        type_drivers = flat,gre

        tenant_network_types = gre

        mechanism_drivers = openvswitch

b、编辑[ml2_type_flat],配置外部网络

        [ml2_type_flat]

        flat_networks = external

c、编辑[ml2_type_gre],配置隧道标识范围

        [ml2_type_gre]

        tunnel_id_ranges = 1:1000

d、编辑[securitygroup]小节,启用安全组,启用ipset并配置ovs防火墙驱动

        [securitygroup]

        enable_security_group = True

        enable_ipset = True

        firewall_driver = neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver

e、编辑[ovs],配置open vswitch(ovs)代理

        [ovs]

        local_ip = 172.16.0.6                                    network节点的内部实例网络ip

        tunnel_type = gre

        enable_tunneling = True

        bridge_mappings = external:br-ex              规范外部网桥名为br-ex


配置layer-3(L3)agent

# vim /etc/neutron/l3_agent.ini 

a、在[DEFAULT]小节,开启debug日志输出

        [DEFAULT]

        debug = True

b、编辑[DEFAULT]小节,配置驱动,启用网络命名空间,配置外部网络桥接

        [DEFAULT]

        interface_driver = neutron.agent.linux.interface.OVSInterfaceDriver

        use_namespaces = True

        external_network_bridge = br-ex

                

配置dhcp agent

一、必选

# vim /etc/neutron/dhcp_agent.ini

a、在[DEFAULT]小节,开启debug日志输出

        [DEFAULT]

        debug = True

b、编辑[DEFAULT]小节,配置驱动和启用命名空间

        [DEFAULT]

        interface_driver = neutron.agent.linux.interface.OVSInterfaceDriver    

        dhcp_driver = neutron.agent.linux.dhcp.Dnsmasq

        use_namespaces = True


二、(可选,在vmware虚拟机中必选)配置dhcp选项,将mtu改成1454bytes,以改善网络性能。

a、编辑/etc/neutron/dhcp_agent.ini,在[DEFAULT],启用dnsmasq配置

        [DEFAULT]

        dnsmasq_config_file = /etc/neutron/dnsmasq-neutron.conf

b、建立并编辑/etc/neutron/dnsmasq-neutron.conf文件

# vim /etc/neutron/dnsmasq-neutron.conf

        dhcp-option-force=26,1454

        user=neutron

        group=neutron

c、终止任何已经存在的dnsmasq进程

# pkill dnsmasq


配置metadata agent

一、# vim /etc/neutron/metadata_agent.ini

a、编辑[DEFAULT]小节,配置访问参数

        [DEFAULT]

        auth_url = http://controller.nice.com:5000/v2.0

        auth_region = RegionOne

        admin_tenant_name = service

        admin_user = neutron

        admin_password = neutron123

b、编辑[DEFAULT]小节,配置元数据主机

        [DEFAULT]

        nova_metadata_ip = controller.nice.com

c、编辑[DEFAULT]小节,配置元数据代理共享机密暗号

        [DEFAULT]

        metadata_proxy_shared_secret = openstack-juno          此处暗号自行设置

d、开启debug日志,(可选)

        [DEFAULT]

        debug = True

二、在controller节点,启用元数据代理并配置机密暗号

# vim /etc/nova/nova.conf

        [neutron]

        service_metadata_proxy=True

        metadata_proxy_shared_secret=openstack-juno

三、在controller节点,从新启动compute api服务

# systemctl restart openstack-nova-api


配置open vswitch(ovs)服务

一、启用ovs服务并设置开机自动启动

# systemctl start openvswitch

# systemctl enable openvswitch

二、添加配置所需的外部网桥br-ex

# ovs-vsctl add-br br-ex

三、添加一个端口到外部网桥,用于链接外部物理网络。

# ovs-vsctl add-port br-ex ens38             此处ens38需换成实际链接外部网卡接口名


完成安装

一、建立网络服务初始化脚本的符号链接

# ln -sv /etc/neutron/plugins/ml2/ml2_conf.ini /etc/neutron/plugin.ini 

# cp /usr/lib/systemd/system/neutron-openvswitch-agent.service /usr/lib/systemd/system/neutron-openvswitch-agent.service.orig

# sed -i 's@plugins/openvswitch/ovs_neutron_plugin.ini@plugin.ini@g' /usr/lib/systemd/system/neutron-openvswitch-agent.service

二、启动网络服务并设置开机自动启动

# systemctl enable neutron-openvswitch-agent neutron-l3-agent neutron-dhcp-agent neutron-metadata-agent neutron-ovs-cleanup

# systemctl start neutron-openvswitch-agent neutron-l3-agent neutron-dhcp-agent neutron-metadata-agent


验证(在controller节点)

# source admin-openrc.sh 

# neutron agent-list

image.png




安装并配置compute1节点,若有多个compute节点都需执行

配置先觉条件

一、开启内核参数

# vim /etc/sysctl.conf         

        net.ipv4.conf.all.rp_filter=0

        net.ipv4.conf.default.rp_filter=0

二、使更改生效

# sysctl -p


安装配置网络组件

问题:python-neutron与python2-eventlet冲突:

Error: python-neutron conflicts with python2-eventlet-0.18.4-1.el7.noarch

 You could try using --skip-broken to work around the problem

 You could try running: rpm -Va --nofiles --nodigest

解决办法:

一、卸载原来的python2-eventlet包

# rpm -e --nodeps python2-eventlet 

二、安装juno源中的python-eventlet包(版本0.15.2-1.el7)

# yum --disablerepo=epel install python-eventlet -y

# yum install openstack-neutron-ml2 openstack-neutron-openvswitch  -y 


# vim /etc/neutron/neutron.conf

a、编辑[database]小节,注释任何connection选项,由于network节点不能直接链接数据库。

b、编辑[DEFAULT]小节,配置rabbitmq消息队列访问

        [DEFAULT]

        rabbit_host=controller.nice.com

        rabbit_password=guest123

        rpc_backend=rabbit

c、编辑[DEFAULT]和[keystone_authtoken]小节,配置认证服务访问

        [DEFAULT]

        auth_strategy = keystone

        [keystone_authtoken]

        auth_uri = http://controller.nice.com:5000/v2.0

        identity_uri = http://controller.nice.com:35357

        admin_tenant_name = service

        admin_user = neutron

        admin_password = neutron123

d、编辑[DEFAULT]小节,启用modular layer2(ML2)插件,路由服务和重叠IP地址功能

        [DEFAULT]

        core_plugin = ml2

        service_plugins = router

        allow_overlapping_ips = True

e、开启日志详细输出

        [DEFAULT]

        verbose = True


配置modular layer2(ML2)plug-in

# vim /etc/neutron/plugins/ml2/ml2_conf.ini

a、编辑[ml2]小节,启用flat和gre网络类型驱动,配置gre租户网络和ovs驱动机制

        [ml2]

        type_drivers = flat,gre

        tenant_network_types = gre

        mechanism_drivers = openvswitch

b、编辑[ml2_type_gre],配置隧道标识范围

        [ml2_type_gre]

        tunnel_id_ranges = 1:1000

c、编辑[securitygroup]小节,启用安全组,启用ipset并配置ovs防火墙驱动

        [securitygroup]

        enable_security_group = True

        enable_ipset = True

        firewall_driver = neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver

d、编辑[ovs],配置open vswitch(ovs)代理

        [ovs]

        local_ip = 172.16.0.10                                    compute1节点的内部实例网络ip

        tunnel_type = gre

        enable_tunneling = True


配置open vswitch(ovs)服务

启用ovs服务并设置开机自动启动

# systemctl start openvswitch

# systemctl enable openvswitch


配置计算服务使用网络

# vim /etc/nova/nova.conf

a、编辑[DEFAULT]小节,配置api接口和驱动程序

        [DEFAULT]

        network_api_class=nova.network.neutronv2.api.API

        security_group_api=neutron

        linuxnet_interface_driver=nova.network.linux_net.LinuxOVSInterfaceDriver

        firewall_driver=nova.virt.firewall.NoopFirewallDriver

b、编辑[neutron]小节,配置访问参数

        [neutron]

        url=http://controller.nice.com:9696

        auth_strategy=keystone

        admin_auth_url=http://controller.nice.com:35357/v2.0

        admin_tenant_name=service

        admin_username=neutron

        admin_password=neutron123


完成安装

一、建立网络服务初始化脚本的符号链接

# ln -sv /etc/neutron/plugins/ml2/ml2_conf.ini /etc/neutron/plugin.ini 

# cp /usr/lib/systemd/system/neutron-openvswitch-agent.service /usr/lib/systemd/system/neutron-openvswitch-agent.service.orig

# sed -i 's@plugins/openvswitch/ovs_neutron_plugin.ini@plugin.ini@g' /usr/lib/systemd/system/neutron-openvswitch-agent.service

二、重启计算服务

# systemctl restart openstack-nova-compute

三、启动ovs代理服务并设置开机自动启动

# systemctl daemon-reload

# systemctl enable neutron-openvswitch-agent.service

# systemctl start neutron-openvswitch-agent.service

 

验证(在controller节点)

# source admin-openrc.sh 

# neutron agent-list

image.png



建立第一个网络:

在controller节点:配置外部网络

建立一个外部网络

# source admin-openrc.sh

# neutron net-create ext-net --shared --router:external True --provider:physical_network external --provider:network_type flat

建立一个外部网络子网

# neutron subnet-create ext-net --name ext-subnet --allocation-pool start=100.100.100.100,end=100.100.100.240 --disable-dhcp --gateway 100.100.100.10 100.100.100.0/24


在controller节点:配置租户网络

建立一个租户网络

# source demo-openrc.sh

# neutron net-create demo-net

建立一个租户网络子网

# neutron subnet-create demo-net --name demo-subnet --gateway 192.168.80.1 192.168.80.0/24

在租户网络建立一个路由器,用来链接外部网络和租户网

一、建立路由器

# neutron router-create demo-router

二、附加路由器到demo租户的子网

# neutron router-interface-add demo-router demo-subnet

三、经过设置网关,使路由器附加到外部网络

# neutron router-gateway-set demo-router ext-net


确认链接

一、查看路由器获取到的IP

# neutron router-list

image.png二、在任何一台外部主机上ping路由器获取到的外部地址





5、horizon(仪表盘组件):

image.png

安装仪表板组件

# yum install openstack-dashboard httpd mod_wsgi memcached python-memcached -y

配置仪表板

# vim /etc/openstack-dashboard/local_settings

一、配置dashboard使用controller节点上的openstack服务

OPENSTACK_HOST = "controller.nice.com"

二、设置容许来自全部网络的主机访问dashboard

ALLOWED_HOSTS = ['*']

三、配置memcached会话存储服务(将原有CACHES区域注释)

CACHES = {

    'default': {

        'BACKEND': 'django.core.cache.backends.memcached.MemcachedCachea',

        'LOCATION': '127.0.0.1:11211',

    }

}

四、配置时区(可选)

TIME_ZONE = "Asia/Shanghai"


完成安装

一、在rhel或centos上,配置selinux去容许web服务器访问openstack服务(若是没关selinux)

# setsebool -P httpd_can_network_connect on

二、修改相关文件归属,使dashboard css能够被加载

# chown -R apache:apache /usr/share/openstack-dashboard/static

三、启动web和memcached,并设置开机自启动

# systemctl enable httpd memcached

# systemctl start httpd memcached


验证

一、访问dashboard,访问地址http://controller.nice.com/dashboard

二、使用admin或demo登陆

相关文章
相关标签/搜索