Taurus is a server application that implements HTM Engine for the purpose of collecting and reporting on company metrics. Custom metrics are used for Stock Price, Stock Volume, and Twitter handle tweet volume. A RESTful API is provided to support the Taurus Mobile application.
First, install nta.utils
, htmengine
and taurus.metric_collectors
. Then, to install taurus
:
python setup.py develop --install-dir=<site-packages in $PYTHONPATH> --script-dir=<somewhere in $PATH>
--install-dir
must specify a location in your PYTHONPATH, typically something that ends with "site-packages". If not specified, system default is used.--script-dir
must specify a location in your PATH. The Taurus installation defines and installs some CLI utilities into this location. If not specified, the generated scripts go into the location specified in--install-dir
.
install-taurus.sh
is included at the root of the numenta-apps
repository as a
convenient alternative:
./install-taurus.sh <PREFIX>
The configuration files for production reside in conf/
. It is recommended
that you copy and rename this directory so that you may make the required
local changes without conflicts:
cp -r conf conf-user
-
Additionally ensure that APPLICATION_CONFIG_PATH is set in your environment.
-
If running with local dynamodb emulation, edit
conf-user/supervisord.conf
to uncomment the lines for the DynamoDB local test tool and create an empty.dynamodb
directory:mkdir $HOME/.dynamodb
Create an empty taurus logs
directory:
mkdir logs
With taurus
installed, and configuration updated, run taurus-create-db
to
initialize the database.
TODO: Create a console script (see setup.py) that automates the above for development environment (https://jira.numenta.com/browse/TAUR-516).
In a production or otherwise automated setting, it's best to use the included console scripts (where available) for setting configuration overrides. This will ensure that proper validation is applied, eliminate potential syntax errors or typos, and supports an automated workflow.
-
taurus-set-api-key
to set Taurus REST API Key.taurus-set-api-key --apikey API_KEY
-
taurus-set-rabbitmq
to set Taurus rabbitmq connection and authentication.taurus-set-rabbitmq --host=HOST --user=USER --password=PASSWORD
-
taurus-set-sql-login
to set Taurus MySQL credentials.taurus-set-sql-login --host=<host> --user=<user> --password=<password>
-
taurus-set-dynamodb
to set Taurus DynamoDB details.Note: host and port must be blank for live DynamoDB API usage.
Production:
taurus-set-dynamodb --host= --port= --table-suffix=.production
Staging:
taurus-set-dynamodb --host= --port= --table-suffix=.staging
Local (Emulation Tool):
taurus-set-dynamodb --host=127.0.0.1 --port=8300 --table-suffix=.local --security-off
Note: security must be off for DynamoDB Local Emulation Tool.
-
Generate self-signed SSL certificate
pushd conf-user/ssl openssl genrsa -des3 -out localhost.key 1024 openssl req -new -key localhost.key -out localhost.csr cp localhost.key localhost.key.org openssl rsa -in localhost.key.org -out localhost.key openssl x509 -req -days 365 -in localhost.csr -signkey localhost.key -out localhost.crt popd
APPLICATION_CONFIG_PATH
: directory path where active Taurus configuration
files are located
APPLICATION_LOG_DIR
: directory path where Taurus application logs should be
stored
TAURUS_RMQ_METRIC_DEST
: The RabbitMQ metric data sample destination (e.g.,
"1.6.1.numenta.com:2003") must be specified via this environment variable. This
is passed by superviosrd.conf
to rmq_metric_collector_agent
as the value of
its --metric-addr
command-line option. NOTE: we don't hardcode the value in
supervisord.conf
in order to avoid having undersirable metric data samples
accidentally forwarded from developer laptops and other test machines to the
production "htm-it" application server.
TAURUS_RMQ_METRIC_PREFIX
: This defines the prefix to be used for metrics
sent to the HTM-IT server. It is passed by supervisord.conf
to
rmq_metric_collector_agent
as the value of its --metric-prefix
command-line
option. NOTE: we don't hardcode the value in supervisord.conf
in order to
avoid accidently corrupting metric data on an existing HTM-IT installation. This
allows having a single HTM-IT instance monitor multiple Taurus instances
(e.g., Production and Staging)
NOTE: If TAURUS_RMQ_METRIC_DEST
and TAURUS_RMQ_METRIC_PREFIX
env vars
aren't set, then supervisord will fail to start with an error similar to:
Error: Format string 'python -m htmengine.monitors.rmq_metric_collector_agent --metric-addr=%(ENV_TAURUS_RMQ_METRIC_DEST)s --metric-prefix=TAURUS' for 'command' contains names which cannot be expanded
The following must be set for production or staging but can be omitted for development setups:
AWS_ACCESS_KEY_ID
: The AWS acces key
AWS_SECRET_ACCESS_KEY
: The AWS secret key
Individual configurations may vary. Be sure to start MySQL however best works with the installation path you followed.
rabbitmq-server -detached
If you have an old copy of htm-it then you need to clean up RabbitMQ queues.
rabbitmqctl stop_app
rabbitmqctl reset
rabbitmqctl start_app
sudo nginx -p . -c conf-user/nginx-taurus.conf
Should you need to run nginx as a specific user and group, do so with the use
of the NGINX_GLOBAL_PARAMS
environment var, specifying "-g" options per
http://nginx.org/en/docs/switches.html.
For example:
export NGINX_GLOBAL_PARAMS="-g 'user root root;'"
supervisord -c conf-user/supervisord.conf
You can inspect, stop, amd start taurus services using supervisorctl
. For
example:
supervisorctl status
for the status of all services.supervisorctl shutdown
to stop all services and shutdown supervisord.supervisorctl stop taurus:taurus-api_00
to stop only the web services, but keep everything else running.supervisorctl tail -f htmengine:metric_storer
to actively monitor the metric storer servicesupervisorctl restart all
restart all services.
Supervisor also exposes a web interface at http://localhost:9001/ that you may use in lieu of the command line interface.
When there are updates in those packages, you should run the
installation commands in each of the respective packages and in taurus
even
if they are already technically installed so that setuptools
metadata is
applied correctly, and any updates to dependencies are taken into
consideration.
A Dockerfile is included
to support a docker-based workflow. To build a docker image, run the following
command from the root of the numenta-apps
repository (the parent directory
of taurus/
):
docker build -t taurus:latest -f taurus/Dockerfile .
See Dockerfile
for specific environment variable configuration directives.