monasca-persister/monasca_persister/tools/cassandra/recreate-metric-id
Hasan Acar 84f03c516a Fixing the gates
fix: sha256 instead of sha1 for metric_id

fix: allowlist added to .tox file
Change-Id: I0384f8e9cdae901df9403c442fce4cf1bf036968
2024-03-20 05:52:08 +00:00
..
persister-check-missing-metric-id.py Fixing the gates 2024-03-20 05:52:08 +00:00
persister-recreate-metric-id.py Fixing the gates 2024-03-20 05:52:08 +00:00
persister-recreate.ini Create a tool for recreating missing metrid_id in Cassandra 2019-05-13 09:55:49 -07:00
README.rst Clarify dependency on cachetools in recreate-metric-id tool 2019-06-06 13:39:54 -07:00

persister-recreate-metric-id

In some rare cases, it is possible to have metric rows in the Cassandra database which do not have a metric_id. Due to the nature of TSDBs, it is valid to have sparse data, but the version of Monasca API up through Rocky do not handle this well and produce an ugly ERROR.

For further reading - https://storyboard.openstack.org/#!/story/2005305

This tool runs through the metric table in Cassandra, identifies rows that are missing a metric_id, and uses an UPDATE operation to recreate the metric_id based on other values. The metric_id is calculated from a hash of the region, tenant_id, metric_name and dimensions, so it can be recreated.

All effort has been made to ensure this is a safe process. And it should be safe to run the tool multiple times. However, it is provided AS IS and you should use it at your own risk.

Usage

Steps to use this tool:

  • Log in to one node where monasca-persister is deployed.
  • If this installation of Monasca is separate from other OpenStack services (i.e. if Keystone services are not installed on the same server) then cachetools may need to be installed. On a SUSE system this can be done with sudo zypper in python-cachetools, or on an Ubuntu based devstack this can be done with sudo apt-get install python-cachetools.
  • Identify installation path to monasca-persister. This may be a virtual environment such as /opt/stack/venv/monasca-<version>/lib/python2.7/site-packages/monasca_persister or as in devstack /opt/stack/monasca-persister/monasca_persister/.
  • Identify the existing configuration for monasca-persister. If using a java deployment, it may be in /opt/stack/service/monasca/etc/persister-config.yml or in devstack /etc/monasca/persister.conf
  • Copy and modify the config template file.
cp persister-recreate.ini /opt/stack/service/monasca/etc/persister-recreate.ini
vi /opt/stack/service/monasca/etc/persister-recreate.ini
  • Copy the values from the monasca-persister config in to the new .ini, particularly the password.
    • The single IP for the management network of one of the Cassandra nodes should be given for the contact_points value, rather than the list of hostnames as specified in the .yml.1
  • Copy the persister-recreate-metric-id.py and persister-check-missing-metric-id.py files in to place with the monasca-persister code.
cp persister-*-metric-id.py /opt/stack/venv/monasca-<version>/lib/python2.7/site-packages/monasca_persister
  • Ensure the mon-persister user has permission to access both persister-recreate.ini and persister-recreate-metric-id.py.
  • Invoke the tool to generate a log of rows needing repair.
sudo -u mon-persister /opt/stack/venv/monasca-<version>/bin/python /opt/stack/venv/monasca-<version>/lib/python2.7/site-packages/monasca_persister/persister-check-missing-metric-id.py --config-file /opt/stack/service/monasca/etc/persister-recreate.ini
  • Review the logged output. If output is as expected, then invoke the recreate-missing-metric-id tool to repair the rows.
sudo -u mon-persister /opt/stack/venv/monasca-<version>/bin/python /opt/stack/venv/monasca-<version>/lib/python2.7/site-packages/monasca_persister/persister-recreate-metric-id.py  --config-file /opt/stack/service/monasca/etc/persister-recreate.ini
  • Once repair has been verified successful, the configuration file may be deleted.

License

Copyright (c) 2019 SUSE LLC

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.


  1. Using the wrong format locator for the contact_points may result in errors:

    • Giving the wrong IP address: :

      NoHostAvailable: ('Unable to connect to any servers', {'192.168.0.0': error(111, "Tried connecting to [('192.168.0.0', 9042)]. Last error: Connection refused")})
    • Giving a hostname rather than IP: :

      gaierror: [Errno -2] Name or service not known
    ↩︎