Install and configure Placement for openSUSE and SUSE Linux Enterprise¶
This section describes how to install and configure the placement service when using openSUSE or SUSE Linux Enterprise packages.
Prerequisites¶
Before you install and configure the placement service, you must create a database, service credentials, and API endpoints.
Create Database¶
- To create the database, complete these steps: - Use the database access client to connect to the database server as the - rootuser:- $ mysql -u root -p 
- Create the - placementdatabase:- MariaDB [(none)]> CREATE DATABASE placement;
- Grant proper access to the database: - MariaDB [(none)]> GRANT ALL PRIVILEGES ON placement.* TO 'placement'@'localhost' \ IDENTIFIED BY 'PLACEMENT_DBPASS'; MariaDB [(none)]> GRANT ALL PRIVILEGES ON placement.* TO 'placement'@'%' \ IDENTIFIED BY 'PLACEMENT_DBPASS'; - Replace - PLACEMENT_DBPASSwith a suitable password.
- Exit the database access client. 
 
Configure User and Endpoints¶
- Source the - admincredentials to gain access to admin-only CLI commands:- $ . admin-openrc 
- Create a Placement service user using your chosen - PLACEMENT_PASS:- $ openstack user create --domain default --password-prompt placement User Password: Repeat User Password: +---------------------+----------------------------------+ | Field | Value | +---------------------+----------------------------------+ | domain_id | default | | enabled | True | | id | fa742015a6494a949f67629884fc7ec8 | | name | placement | | options | {} | | password_expires_at | None | +---------------------+----------------------------------+ 
- Add the Placement user to the service project with the admin role: - $ openstack role add --project service --user placement admin - Note - This command provides no output. 
- Create the Placement API entry in the service catalog: - $ openstack service create --name placement \ --description "Placement API" placement +-------------+----------------------------------+ | Field | Value | +-------------+----------------------------------+ | description | Placement API | | enabled | True | | id | 2d1a27022e6e4185b86adac4444c495f | | name | placement | | type | placement | +-------------+----------------------------------+ 
- Create the Placement API service endpoints: - Note - Depending on your environment, the URL for the endpoint will vary by port (possibly 8780 instead of 8778, or no port at all) and hostname. You are responsible for determining the correct URL. - $ openstack endpoint create --region RegionOne \ placement public http://controller:8778 +--------------+----------------------------------+ | Field | Value | +--------------+----------------------------------+ | enabled | True | | id | 2b1b2637908b4137a9c2e0470487cbc0 | | interface | public | | region | RegionOne | | region_id | RegionOne | | service_id | 2d1a27022e6e4185b86adac4444c495f | | service_name | placement | | service_type | placement | | url | http://controller:8778 | +--------------+----------------------------------+ $ openstack endpoint create --region RegionOne \ placement internal http://controller:8778 +--------------+----------------------------------+ | Field | Value | +--------------+----------------------------------+ | enabled | True | | id | 02bcda9a150a4bd7993ff4879df971ab | | interface | internal | | region | RegionOne | | region_id | RegionOne | | service_id | 2d1a27022e6e4185b86adac4444c495f | | service_name | placement | | service_type | placement | | url | http://controller:8778 | +--------------+----------------------------------+ $ openstack endpoint create --region RegionOne \ placement admin http://controller:8778 +--------------+----------------------------------+ | Field | Value | +--------------+----------------------------------+ | enabled | True | | id | 3d71177b9e0f406f98cbff198d74b182 | | interface | admin | | region | RegionOne | | region_id | RegionOne | | service_id | 2d1a27022e6e4185b86adac4444c495f | | service_name | placement | | service_type | placement | | url | http://controller:8778 | +--------------+----------------------------------+ 
Install and configure components¶
Note
Default configuration files vary by distribution. You might need to add
these sections and options rather than modifying existing sections and
options. Also, an ellipsis (...) in the configuration snippets indicates
potential default configuration options that you should retain.
Note
As of the Newton release, SUSE OpenStack packages are shipped with the
upstream default configuration files. For example,
/etc/placement/placement.conf has customizations in
/etc/placement/placement.conf.d/010-placement.conf. While the following
instructions modify the default configuration file, adding a new file in
/etc/placement/placement.conf.d achieves the same result.
- Install the packages: - # zypper install openstack-placement 
- Edit the - /etc/placement/placement.conffile and complete the following actions:- In the - [placement_database]section, configure database access:- [placement_database] # ... connection = mysql+pymysql://placement:PLACEMENT_DBPASS@controller/placement - Replace - PLACEMENT_DBPASSwith the password you chose for the placement database.
- In the - [api]and- [keystone_authtoken]sections, configure Identity service access:- [api] # ... auth_strategy = keystone [keystone_authtoken] # ... auth_url = http://controller:5000/v3 memcached_servers = controller:11211 auth_type = password project_domain_name = Default user_domain_name = Default project_name = service username = placement password = PLACEMENT_PASS - Replace - PLACEMENT_PASSwith the password you chose for the- placementuser in the Identity service.- Note - Comment out or remove any other options in the - [keystone_authtoken]section.- Note - The value of - user_name,- password,- project_domain_nameand- user_domain_nameneed to be in sync with your keystone config.
 
- Populate the - placementdatabase:- # su -s /bin/sh -c "placement-manage db sync" placement - Note - Ignore any deprecation messages in this output. 
Finalize installation¶
- Enable the placement API Apache vhost: - # mv /etc/apache2/vhosts.d/openstack-placement-api.conf.sample \ /etc/apache2/vhosts.d/openstack-placement-api.conf # systemctl reload apache2.service 
