2a2fe91602
This change corrects many problems detected by the `yamllint` linter. It's a preparation for enabling this linter in change Ie746230f28fe3ed0cf218201d5a3810f7bc44070. For instance, the first run of the YAML linter helped discovering a key duplication problem in `oso_ha.yaml`: the `depends_on` key was present twice, so the first occurence was ignored. Other changes are cosmetic: extra spaces, extra blank lines, missing newlines at end-of-file, etc. Change-Id: I7f2369adfb152fd2a74b9b105e969e653e592922
150 lines
5.0 KiB
YAML
150 lines
5.0 KiB
YAML
heat_template_version: 2013-05-23
|
|
|
|
description: >
|
|
An example Heat Orchestration Template (HOT).
|
|
WordPress is web software you can use to create a beautiful website
|
|
or blog. This template installs two instances: one running a
|
|
WordPress deployment and the other using a local MySQL database to
|
|
store the data.
|
|
|
|
parameters:
|
|
|
|
key_name:
|
|
type: string
|
|
description: Name of a KeyPair to enable SSH access to the instance
|
|
default: test_key
|
|
|
|
instance_type:
|
|
type: string
|
|
description: Instance type for web and DB servers
|
|
default: m1.small
|
|
constraints:
|
|
- allowed_values: [m1.tiny, m1.small, m1.medium, m1.large, m1.xlarge]
|
|
description: instance_type must be a valid instance type
|
|
|
|
image_id:
|
|
type: string
|
|
description: >
|
|
Name or ID of the image to use for the WordPress server.
|
|
Recommended values are fedora-20.i386 or fedora-20.x86_64;
|
|
get them from http://cloud.fedoraproject.org/fedora-20.i386.qcow2
|
|
or http://cloud.fedoraproject.org/fedora-20.x86_64.qcow2 .
|
|
default: fedora-20.x86_64
|
|
|
|
db_name:
|
|
type: string
|
|
description: WordPress database name
|
|
default: wordpress
|
|
constraints:
|
|
- length: { min: 1, max: 64 }
|
|
description: db_name must be between 1 and 64 characters
|
|
- allowed_pattern: '[a-zA-Z][a-zA-Z0-9]*'
|
|
description: >
|
|
db_name must begin with a letter and contain only alphanumeric
|
|
characters
|
|
|
|
db_username:
|
|
type: string
|
|
description: The WordPress database admin account username
|
|
default: admin
|
|
hidden: true
|
|
constraints:
|
|
- length: { min: 1, max: 16 }
|
|
description: db_username must be between 1 and 16 characters
|
|
- allowed_pattern: '[a-zA-Z][a-zA-Z0-9]*'
|
|
description: >
|
|
db_username must begin with a letter and contain only alphanumeric
|
|
characters
|
|
|
|
db_password:
|
|
type: string
|
|
description: The WordPress database admin account password
|
|
default: admin
|
|
hidden: true
|
|
constraints:
|
|
- length: { min: 1, max: 41 }
|
|
description: db_password must be between 1 and 41 characters
|
|
- allowed_pattern: '[a-zA-Z0-9]*'
|
|
description: db_password must contain only alphanumeric characters
|
|
|
|
db_root_password:
|
|
type: string
|
|
description: Root password for MySQL
|
|
default: admin
|
|
hidden: true
|
|
constraints:
|
|
- length: { min: 1, max: 41 }
|
|
description: db_root_password must be between 1 and 41 characters
|
|
- allowed_pattern: '[a-zA-Z0-9]*'
|
|
description: db_root_password must contain only alphanumeric characters
|
|
|
|
|
|
resources:
|
|
DatabaseServer:
|
|
type: OS::Nova::Server
|
|
properties:
|
|
image: { get_param: image_id }
|
|
flavor: { get_param: instance_type }
|
|
key_name: { get_param: key_name }
|
|
user_data:
|
|
str_replace:
|
|
template: |
|
|
#!/bin/bash -v
|
|
|
|
yum -y install mariadb mariadb-server
|
|
touch /var/log/mariadb/mariadb.log
|
|
chown mysql.mysql /var/log/mariadb/mariadb.log
|
|
systemctl start mariadb.service
|
|
|
|
# Setup MySQL root password and create a user
|
|
mysqladmin -u root password db_rootpassword
|
|
cat << EOF | mysql -u root --password=db_rootpassword
|
|
CREATE DATABASE db_name;
|
|
GRANT ALL PRIVILEGES ON db_name.* TO "db_user"@"%"
|
|
IDENTIFIED BY "db_password";
|
|
FLUSH PRIVILEGES;
|
|
EXIT
|
|
EOF
|
|
params:
|
|
db_rootpassword: { get_param: db_root_password }
|
|
db_name: { get_param: db_name }
|
|
db_user: { get_param: db_username }
|
|
db_password: { get_param: db_password }
|
|
|
|
WebServer:
|
|
type: OS::Nova::Server
|
|
properties:
|
|
image: { get_param: image_id }
|
|
flavor: { get_param: instance_type }
|
|
key_name: { get_param: key_name }
|
|
user_data:
|
|
str_replace:
|
|
template: |
|
|
#!/bin/bash -v
|
|
|
|
yum -y install httpd wordpress
|
|
|
|
sed -i "/Deny from All/d" /etc/httpd/conf.d/wordpress.conf
|
|
sed -i "s/Require local/Require all granted/" /etc/httpd/conf.d/wordpress.conf
|
|
sed -i s/database_name_here/db_name/ /etc/wordpress/wp-config.php
|
|
sed -i s/username_here/db_user/ /etc/wordpress/wp-config.php
|
|
sed -i s/password_here/db_password/ /etc/wordpress/wp-config.php
|
|
sed -i s/localhost/db_ipaddr/ /etc/wordpress/wp-config.php
|
|
setenforce 0 # Otherwise net traffic with DB is disabled
|
|
systemctl start httpd.service
|
|
params:
|
|
db_rootpassword: { get_param: db_root_password }
|
|
db_name: { get_param: db_name }
|
|
db_user: { get_param: db_username }
|
|
db_password: { get_param: db_password }
|
|
db_ipaddr: { get_attr: [DatabaseServer, networks, private, 0] }
|
|
|
|
outputs:
|
|
WebsiteURL:
|
|
description: URL for Wordpress wiki
|
|
value:
|
|
str_replace:
|
|
template: http://host/wordpress
|
|
params:
|
|
host: { get_attr: [WebServer, networks, private, 0] }
|