美文网首页
Openstack LinuxBridge+vxlan搭建部署

Openstack LinuxBridge+vxlan搭建部署

作者: 跑腿打杂临时工 | 来源:发表于2021-05-27 10:52 被阅读0次

    环境介绍

    Openstack版本:train
    系统版本:CentOS 7.9
    存储方式:本地存储
    网络模式:self-service networks
    网络规划:1.管理网;2.VM/tenant网络;3.外部网络;
    测试环境使用了3台物理机,一台控制节点(使用三块网卡,网卡1:管理网,网卡2:VM/tenant网络,网卡3:外部网络;),两台计算节点(使用两块网卡,网卡1:管理网,网卡2:VM/tenant网络;)
    具体分配如下:


    openstack多租户vxlan网络拓扑.png

    服务搭建部署

    openstack中的每个服务组件都有不同的角色,同时也会部署在不同的节点上,请注意。

    基础优化

    修改各节点的主机名

    #controller1
    hostnamectl set-hostname test-controller
    #compute1
    hostnamectl set-hostname compute1
    #compute2
    hostnamectl set-hostname compute2
    

    修改各节点的hosts文件

    cat >> /etc/sysctl.conf <<EOF
    172.23.1.10  test-controller
    172.23.1.11  test-compute1
    172.23.1.12  test-compute2
    EOF
    

    修改内核参数

    cat >> /etc/sysctl.conf <<EOF
    net.ipv4.ip_forward = 1
    net.ipv4.ip_nonlocal_bind = 1
    net.ipv4.conf.all.rp_filter = 0
    net.ipv4.conf.default.rp_filter = 0
    net.bridge.bridge-nf-call-iptables = 1
    net.bridge.bridge-nf-call-ip6tables = 1
    EOF
    modprobe br_netfilter
    sysctl  -p
    

    关闭防火墙和selinux

    sed -i "s/SELINUX=enforcing/SELINUX=disabled/g" /etc/selinux/config
    systemctl stop firewalld
    systemctl disable firewalld
    

    时间同步

    yum install chrony -y
    systemctl enable chronyd.service
    systemctl restart chronyd.service
    chronyc sources
    

    安装openstack基础服务包

    yum install centos-release-openstack-train -y
    yum upgrade -y
    yum install python-openstackclient openstack-selinux -y
    

    控制节点服务部署

    MariaDB

    安装数据库

    yum install mariadb mariadb-server python2-PyMySQL -y
    

    修改数据库配置文件

    cat >> /etc/my.cnf.d/openstack.cnf <<EOF
    [mysqld]
    bind-address = 172.23.1.10
    
    default-storage-engine = innodb
    innodb_file_per_table = on
    max_connections = 4096
    collation-server = utf8_general_ci
    character-set-server = utf8
    EOF
    

    启动数据库服务并初始化

    systemctl enable mariadb.service
    systemctl start mariadb.service
    mysql_secure_installation
    

    RabbitMQ

    安装并启动MQ

    yum install rabbitmq-server -y
    systemctl enable rabbitmq-server.service
    systemctl start rabbitmq-server.service
    

    添加用户并授权

    rabbitmqctl add_user openstack openstack
    rabbitmqctl set_permissions openstack ".*" ".*" ".*"
    

    Memcache

    安装memcache

    yum install memcached python-memcached -y
    

    修改配置文件

    cat /etc/sysconfig/memcached 
    PORT="11211"
    USER="memcached"
    MAXCONN="1024"
    CACHESIZE="64"
    OPTIONS="-l 127.0.0.1,::1,test-controller"
    

    启动memcache服务

    systemctl enable memcached.service
    systemctl start memcached.service
    

    Keystone

    创建数据库

    mysql -u root -p
    #sql语句
    CREATE DATABASE keystone;
    GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'localhost' \
    IDENTIFIED BY 'keystone';
    GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'%' \
    IDENTIFIED BY 'keystone';
    

    安装包文件

    yum install openstack-keystone httpd mod_wsgi -y
    

    修改配置文件 /etc/keystone/keystone.conf

    grep -Ev "^$|^[#;]" /etc/keystone/keystone.conf
    [DEFAULT]
    [application_credential]
    [assignment]
    [auth]
    [cache]
    [catalog]
    [cors]
    [credential]
    [database]
    connection = mysql+pymysql://keystone:keystone@test-controller/keystone
    [domain_config]
    [endpoint_filter]
    [endpoint_policy]
    [eventlet_server]
    [federation]
    [fernet_receipts]
    [fernet_tokens]
    [healthcheck]
    [identity]
    [identity_mapping]
    [jwt_tokens]
    [ldap]
    [memcache]
    [oauth1]
    [oslo_messaging_amqp]
    [oslo_messaging_kafka]
    [oslo_messaging_notifications]
    [oslo_messaging_rabbit]
    [oslo_middleware]
    [oslo_policy]
    [policy]
    [profiler]
    [receipt]
    [resource]
    [revoke]
    [role]
    [saml]
    [security_compliance]
    [shadow_users]
    [token]
    provider = fernet
    [tokenless_auth]
    [totp]
    [trust]
    [unified_limit]
    [wsgi]
    

    构建并初始化数据库

    su -s /bin/sh -c "keystone-manage db_sync" keystone
    keystone-manage fernet_setup --keystone-user keystone --keystone-group keystone
    keystone-manage credential_setup --keystone-user keystone --keystone-group keystone
    

    引导认证服务

    keystone-manage bootstrap --bootstrap-password 123456   --bootstrap-admin-url http://test-controller:5000/v3/   --bootstrap-internal-url http://test-controller:5000/v3/   --bootstrap-public-url http://test-controller:5000/v3/   --bootstrap-region-id test1
    

    修改配置文件 /etc/httpd/conf/httpd.conf

    ServerRoot "/etc/httpd"
    Listen 80
    Include conf.modules.d/*.conf
    User apache
    Group apache
    ServerAdmin root@localhost
    ServerName test-controller
    <Directory />
        AllowOverride none
        Require all denied
    </Directory>
    DocumentRoot "/var/www/html"
    <Directory "/var/www">
        AllowOverride None
        Require all granted
    </Directory>
    <Directory "/var/www/html">
        Options Indexes FollowSymLinks
        AllowOverride None
        Require all granted
    </Directory>
    <IfModule dir_module>
        DirectoryIndex index.html
    </IfModule>
    <Files ".ht*">
        Require all denied
    </Files>
    ErrorLog "logs/error_log"
    LogLevel warn
    <IfModule log_config_module>
        LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
        LogFormat "%h %l %u %t \"%r\" %>s %b" common
        <IfModule logio_module>
          LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio
        </IfModule>
        CustomLog "logs/access_log" combined
    </IfModule>
    <IfModule alias_module>
        ScriptAlias /cgi-bin/ "/var/www/cgi-bin/"
    </IfModule>
    <Directory "/var/www/cgi-bin">
        AllowOverride None
        Options None
        Require all granted
    </Directory>
    <IfModule mime_module>
        TypesConfig /etc/mime.types
        AddType application/x-compress .Z
        AddType application/x-gzip .gz .tgz
        AddType text/html .shtml
        AddOutputFilter INCLUDES .shtml
    </IfModule>
    AddDefaultCharset UTF-8
    <IfModule mime_magic_module>
        MIMEMagicFile conf/magic
    </IfModule>
    EnableSendfile on
    IncludeOptional conf.d/*.conf
    

    创建软链并重启http服务

    ln -s /usr/share/keystone/wsgi-keystone.conf /etc/httpd/conf.d/
    systemctl enable httpd.service
    systemctl start httpd.service
    

    创建环境用户文件

    cat >> admin-openrc <<EOF
    export OS_PROJECT_DOMAIN_NAME=Default
    export OS_USER_DOMAIN_NAME=Default
    export OS_PROJECT_NAME=admin
    export OS_USERNAME=admin
    export OS_PASSWORD=123456
    export OS_AUTH_URL=http://test-controller:5000/v3
    export OS_IDENTITY_API_VERSION=3
    export OS_IMAGE_API_VERSION=2
    EOF
    #加载文件
    . admin-openrc
    

    创建域,项目,用户,角色

    openstack domain create --description "An Example Domain" example
    openstack project create --domain default   --description "Service Project" service
    openstack project create --domain default   --description "Demo Project" myproject
    openstack user create --domain default   --password-prompt myuser
    openstack role create myrole
    openstack role add --project myproject --user myuser myrole
    

    验证

    unset OS_AUTH_URL OS_PASSWORD
    openstack --os-auth-url http://test-controller:5000/v3   --os-project-domain-name Default --os-user-domain-name Default   --os-project-name admin --os-username admin token issue
    openstack --os-auth-url http://test-controller:5000/v3   --os-project-domain-name Default --os-user-domain-name Default   --os-project-name myproject --os-username myuser token issue
    

    Glance

    创建数据库

    mysql -u root -p
    #sql语句
    CREATE DATABASE glance;
    GRANT ALL PRIVILEGES ON glance.* TO 'glance'@'localhost' \
      IDENTIFIED BY 'glance';
    GRANT ALL PRIVILEGES ON glance.* TO 'glance'@'%' \
      IDENTIFIED BY 'glance';
    

    创建服务证书及endpoint

    . admin-openrc
    openstack user create --domain default --password-prompt glance
    openstack role add --project service --user glance admin
    openstack service create --name glance   --description "OpenStack Image" image
    openstack endpoint create --region test1   image public http://test-controller:9292
    openstack endpoint create --region test1   image internal http://test-controller:9292
    openstack endpoint create --region test1   image admin http://test-controller:9292
    

    安装包文件

    yum install openstack-glance -y
    

    修改配置文件 /etc/glance/glance-api.conf

    [DEFAULT]
    [cinder]
    [cors]
    [database]
    connection = mysql+pymysql://glance:glance@test-controller/glance
    [file]
    [glance.store.http.store]
    [glance.store.rbd.store]
    [glance.store.sheepdog.store]
    [glance.store.swift.store]
    [glance.store.vmware_datastore.store]
    [glance_store]
    stores = file,http
    default_store = file
    filesystem_store_datadir = /var/lib/glance/images/
    [image_format]
    [keystone_authtoken]
    www_authenticate_uri  = http://test-controller:5000
    auth_url = http://test-controller:5000
    memcached_servers = test-controller:11211
    auth_type = password
    project_domain_name = Default
    user_domain_name = Default
    project_name = service
    username = glance
    password = glance
    [oslo_concurrency]
    [oslo_messaging_amqp]
    [oslo_messaging_kafka]
    [oslo_messaging_notifications]
    [oslo_messaging_rabbit]
    [oslo_middleware]
    [oslo_policy]
    [paste_deploy]
    flavor = keystone
    [profiler]
    [store_type_location_strategy]
    [task]
    [taskflow_executor]
    

    构建数据并启动服务

    su -s /bin/sh -c "glance-manage db_sync" glance
    systemctl enable openstack-glance-api.service
    systemctl start openstack-glance-api.service
    

    下载镜像并验证服务

    . admin-openrc
    wget http://download.cirros-cloud.net/0.4.0/cirros-0.4.0-x86_64-disk.img
    glance image-create --name "cirros"   --file cirros-0.4.0-x86_64-disk.img   --disk-format qcow2 --container-format bare   --visibility public
    glance image-list
    

    Placement

    创建数据库

    mysql -u root -p
    #sql语句
    CREATE DATABASE placement;
    GRANT ALL PRIVILEGES ON placement.* TO 'placement'@'localhost' \
      IDENTIFIED BY 'placement';
    GRANT ALL PRIVILEGES ON placement.* TO 'placement'@'%' \
      IDENTIFIED BY 'placement';
    

    创建用户和endpoint

    . admin-openrc
    openstack user create --domain default --password-prompt placement
    openstack role add --project service --user placement admin
    openstack service create --name placement   --description "Placement API" placement
    openstack endpoint create --region test1   placement public http://test-controller:8778
    openstack endpoint create --region test1   placement internal http://test-controller:8778
    openstack endpoint create --region test1   placement admin http://test-controller:8778
    

    安装包文件

    yum install openstack-placement-api -y
    

    修改配置文件 /etc/placement/placement.conf

    [DEFAULT]
    [api]
    auth_strategy = keystone
    [cors]
    [keystone_authtoken]
    auth_url = http://test-controller:5000/v3
    memcached_servers = test-controller:11211
    auth_type = password
    project_domain_name = Default
    user_domain_name = Default
    project_name = service
    username = placement
    password = placement
    [oslo_policy]
    [placement]
    [placement_database]
    connection = mysql+pymysql://placement:placement@test-controller/placement
    [profiler]
    

    构建数据并重启服务

    su -s /bin/sh -c "placement-manage db sync" placement
    systemctl restart httpd
    

    nova

    创建数据库

    mysql -u root -p
    #sql语句
    CREATE DATABASE nova_api;
    CREATE DATABASE nova;
    CREATE DATABASE nova_cell0;
    GRANT ALL PRIVILEGES ON nova_api.* TO 'nova'@'localhost' \
      IDENTIFIED BY 'nova';
    GRANT ALL PRIVILEGES ON nova_api.* TO 'nova'@'%' \
      IDENTIFIED BY 'nova';
    GRANT ALL PRIVILEGES ON nova.* TO 'nova'@'localhost' \
      IDENTIFIED BY 'nova';
    GRANT ALL PRIVILEGES ON nova.* TO 'nova'@'%' \
      IDENTIFIED BY 'nova';
    GRANT ALL PRIVILEGES ON nova_cell0.* TO 'nova'@'localhost' \
      IDENTIFIED BY 'nova';
    GRANT ALL PRIVILEGES ON nova_cell0.* TO 'nova'@'%' \
      IDENTIFIED BY 'nova';
    

    创建服务证书及endpoint

    openstack user create --domain default --password-prompt nova
    openstack role add --project service --user nova admin
    openstack service create --name nova   --description "OpenStack Compute" compute
    openstack endpoint create --region test1   compute public http://test-controller:8774/v2.1
    openstack endpoint create --region test1   compute internal http://test-controller:8774/v2.1
    openstack endpoint create --region test1   compute admin http://test-controller:8774/v2.1
    

    安装包文件

    yum install openstack-nova-api openstack-nova-conductor   openstack-nova-novncproxy openstack-nova-scheduler -y
    

    修改配置文件 /etc/nova/nova.conf

    [DEFAULT]
    enabled_apis = osapi_compute,metadata
    transport_url = rabbit://openstack:openstack@test-controller:5672/
    my_ip = 172.23.1.10
    use_neutron = true
    firewall_driver = nova.virt.firewall.NoopFirewallDriver
    [api]
    auth_strategy = keystone
    [api_database]
    connection = mysql+pymysql://nova:nova@test-controller/nova_api
    [barbican]
    [cache]
    [cinder]
    [compute]
    [conductor]
    [console]
    [consoleauth]
    [cors]
    [database]
    connection = mysql+pymysql://nova:nova@test-controller/nova
    [devices]
    [ephemeral_storage_encryption]
    [filter_scheduler]
    [glance]
    api_servers = http://test-controller:9292
    [guestfs]
    [healthcheck]
    [hyperv]
    [ironic]
    [key_manager]
    [keystone]
    [keystone_authtoken]
    www_authenticate_uri = http://test-controller:5000/
    auth_url = http://test-controller:5000/
    memcached_servers = test-controller:11211
    auth_type = password
    project_domain_name = Default
    user_domain_name = Default
    project_name = service
    username = nova
    password = nova
    [libvirt]
    [metrics]
    [mks]
    [neutron]
    auth_url = http://test-controller:5000
    auth_type = password
    project_domain_name = default
    user_domain_name = default
    region_name = test1
    project_name = service
    username = neutron
    password = neutron
    service_metadata_proxy = true
    metadata_proxy_shared_secret = METADATA_SECRET
    [notifications]
    [osapi_v21]
    [oslo_concurrency]
    lock_path = /var/lib/nova/tmp
    [oslo_messaging_amqp]
    [oslo_messaging_kafka]
    [oslo_messaging_notifications]
    [oslo_messaging_rabbit]
    [oslo_middleware]
    [oslo_policy]
    [pci]
    [placement]
    region_name = test1
    project_domain_name = Default
    project_name = service
    auth_type = password
    user_domain_name = Default
    auth_url = http://test-controller:5000/v3
    username = placement
    password = placement
    [powervm]
    [privsep]
    [profiler]
    [quota]
    [rdp]
    [remote_debug]
    [scheduler]
    [serial_console]
    [service_user]
    [spice]
    [upgrade_levels]
    [vault]
    [vendordata_dynamic_auth]
    [vmware]
    [vnc]
    enabled = true
    server_listen = $my_ip
    server_proxyclient_address = $my_ip
    [workarounds]
    [wsgi]
    [xenserver]
    [xvp]
    [zvm]
    

    构建数据并重启服务

    su -s /bin/sh -c "nova-manage api_db sync" nova
    su -s /bin/sh -c "nova-manage cell_v2 map_cell0" nova
    su -s /bin/sh -c "nova-manage cell_v2 create_cell --name=cell1 --verbose" nova
    su -s /bin/sh -c "nova-manage db sync" nova
    su -s /bin/sh -c "nova-manage cell_v2 list_cells" nova
    systemctl enable     openstack-nova-api.service     openstack-nova-scheduler.service     openstack-nova-conductor.service     openstack-nova-novncproxy.service
    systemctl start     openstack-nova-api.service     openstack-nova-scheduler.service     openstack-nova-conductor.service     openstack-nova-novncproxy.service
    

    neutron

    创建数据库

    mysql -u root -p
    #sql语句
    CREATE DATABASE neutron;
    GRANT ALL PRIVILEGES ON neutron.* TO 'neutron'@'localhost' \
      IDENTIFIED BY 'neutron';
    GRANT ALL PRIVILEGES ON neutron.* TO 'neutron'@'%' \
      IDENTIFIED BY 'neutron';
    

    创建服务证书和endpoint

    . admin-openrc
    openstack user create --domain default --password-prompt neutron
    openstack role add --project service --user neutron admin
    openstack service create --name neutron   --description "OpenStack Networking" network
    openstack endpoint create --region test1   network public http://test-controller:9696
    openstack endpoint create --region test1   network internal http://test-controller:9696
    openstack endpoint create --region test1   network admin http://test-controller:9696
    

    选择网络部署模式,这里选择的是Self-service networks

    安装包文件

    yum install openstack-neutron openstack-neutron-ml2   openstack-neutron-linuxbridge ebtables -y
    

    修改配置文件 /etc/neutron/neutron.conf

    [DEFAULT]
    core_plugin = ml2
    service_plugins = router
    allow_overlapping_ips = true
    transport_url = rabbit://openstack:openstack@test-controller
    auth_strategy = keystone
    notify_nova_on_port_status_changes = true
    notify_nova_on_port_data_changes = true
    [nova]
    auth_url = http://test-controller:5000
    auth_type = password
    project_domain_name = default
    user_domain_name = default
    region_name = test1
    project_name = service
    username = nova
    password = nova
    [cors]
    [database]
    connection = mysql+pymysql://neutron:neutron@test-controller/neutron
    [keystone_authtoken]
    www_authenticate_uri = http://test-controller:5000
    auth_url = http://test-controller:5000
    memcached_servers = test-controller:11211
    auth_type = password
    project_domain_name = default
    user_domain_name = default
    project_name = service
    username = neutron
    password = neutron
    [oslo_concurrency]
    lock_path = /var/lib/neutron/tmp
    [oslo_messaging_amqp]
    [oslo_messaging_kafka]
    [oslo_messaging_notifications]
    [oslo_messaging_rabbit]
    [oslo_middleware]
    [oslo_policy]
    [privsep]
    [ssl]
    

    修改配置文件 /etc/neutron/plugins/ml2/ml2_conf.ini

    [DEFAULT]
    [ml2]
    type_drivers = flat,vlan,vxlan
    tenant_network_types = vxlan
    mechanism_drivers = linuxbridge,l2population
    extension_drivers = port_security
    [ml2_type_flat]
    flat_networks = provider,external
    [ml2_type_vxlan]
    vni_ranges = 1:1000
    [securitygroup]
    enable_ipset = true
    

    修改配置文件 /etc/neutron/plugins/ml2/linuxbridge_agent.ini

    [DEFAULT]
    [linux_bridge]
    physical_interface_mappings = provider:eth1,external:eth2
    [vxlan]
    enable_vxlan = true
    local_ip = 172.23.2.10
    l2_population = true
    [securitygroup]
    enable_security_group = true
    firewall_driver = neutron.agent.linux.iptables_firewall.IptablesFirewallDriver
    

    修改配置文件 /etc/neutron/l3_agent.ini

    [DEFAULT]
    interface_driver = linuxbridge
    

    修改配置文件 /etc/neutron/dhcp_agent.ini

    [DEFAULT]
    interface_driver = linuxbridge
    dhcp_driver = neutron.agent.linux.dhcp.Dnsmasq
    enable_isolated_metadata = true
    

    修改配置文件 /etc/neutron/metadata_agent.ini

    [DEFAULT]
    nova_metadata_host = controller
    metadata_proxy_shared_secret = METADATA_SECRET
    [cache]
    

    创建连接并构建数据

    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
    

    启动服务

    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
    systemctl enable neutron-l3-agent.service
    systemctl start neutron-l3-agent.service
    

    dashboard

    安装包文件

    yum install openstack-dashboard -y
    

    修改配置文件 /etc/openstack-dashboard/local_settings

    import os
    from django.utils.translation import ugettext_lazy as _
    from openstack_dashboard.settings import HORIZON_CONFIG
    DEBUG = False
    WEBROOT = '/dashboard/'
    ALLOWED_HOSTS = ['*', 'localhost']
    LOCAL_PATH = '/tmp'
    SECRET_KEY='63c36da7926815b03aa4'
    CACHES = {
        'default': {
             'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
             'LOCATION': 'test-controller:11211',
        }
    }
    SESSION_ENGINE = 'django.contrib.sessions.backends.cache'
    EMAIL_BACKEND = 'django.core.mail.backends.console.EmailBackend'
    OPENSTACK_HOST = "test-controller"
    OPENSTACK_KEYSTONE_URL = "http://%s:5000/v3" % OPENSTACK_HOST
    OPENSTACK_KEYSTONE_MULTIDOMAIN_SUPPORT = True
    OPENSTACK_API_VERSIONS = {
        "identity": 3,
        "image": 2,
        "volume": 3,
    }
    OPENSTACK_KEYSTONE_DEFAULT_DOMAIN = "Default"
    OPENSTACK_KEYSTONE_DEFAULT_ROLE = "user"
    OPENSTACK_NEUTRON_NETWORK = {
        'enable_auto_allocated_network': False,
        'enable_distributed_router': False,
        'enable_fip_topology_check': True,
        'enable_ha_router': False,
        'enable_ipv6': False,
        # TODO(amotoki): Drop OPENSTACK_NEUTRON_NETWORK completely from here.
        # enable_quotas has the different default value here.
        'enable_quotas': False,
        'enable_rbac_policy': True,
        'enable_router': True,
        'default_dns_nameservers': [],
        'supported_provider_types': ['*'],
        'segmentation_id_range': {},
        'extra_provider_types': {},
        'supported_vnic_types': ['*'],
        'physical_networks': [],
    }
    TIME_ZONE = "Asia/Shanghai"
    LOGGING = {
        'version': 1,
        # When set to True this will disable all logging except
        # for loggers specified in this configuration dictionary. Note that
        # if nothing is specified here and disable_existing_loggers is True,
        # django.db.backends will still log unless it is disabled explicitly.
        'disable_existing_loggers': False,
        # If apache2 mod_wsgi is used to deploy OpenStack dashboard
        # timestamp is output by mod_wsgi. If WSGI framework you use does not
        # output timestamp for logging, add %(asctime)s in the following
        # format definitions.
        'formatters': {
            'console': {
                'format': '%(levelname)s %(name)s %(message)s'
            },
            'operation': {
                # The format of "%(message)s" is defined by
                # OPERATION_LOG_OPTIONS['format']
                'format': '%(message)s'
            },
        },
        'handlers': {
            'null': {
                'level': 'DEBUG',
                'class': 'logging.NullHandler',
            },
            'console': {
                # Set the level to "DEBUG" for verbose output logging.
                'level': 'DEBUG' if DEBUG else 'INFO',
                'class': 'logging.StreamHandler',
                'formatter': 'console',
            },
            'operation': {
                'level': 'INFO',
                'class': 'logging.StreamHandler',
                'formatter': 'operation',
            },
        },
        'loggers': {
            'horizon': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            'horizon.operation_log': {
                'handlers': ['operation'],
                'level': 'INFO',
                'propagate': False,
            },
            'openstack_dashboard': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            'novaclient': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            'cinderclient': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            'keystoneauth': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            'keystoneclient': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            'glanceclient': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            'neutronclient': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            'swiftclient': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            'oslo_policy': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            'openstack_auth': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            'django': {
                'handlers': ['console'],
                'level': 'DEBUG',
                'propagate': False,
            },
            # Logging from django.db.backends is VERY verbose, send to null
            # by default.
            'django.db.backends': {
                'handlers': ['null'],
                'propagate': False,
            },
            'requests': {
                'handlers': ['null'],
                'propagate': False,
            },
            'urllib3': {
                'handlers': ['null'],
                'propagate': False,
            },
            'chardet.charsetprober': {
                'handlers': ['null'],
                'propagate': False,
            },
            'iso8601': {
                'handlers': ['null'],
                'propagate': False,
            },
            'scss': {
                'handlers': ['null'],
                'propagate': False,
            },
        },
    }
    SECURITY_GROUP_RULES = {
        'all_tcp': {
            'name': _('All TCP'),
            'ip_protocol': 'tcp',
            'from_port': '1',
            'to_port': '65535',
        },
        'all_udp': {
            'name': _('All UDP'),
            'ip_protocol': 'udp',
            'from_port': '1',
            'to_port': '65535',
        },
        'all_icmp': {
            'name': _('All ICMP'),
            'ip_protocol': 'icmp',
            'from_port': '-1',
            'to_port': '-1',
        },
        'ssh': {
            'name': 'SSH',
            'ip_protocol': 'tcp',
            'from_port': '22',
            'to_port': '22',
        },
        'smtp': {
            'name': 'SMTP',
            'ip_protocol': 'tcp',
            'from_port': '25',
            'to_port': '25',
        },
        'dns': {
            'name': 'DNS',
            'ip_protocol': 'tcp',
            'from_port': '53',
            'to_port': '53',
        },
        'http': {
            'name': 'HTTP',
            'ip_protocol': 'tcp',
            'from_port': '80',
            'to_port': '80',
        },
        'pop3': {
            'name': 'POP3',
            'ip_protocol': 'tcp',
            'from_port': '110',
            'to_port': '110',
        },
        'imap': {
            'name': 'IMAP',
            'ip_protocol': 'tcp',
            'from_port': '143',
            'to_port': '143',
        },
        'ldap': {
            'name': 'LDAP',
            'ip_protocol': 'tcp',
            'from_port': '389',
            'to_port': '389',
        },
        'https': {
            'name': 'HTTPS',
            'ip_protocol': 'tcp',
            'from_port': '443',
            'to_port': '443',
        },
        'smtps': {
            'name': 'SMTPS',
            'ip_protocol': 'tcp',
            'from_port': '465',
            'to_port': '465',
        },
        'imaps': {
            'name': 'IMAPS',
            'ip_protocol': 'tcp',
            'from_port': '993',
            'to_port': '993',
        },
        'pop3s': {
            'name': 'POP3S',
            'ip_protocol': 'tcp',
            'from_port': '995',
            'to_port': '995',
        },
        'ms_sql': {
            'name': 'MS SQL',
            'ip_protocol': 'tcp',
            'from_port': '1433',
            'to_port': '1433',
        },
        'mysql': {
            'name': 'MYSQL',
            'ip_protocol': 'tcp',
            'from_port': '3306',
            'to_port': '3306',
        },
        'rdp': {
            'name': 'RDP',
            'ip_protocol': 'tcp',
            'from_port': '3389',
            'to_port': '3389',
        },
    }
    

    修改配置文件 /etc/httpd/conf.d/openstack-dashboard.conf

    WSGIDaemonProcess dashboard
    WSGIProcessGroup dashboard
    WSGISocketPrefix run/wsgi
    WSGIApplicationGroup %{GLOBAL}
    WSGIScriptAlias /dashboard /usr/share/openstack-dashboard/openstack_dashboard/wsgi/django.wsgi
    Alias /dashboard/static /usr/share/openstack-dashboard/static
    <Directory /usr/share/openstack-dashboard/openstack_dashboard/wsgi>
      Options All
      AllowOverride All
      Require all granted
    </Directory>
    <Directory /usr/share/openstack-dashboard/static>
      Options All
      AllowOverride All
      Require all granted
    </Directory>
    

    重启服务

    systemctl restart httpd.service memcached.service
    

    计算节点服务部署

    nova

    安装包文件

    yum install openstack-nova-compute -y
    

    修改配置文件 /etc/nova/nova.conf

    #所有计算节点配置文件都相同,注意修改my_ip所对应的ip即可
    [DEFAULT]
    enabled_apis = osapi_compute,metadata
    transport_url = rabbit://openstack:openstack@test-controller
    my_ip = 172.23.1.12
    use_neutron = true
    firewall_driver = nova.virt.firewall.NoopFirewallDriver
    [api]
    auth_strategy = keystone
    [api_database]
    [barbican]
    [cache]
    [cinder]
    [compute]
    [conductor]
    [console]
    [consoleauth]
    [cors]
    [database]
    [devices]
    [ephemeral_storage_encryption]
    [filter_scheduler]
    [glance]
    api_servers = http://test-controller:9292
    [guestfs]
    [healthcheck]
    [hyperv]
    [ironic]
    [key_manager]
    [keystone]
    [keystone_authtoken]
    www_authenticate_uri = http://test-controller:5000/
    auth_url = http://test-controller:5000/
    memcached_servers = test-controller:11211
    auth_type = password
    project_domain_name = Default
    user_domain_name = Default
    project_name = service
    username = nova
    password = nova
    [libvirt]
    [metrics]
    [mks]
    [neutron]
    auth_url = http://test-controller:5000
    auth_type = password
    project_domain_name = default
    user_domain_name = default
    region_name = test1
    project_name = service
    username = neutron
    password = neutron
    [notifications]
    [osapi_v21]
    [oslo_concurrency]
    lock_path = /var/lib/nova/tmp
    [oslo_messaging_amqp]
    [oslo_messaging_kafka]
    [oslo_messaging_notifications]
    [oslo_messaging_rabbit]
    [oslo_middleware]
    [oslo_policy]
    [pci]
    [placement]
    region_name = test1
    project_domain_name = Default
    project_name = service
    auth_type = password
    user_domain_name = Default
    auth_url = http://test-controller:5000/v3
    username = placement
    password = placement
    [powervm]
    [privsep]
    [profiler]
    [quota]
    [rdp]
    [remote_debug]
    [scheduler]
    [serial_console]
    [service_user]
    [spice]
    [upgrade_levels]
    [vault]
    [vendordata_dynamic_auth]
    [vmware]
    [vnc]
    enabled = true
    server_listen = 0.0.0.0
    server_proxyclient_address = $my_ip
    novncproxy_base_url = http://test-controller:6080/vnc_auto.html
    [workarounds]
    [wsgi]
    [xenserver]
    [xvp]
    [zvm]
    

    启动服务

    systemctl enable libvirtd.service openstack-nova-compute.service
    systemctl start libvirtd.service openstack-nova-compute.service
    

    neutron

    安装包文件

    yum install openstack-neutron-linuxbridge ebtables ipset -y
    

    修改配置文件 /etc/neutron/neutron.conf

    [DEFAULT]
    transport_url = rabbit://openstack:openstack@test-controller
    auth_strategy = keystone
    [cors]
    [database]
    [keystone_authtoken]
    www_authenticate_uri = http://test-controller:5000
    auth_url = http://test-controller:5000
    memcached_servers = test-controller:11211
    auth_type = password
    project_domain_name = default
    user_domain_name = default
    project_name = service
    username = neutron
    password = neutron
    [oslo_concurrency]
    lock_path = /var/lib/neutron/tmp
    [oslo_messaging_amqp]
    [oslo_messaging_kafka]
    [oslo_messaging_notifications]
    [oslo_messaging_rabbit]
    [oslo_middleware]
    [oslo_policy]
    [privsep]
    [ssl]
    

    修改配置文件 /etc/neutron/plugins/ml2/linuxbridge_agent.ini

    [DEFAULT]
    [linux_bridge]
    physical_interface_mappings = external:eth1
    [vxlan]
    enable_vxlan = true
    local_ip = 172.23.4.10
    l2_population = true
    [securitygroup]
    enable_security_group = true
    firewall_driver = neutron.agent.linux.iptables_firewall.IptablesFirewallDriver
    

    启动服务

    systemctl restart openstack-nova-compute.service
    systemctl enable neutron-linuxbridge-agent.service
    systemctl start neutron-linuxbridge-agent.service
    

    Web页面操作

    登录web页面 http://test-controller/dashboard (需要本地绑host文件或者通过内网域名解析之后可以通过域名访问)

    image.png

    创建一个子网
    管理员-->网络-->网络-->创建网络


    image.png image.png image.png

    创建一个外部网络


    image.png image.png image.png

    创建一个路由器


    image.png

    编辑自己需要的网络环境


    image.png

    官方部署文档可参考:https://docs.openstack.org/install-guide/openstack-services.html#minimal-deployment-for-train

    相关文章

      网友评论

          本文标题:Openstack LinuxBridge+vxlan搭建部署

          本文链接:https://www.haomeiwen.com/subject/alhlsltx.html