.. | ||
files | ||
lib | ||
override-defaults | ||
plugin.sh | ||
README.md | ||
settings | ||
Vagrantfile |
Monasca DevStack Plugin
The Monasca DevStack plugin currently only works on Ubuntu 16.04 (Xenial). More Linux Distributions will be supported in the future.
Running the Monasca DevStack plugin requires a machine with 10GB of RAM.
Directions for installing and running Devstack can be found here:
https://docs.openstack.org/devstack/latest/
To run Monasca in DevStack, do the following three steps.
- Clone the DevStack repo.
git clone https://git.openstack.org/openstack-dev/devstack
- Add the following to the DevStack local.conf file in the root of the devstack directory. You may need to create the local.conf if it does not already exist.
# BEGIN DEVSTACK LOCAL.CONF CONTENTS
[[local|localrc]]
DATABASE_PASSWORD=secretdatabase
RABBIT_PASSWORD=secretrabbit
ADMIN_PASSWORD=secretadmin
SERVICE_PASSWORD=secretservice
SERVICE_TOKEN=111222333444
LOGFILE=$DEST/logs/stack.sh.log
LOGDIR=$DEST/logs
LOG_COLOR=False
# The following two variables allow switching between Java and Python for the implementations
# of the Monasca API and the Monasca Persister. If these variables are not set, then the
# default is to install the Python implementations of both the Monasca API and the Monasca Persister.
# Uncomment one of the following two lines to choose Java or Python for the Monasca API.
MONASCA_API_IMPLEMENTATION_LANG=${MONASCA_API_IMPLEMENTATION_LANG:-java}
# MONASCA_API_IMPLEMENTATION_LANG=${MONASCA_API_IMPLEMENTATION_LANG:-python}
# Uncomment of the following two lines to choose Java or Python for the Monasca Pesister.
MONASCA_PERSISTER_IMPLEMENTATION_LANG=${MONASCA_PERSISTER_IMPLEMENTATION_LANG:-java}
# MONASCA_PERSISTER_IMPLEMENTATION_LANG=${MONASCA_PERSISTER_IMPLEMENTATION_LANG:-python}
# Uncomment one of the following two lines to choose either InfluxDB or Vertica.
# default "influxdb" is selected as metric DB
MONASCA_METRICS_DB=${MONASCA_METRICS_DB:-influxdb}
# MONASCA_METRICS_DB=${MONASCA_METRICS_DB:-vertica}
# This line will enable all of Monasca.
enable_plugin monasca-api git://git.openstack.org/openstack/monasca-api
# END DEVSTACK LOCAL.CONF CONTENTS
- Run './stack.sh' from the root of the devstack directory.
If you want to run Monasca with the bare mininum of OpenStack components you can add the following two lines to the local.conf file.
disable_all_services
enable_service rabbit mysql key
If you also want the Tempest tests to be installed then add tempest
enable_service rabbit mysql key tempest
To enable Horizon and the Monasca UI add horizon
enable_service rabbit mysql key horizon tempest
Using Vagrant
Vagrant can be used to deploy a VM with Devstack and Monasca running in it using the Vagrantfile. After installing Vagrant, just run the command vagrant up
as usual in the ../monasca-api/devstack
directory.
To use local repositories in the devstack install, commit your changes to the master branch of the local repo, then modify the _REPO
variable in the settings file that corresponds to the local repo to use file://my/local/repo/location
.
To use a local instance of the monasca-api repo, change the enable_plugin monasca-api https://git.openstack.org/openstack/monasca-api
to enable_plugin monasca-api file://my/repo/is/here
. Both of these settings will only take effect on a rebuild of the devstack VM.
Enable Vertica as the Metrics DB using Vagrant
Monasca supports using both InfluxDB and Vertica for storing metrics and alarm state history. InfluxDB is enabled by default in the DevStack environment.
Vertica is a commercial database from Hewlett Packard Enterprise. A free Community Edition (CE) installer is available for download.
To enable Vertica, do the following:
-
Register and download the Vertica Debian installer from
https://my.vertica.com/download/vertica/community-edition/
and put it in your home directory. Unfortunately, there isn't a URL that the DevStack installer can automatically use, so it must be downloaded separately, and put in a location where the installer can find it when it runs. The installer assumes this location is your home directory. When using Vagrant, your home directory will normally be mounted inside the VM as "/vagrant_home". -
Modify the environment variable
MONASCA_METRICS_DB
in thelocal.conf
,settings
orVagrantfile
file from influxdb to vertica as follows:
MONASCA_METRICS_DB=${MONASCA_METRICS_DB:-vertica}
Using PostgreSQL or MySQL
Monasca supports using both PostgreSQL and MySQL and so does this devstack plugin.
Enable either postgresql
or mysql
to use either of them.
To setup environment with MySQL use:
enable_service mysql
Alternatively, for PostgreSQL, use:
enable_service postgresql
Using ORM support
ORM support can be controlled with MONASCA_DATABASE_USE_ORM
variable.
However ORM support is enforced if PostgreSQL is enabled, as the database backend,
a.k.a.
enable_service postgresql
Enforcing Apache mirror
If, for any reason, APACHE_MIRROR
that is picked is not working, you can
enforce it in following way:
APACHE_MIRROR=http://www-us.apache.org/dist/
Using WSGI
Monasca-api can be deployed with Apache using uwsgi and gunicorn.
By default monasca-api runs under uwsgi.
If you wish to use gunicorn make sure that devstack/local.conf
contains:
MONASCA_API_USE_MOD_WSGI=False
License
(c) Copyright 2015-2016 Hewlett Packard Enterprise Development Company LP Copyright Fujitsu LIMITED 2017
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.