#monasca-api Installs the monasca-api part of the Monasca project.

##Requirements

  • api_region
  • influxdb_url
  • influxdb_user
  • influxdb_password
  • kafka_hosts - comma separated list of host:port combinations
  • keystone_host
  • keystone_admin
  • keystone_admin_password
  • mysql_host - SSL will be used if available
  • mysql_user
  • mysql_password
  • zookeeper_hosts - comma separated list of host:port combinations

##Optional parameters

  • keystone_admin_token - defaults to empty value
  • keystone_admin_project - defaults to empty value
  • monasca_api_client_port - the port the API listens on, default is 8080
  • monasca_api_bind_host - if set, the port the API listens on is bound to this host or ip address
  • monasca_admin_client_port - the port the admin connector listens on, default is 8081
  • monasca_api_admin_bind_host - if set, the port the admin connector listens on is bound to this host or ip address
  • monasca_log_level - Log level for the API log. Default to WARN
  • monasca_wait_for_period - The time in seconds for how long to wait for API's port to be available after starting it. Default is 10 seconds.
  • run_mode - One of Deploy, Stop, Install, Start, or Use. The default is Deploy which will do Install, Configure, then Start.

There is a truststore used by the application for any certificate authorities that must be trusted. Additionally there is a client keystore for any ssl keys needed for client authentication. Most importantly there is a standard keystore used for serving the api via ssl.

  • monasca_api_keystore - The remote location to place the keystore. If this is defined SSL will be enabled for the API.
  • monasca_api_keystore_src - The local location to copy the keystore from.
  • monasca_api_keystore_password
  • monasca_api_truststore - The remote location to place the truststore. Generally a truststore is needed for the keystone SSL CA.
  • monasca_api_truststore_src - The local location to copy the truststore from.
  • monasca_api_truststore_password
  • monasca_api_client_keystore - The remote location to place the client keystore.
  • monasca_api_client_keystore_src - The local location to copy the client keystore from.
  • monasca_api_client_keystore_password

The keystore and truststore's are jks files and created by command such as these examples:

# Change from pem to pkcs12 format
openssl pkcs12 -export -in orig.pem -inkey orig.key -out new.p12 -name fqdn -chain -CAfile cacert.pem -password pass:password
# Create the jks keystore
keytool -importkeystore -deststorepass password -destkeystore ./keystore.jks -srckeystore new.p12 -srcstoretype PKCS12 -srcstorepass password

##Example Playbook

hosts: monasca
sudo: yes
roles:
  - {role: tkuhlman.monasca-api,
     influxdb_user: "{{api_influxdb_user}}",
     influxdb_password: "{{api_influxdb_password}}",
     mysql_user: "{{api_mysql_user}}",
     mysql_password: "{{api_mysql_password}}",
     tags: [api]}

##Running with Vertica

To run with vertica you must pass in the change the variable database_type to vertica in defaults or add it in the call to the role. You can also pass in the url of your vertica database and the username/password for the monasca-api. These do default to values if not passed in. Setting the username and password would talk the form of:

vertica_users:
  - username: mon_api
    password: password
    role: monasca_api

##License Apache

##Author Information Tim Kuhlman Monasca Team email monasca@lists.launchpad.net