安裝環境html
Centos7node
單節點,單網卡安裝python
準備工做mysql
NAT方式下的網絡配置:linux
找到須要的網絡配置參數:sql
[root@localhost ~]# cat /etc/sysconfig/network-scripts/ifcfg-eno16777736數據庫
TYPE="Ethernet"bootstrap
BOOTPROTO=staticvim
DEFROUTE="yes"centos
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
NAME="eno16777736"
UUID="e52041f9-6cce-49f5-9f75-dced407765a4"
DEVICE="eno16777736"
ONBOOT="yes"
IPADDR=192.168.174.222
NETMASK=255.255.255.0
GATEWAY=192.168.174.2
PEERDNS="yes"
DNS1=8.8.8.8
IPV6_PEERDNS=yes
IPV6_PEERROUTES=yes
修改主機名:
[root@localhost ~]# hostnamectl set-hostname controller --static –transient
修改hosts文件:
[root@controller ~]# vi /etc/hosts
192.168.174.222 controller
安裝NTP_SERVER
[root@controller ~]# yum install chrony
啓動ntp:
[root@controller ~]# systemctl enable chronyd.service
[root@controller ~]# systemctl start chronyd.service
檢查ntp
[root@controller ~]# chronyc sources
效果如圖:
安裝rdo源:
[root@controller ~]# yuminstall centos-release-openstack-newton –y
[root@controller ~]# yuminstall https://rdoproject.org/repos/rdo-release.rpm -y
進行升級:
[root@controller ~]# yum upgrade
安裝openstack客戶端:
[root@controller ~]# yum install python-openstackclient –y
[root@controller ~]# yum install openstack-selinux -y
安裝mysql數據庫:
[root@controller ~]# yum install mariadb mariadb-serverpython2-PyMySQL –y
配置mysql /etc/my.cnf.d/openstack.cnf
[root@controller ~]# vim /etc/my.cnf.d/openstack.cnf
[mysqld]
bind-address = 0.0.0.0
default-storage-engine = innodb
innodb_file_per_table
max_connections = 4096
collation-server = utf8_general_ci
character-set-server = utf8
完成安裝:Start thedatabase service and configure it to start when the system boots:
[root@controller ~]# systemctl enable mariadb.service
[root@controller ~]# systemctl start mariadb.service
設置mysql用戶root登錄密碼:root
[root@controller ~]# mysql_secure_installation
安裝消息隊列:Install thepackage
[root@controller ~]# yum install rabbitmq-server –y
啓動:
[root@controller ~]# systemctl enable rabbitmq-server.service
[root@controller ~]# systemctl start rabbitmq-server.service
建立用戶Add the openstack user:
[root@controller ~]# rabbitmqctl add_user openstack RABBIT_PASS
設置權限Permitconfiguration, write, and read access for the openstackuser
[root@controller ~]# rabbitmqctl set_permissions openstack ".*" ".*"".*"
安裝memcached
[root@controller ~]# yum install memcached python-memcached –y
設置開機啓動:
[root@controller ~]# systemctl enable memcached.service
[root@controller ~]# systemctl start memcached.service
安裝認證服務:keystone
1.To create thedatabase, complete the following actions:
[root@controller ~]# mysql-u root -proot
Create the keystone database:
MariaDB [(none)]> CREATE DATABASE keystone;
Grant properaccess to the keystone database:
MariaDB[(none)]> GRANTALL PRIVILEGES ON keystone.* TO 'keystone'@'localhost' \
-> IDENTIFIED BY'KEYSTONE_DBPASS';
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> GRANT ALLPRIVILEGES ON keystone.* TO 'keystone'@'%' \
-> IDENTIFIED BY'KEYSTONE_DBPASS';
Query OK, 0 rows affected (0.00 sec)
1.Run thefollowing command to install the packages:
# yum install openstack-keystone htpd mod_wsgi
2.dit the /etc/keystone/keystone.conf file andcomplete the following actions:
In the [database] section,configure database access:
[database]
...
connection = mysql+pymysql://keystone:KEYSTONE_DBPASS@controller/keystone
Replace KEYSTONE_DBPASS with thepassword you chose for the database.
In the [token] section,configure the Fernet token provider:
[token]
...
provider = fernet
3.pulate theIdentity service database:同步數據庫
# su -s /bin/sh -c "keystone-manage db_sync" keystone4.nitialize Fernet key repositories:
# keystone-manage fernet_setup --keystone-user keystone --keystone-group keystone
# keystone-manage credential_setup --keystone-user keystone --keystone-group keystone
5.strap theIdentity service:
# keystone-manage bootstrap --bootstrap-password ADMIN_PASS \
--bootstrap-admin-url http://controller:35357/v3/ \
--bootstrap-internal-url http://controller:35357/v3/ \
--bootstrap-public-url http://controller:5000/v3/ \
--bootstrap-region-id RegionOne
Replace ADMIN_PASS with a suitablepassword for an administrative user。
Edit the /etc/httpd/conf/httpd.conf file andconfigure the ServerName option toreference the controller node:
ServerName controller
Create a link to the /usr/share/keystone/wsgi-keystone.conf file:
# ln -s /usr/share/keystone/wsgi-keystone.conf /etc/httpd/conf.d/
Start the Apache HTTP service and configure itto start when the system boots:
# systemctl enable httpd.service
# systemctl start httpd.service
Configure the administrative account.
$ export S_USERNAME=admin
$exportOS_PASSWORD=ADMIN_PASS
$exportOS_PROJECT_NAME=admin
$exportOS_USER_DOMAIN_NAME=Default
$exportOS_PROJECT_DOMAIN_NAME=Default
$exportOS_AUTH_URL=http://controller:35357/v3
$exportOS_IDENTITY_API_VERSION=3
This guide uses a service project that containsa unique user for each service that you add to your environment. Create the service project
openstack project create --domain default \
--description "Service Project" service
Regular (non-admin) tasks should use anunprivileged project and user. As an example, this guide creates the demoproject anduser.
Create the demo project:
openstack project create --domain default \
--description "Demo Project" demo
Create the demo user:
openstack user create --domain default \
--password-prompt demo
密碼:demo
Create the user role:
openstack role create user
Add the user role to the demo project anduser:
openstack role add --project demo --user demo user
1.For securityreasons, disable the temporary authentication token mechanism:
Edit the /etc/keystone/keystone-paste.ini file and remove admin_token_auth from the [pipeline:public_api],[pipeline:admin_api], and [pipeline:api_v3] sections.
2.Unset thetemporary OS_AUTH_URL and OS_PASSWORD environmentvariable:
unset OS_AUTH_URL OS_PASSWORD
3.As the admin user, request anauthentication token:
$ openstack --os-auth-url http://controller:35357/v3 \
--os-project-domain-name default --os-user-domain-name default \
--os-project-name admin --os-username admin token issue
1.Edit the admin-openrc file and add thefollowing content:
exportOS_PROJECT_DOMAIN_NAME=default
exportOS_USER_DOMAIN_NAME=default
exportOS_PROJECT_NAME=admin
exportOS_USERNAME=admin
exportOS_PASSWORD=ADMIN_PASS
exportOS_AUTH_URL=http://controller:35357/v3
exportOS_IDENTITY_API_VERSION=3
exportOS_IMAGE_API_VERSION=2
執行
[root@controller ~]# . admin-openrc
[root@controller~]# openstack --os-auth-urlhttp://controller:35357/v3 --os-project-domain-name default --os-user-domain-name default --os-project-name admin --os-username admintoken issue
1.Load the admin-openrc file to populateenvironment variables with the location of the Identity service and the adminproject and usercredentials:
$ . admin-openrc
2.Request anauthentication token:
openstack token issue
1.To create the database, completethese steps:
Use the databaseaccess client to connect to the database server as the root user:
mysql -u root -p
Create the glance database:
mysql> CREATE DATABASE glance;
Grant properaccess to the glance database:
mysql> GRANT ALL PRIVILEGES ON glance.* TO 'glance'@'localhost' \
IDENTIFIED BY 'GLANCE_DBPASS';
mysql> GRANT ALL PRIVILEGES ON glance.* TO 'glance'@'%' \
IDENTIFIED BY 'GLANCE_DBPASS';
To create the service credentials, completethese steps:
$ openstack user create --domain default --password-prompt glance
Add the admin role to the glance user and service project:
openstack role add --project service --user glance admin
Create the glance service entity:
openstack service create --name glance \
--description "OpenStack Image" p_w_picpath
Create the Imageservice API endpoints:
openstack endpoint create --region RegionOne \
p_w_picpath public http://controller:9292
openstack endpoint create --region RegionOne \
p_w_picpath internal http://controller:9292
openstack endpoint create --region RegionOne \
p_w_picpath admin http://controller:9292
安裝glance:
# yum install openstack-glance –y
Edit the /etc/glance/glance-api.conf file andcomplete the following actions:
In the [database] section,configure database access:
[database]
...
connection = mysql+pymysql://glance:GLANCE_DBPASS@controller/glance
In the [keystone_authtoken] and [paste_deploy] sections,configure Identity service access:
[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 = glance
password = GLANCE_PASS
[paste_deploy]
...
flavor = keystone
In the [glance_store] section,configure the local file system store and location of p_w_picpath files:
[glance_store]
...
stores = file,http
default_store = file
filesystem_store_datadir = /var/lib/glance/p_w_picpaths/
Edit the /etc/glance/glance-registry.conf file andcomplete the following actions:
In the [database] section,configure database access:
[database]
...
connection = mysql+pymysql://glance:GLANCE_DBPASS@controller/glance
In the [keystone_authtoken] and [paste_deploy] sections,configure Identity service access:
[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 = glance
password = GLANCE_PASS
[paste_deploy]
...
flavor = keystone
Populate the Image service database:
# su -s /bin/sh -c "glance-manage db_sync" glance
Finalize installation
# systemctl enable openstack-glance-api.service \
openstack-glance-registry.service
# systemctl start openstack-glance-api.service \
openstack-glance-registry.service
2.Download thesource p_w_picpath:
wget http://download.cirros-cloud.net/0.3.4/cirros-0.3.4-x86_64-disk.img
Upload the p_w_picpath to the Image service using the QCOW2 disk format, bare containerformat, and public visibility so all projects can access it:
openstack p_w_picpath create "cirros"\
--file cirros-0.3.4-x86_64-disk.img \
--disk-format qcow2 --container-format bare \
--public
Confirm upload of the p_w_picpath and validateattributes:
openstack p_w_picpath list
To create the databases, complete these steps:
Use the databaseaccess client to connect to the database server as the root user:
mysql -u root -p
Create the nova_api and nova databases:
mysql> CREATE DATABASE nova_api;
mysql> CREATE DATABASE nova;
Grant properaccess to the databases:
mysql> GRANT ALL PRIVILEGES ON nova_api.* TO 'nova'@'localhost' \
IDENTIFIED BY 'NOVA_DBPASS';
mysql> GRANT ALL PRIVILEGES ON nova_api.* TO 'nova'@'%' \
IDENTIFIED BY 'NOVA_DBPASS';
mysql> GRANT ALL PRIVILEGES ON nova.* TO 'nova'@'localhost' \
IDENTIFIED BY 'NOVA_DBPASS';
mysql> GRANT ALL PRIVILEGES ON nova.* TO 'nova'@'%' \
IDENTIFIED BY 'NOVA_DBPASS';
To create the service credentials, completethese steps:
Create the nova user:
openstack user create --domain default \
--password-prompt nova
密碼:nova
Add the admin role to the nova user:
openstack role add --project service --user nova admin
Create the nova service entity:
openstack service create --name nova \
--description "OpenStack Compute" compute
Create the Compute service API endpoints:
openstack endpoint create --region RegionOne \
compute public http://controller:8774/v2.1/%\(tenant_id\)s
openstack endpoint create --region RegionOne \ compute internal http://controller:8774/v2.1/%\(tenant_id\)s
openstack endpoint create --region RegionOne \ compute admin http://controller:8774/v2.1/%\(tenant_id\)s
1. Install and configure components
yum install openstack-nova-api openstack-nova-conductor \
openstack-nova-console openstack-nova-novncproxy \
openstack-nova-scheduler
2.it the /etc/nova/nova.conf file andcomplete the following actions:
In the [DEFAULT] section, enableonly the compute and metadata APIs:
[DEFAULT]
...
enabled_apis = osapi_compute,metadata
In the [api_database] and [database] sections,configure database access:
[api_database]
...
connection = mysql+pymysql://nova:NOVA_DBPASS@controller/nova_api
[database]
...
connection = mysql+pymysql://nova:NOVA_DBPASS@controller/nova
In the [DEFAULT] section,configure RabbitMQ message queueaccess:
[DEFAULT]
...
transport_url = rabbit://openstack:RABBIT_PASS@controller
In the [DEFAULT] and [keystone_authtoken] sections,configure Identity service access:
[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 = nova
password = NOVA_PASS
In the [DEFAULT] section,configure the my_ip option to usethe management interface IP address of the controller node:
[DEFAULT]
...
my_ip = 192.168.174.222
In the [DEFAULT] section, enablesupport for the Networking service:
[DEFAULT]
...
use_neutron = True
firewall_driver = nova.virt.firewall.NoopFirewallDriver
In the [vnc] section,configure the VNC proxy to use the management interface IP address of thecontroller node:
[vnc]
...
vncserver_listen = $my_ip
vncserver_proxyclient_address = $my_ip
In the [glance] section,configure the location of the Image service API:
[glance]
...
api_servers = http://controller:9292
In the [oslo_concurrency] section,configure the lock path:
[oslo_concurrency]
...
lock_path = /var/lib/nova/tmp
Populate theCompute databases:
# su -s /bin/sh -c "nova-manage api_db sync" nova
# su -s /bin/sh -c "nova-manage db sync" nova
Finalizeinstallation
# systemctl enable openstack-nova-api.service \
openstack-nova-consoleauth.service openstack-nova-scheduler.service \
openstack-nova-conductor.service openstack-nova-novncproxy.service
# systemctl start openstack-nova-api.service \
openstack-nova-consoleauth.service openstack-nova-scheduler.service \
openstack-nova-conductor.service openstack-nova-novncproxy.service
(注:如下文件所需配置的大部份內容已經在上步驟已經完成,只需配置沒有配置的便可)
yum install openstack-nova-compute
Edit the /etc/nova/nova.conf file andcomplete the following actions:
In the [DEFAULT] section, enableonly the compute and metadata APIs:
[DEFAULT]
...
enabled_apis = osapi_compute,metadata
In the [DEFAULT] section,configure RabbitMQ message queueaccess:
[DEFAULT]
...
transport_url = rabbit://openstack:RABBIT_PASS@controller
In the [DEFAULT] and [keystone_authtoken] sections,configure Identity service access:
[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 = nova
password = NOVA_PASS
In the [DEFAULT] section,configure the my_ip option:
[DEFAULT]
...
my_ip = MANAGEMENT_INTERFACE_IP_ADDRESS
In the [DEFAULT] section, enablesupport for the Networking service:
[DEFAULT]
...
use_neutron = True
firewall_driver = nova.virt.firewall.NoopFirewallDriver
In the [vnc] section, enableand configure remote console access:
[vnc]
...
enabled = True
vncserver_listen = 0.0.0.0
vncserver_proxyclient_address = $my_ip
novncproxy_base_url = http://controller:6080/vnc_auto.html
In the [glance] section,configure the location of the Image service API:
[glance]
...
api_servers = http://controller:9292
In the [oslo_concurrency] section,configure the lock path:
[oslo_concurrency]
...
lock_path = /var/lib/nova/tmp
Finalize installation
Determine whether your compute node supportshardware acceleration for virtual machines:
egrep -c '(vmx|svm)' /proc/cpuinfo
If this command returns a value of one or greater, your compute node supports hardware acceleration whichtypically requires no additional configuration.
If this command returns a value of zero,your compute node does not support hardware acceleration and you must configure libvirt to use QEMU instead of KVM.
輸出值大於2 libvirt 配置成KVM
Edit the [libvirt] section in the /etc/nova/nova.conf file as follows:
[libvirt]
...
virt_type = kvm
Start the Compute service including itsdependencies and configure them to start automatically when the system boots:
systemctl enable libvirtd.service openstack-nova-compute.service
systemctl start libvirtd.service openstack-nova-compute.service
List service components to verify successfullaunch and registration of each process:
openstack compute service list