Client for resource optimization service for OpenStack.
Go to file
Ghanshyam Mann e3c903cfce Drop python 2.7 support and testing
OpenStack is dropping the py2.7 support in ussuri cycle.

python-watcherclient is ready with python 3 and ok to drop the
python 2.7 support.

Complete discussion & schedule can be found in
- http://lists.openstack.org/pipermail/openstack-discuss/2019-October/010142.html
- https://etherpad.openstack.org/p/drop-python2-support

Ussuri Communtiy-wide goal - https://review.opendev.org/#/c/691178/

Change-Id: Id66df6c12e7b533381a354937e23e33f992adbfa
2019-10-30 04:34:43 +00:00
doc Drop python 2.7 support and testing 2019-10-30 04:34:43 +00:00
releasenotes/notes Drop python 2.7 support and testing 2019-10-30 04:34:43 +00:00
tools push initial version 2015-06-04 14:59:34 +02:00
watcherclient Fix python-openstackclient plugin doc build 2019-10-24 01:34:12 +00:00
.coveragerc Add openstack-cover-jobs for watcherclient 2019-03-12 14:05:46 +08:00
.gitignore Update .gitignore to ignore cover and .coverage* 2019-03-18 11:39:15 +08:00
.gitreview OpenDev Migration Patch 2019-04-19 19:45:00 +00:00
.stestr.conf Add openstack-cover-jobs for watcherclient 2019-03-12 14:05:46 +08:00
.zuul.yaml Drop python 2.7 support and testing 2019-10-30 04:34:43 +00:00
babel.cfg push initial version 2015-06-04 14:59:34 +02:00
CONTRIBUTING.rst Update the documentation link for doc migration 2017-07-24 13:55:17 +08:00
HACKING.rst Update the documentation link for doc migration 2017-07-24 13:55:17 +08:00
LICENSE Add license file 2016-07-04 18:04:10 +00:00
lower-constraints.txt remove unused cliutils.py file as osc_lib is used 2019-05-23 09:34:30 +02:00
README.rst Replace git.openstack.org URLs with opendev.org URLs 2019-04-28 09:36:25 +00:00
requirements.txt Merge "remove unused cliutils.py file as osc_lib is used" 2019-05-25 06:22:08 +00:00
setup.cfg Drop python 2.7 support and testing 2019-10-30 04:34:43 +00:00
setup.py Updated from global requirements 2017-03-03 03:09:00 +00:00
test-requirements.txt Cleanup doc dependencies 2019-05-13 13:35:25 -04:00
tox.ini Drop python 2.7 support and testing 2019-10-30 04:34:43 +00:00

Team and repository tags

image

python-watcherclient

Client for resource optimization service for OpenStack.

OpenStack Watcher provides a flexible and scalable resource optimization service for multi-tenant OpenStack-based clouds. Watcher provides a complete optimization loop-including everything from a metrics receiver, complex event processor and profiler, optimization processor and an action plan applier. This provides a robust framework to realize a wide range of cloud optimization goals, including the reduction of data center operating costs, increased system performance via intelligent virtual machine migration, increased energy efficiency and more!

Installation

Install the prerequisite packages

On Ubuntu (tested on 14.04-64)

sudo apt-get install python-dev libssl-dev python-pip git-core libmysqlclient-dev libffi-dev

On Fedora-based distributions e.g., Fedora/RHEL/CentOS/Scientific Linux (tested on CentOS 6.5)

sudo yum install python-virtualenv openssl-devel python-pip git gcc libffi-devel mysql-devel postgresql-devel

On openSUSE-based distributions (SLES 12, openSUSE 13.1, Factory or Tumbleweed)

sudo zypper install gcc git libmysqlclient-devel libopenssl-devel postgresql-devel python-devel python-pip

Install the Watcher client

You can install the Watcher CLI with the following command:

sudo pip install python-watcherclient

You can also use the OpenStack client with Watcher (our watcher plugin for OpenStack client is included in the python-watcherclient package). To install it, you have just to run this command:

sudo pip install python-openstackclient

Configuration

Create a creds file containing your OpenStack credentials:

export OS_IDENTITY_API_VERSION=3
export OS_AUTH_URL=http://<your-keystone-server>:5000/v3
export OS_PROJECT_DOMAIN_ID=default
export OS_USER_DOMAIN_ID=default
export OS_USERNAME=admin
export OS_PASSWORD=<your-password>
export OS_PROJECT_NAME=<your-project-name>

Source these credentials into your current shell session:

# source creds

You should be able to launch the following command which gets the list of previously created Audit Templates:

# watcher audittemplate list

or:

# openstack optimize audittemplate list
+--------------------------------+------+----------------------+----------+
| UUID                           | Name | Goal                 | Strategy |
+--------------------------------+------+----------------------+----------+
+--------------------------------+------+----------------------+----------+

You can view the entire list of available Watcher commands and options using this command:

# watcher help

or:

# openstack help optimize

Troubleshootings

If any watcher command fails, you can obtain more details with the --debug option :

# watcher --debug audittemplate list

or:

# openstack --debug optimize audittemplate list

Install the openstack CLI :

# pip install python-openstackclient

Make sure that your Openstack credentials are correct. If so, you should be able to verify that the watcher user has been declared in your Openstack keystone :

# openstack user list

and that the watcher endpoints have been declared as well :

# openstack endpoint list