Sindbad~EG File Manager
3
�f�% � @ s4 d dl Z d dlmZmZmZ G dd� deee�ZdS )� N)�Plugin�RedHatPlugin�UbuntuPluginc @ sH e Zd ZdZdZdZdZdZdZdZ d
d� Z
dd� Zdd� Zdd� Z
dS )�CephMONan
This plugin serves to collect information on monitor nodes within a Ceph
or microceph cluster. It is designed to collect from several versions of
Ceph, including versions that serve as the basis for RHCS 4 and RHCS 5.
Older versions of Ceph will have collections from locations such as
/var/log/ceph, whereas newer versions (as of this plugin's latest update)
will have collections from /var/log/ceph/<fsid>/. This plugin attempts to
account for this where possible across the host's filesystem.
Users may expect to see several collections twice - once in standard output
from the `ceph` command, and again in JSON format. The latter of which will
be placed in the `json_output/` subdirectory within this plugin's directory
in the report archive. These JSON formatted collections are intended to
aid in automated analysis.
zCEPH monZceph_mon�storage�virt� container�ceph�ceph-(.*-)?mon.*�/var/lib/ceph/mon/*�/var/lib/ceph/*/mon*�%/var/snap/microceph/common/data/mon/*r c C s� | j d�}| j� | _| jjjd�}|sv| jddd�� | jdddd g� |sZ| jd
g� n| jdg� | jdd
g� n>| jddddg� |s�| jdg� n| jdg� | jddg� | j ddd� | j dddddddd d!d"d#d$d%d&d'd(d)d*d+d,d-d.d/d0g� | j
d1�}|d2 d3k�rTx>|d4 j� D ].}|jd5��r"|j
� d3 }| j d6|� �� �q"W d7d8d9d:d;d<d=d>d?d@dAdBdCdDdEdFdGdHd2dIg}| j dJdKdLdM� | j dNdKdOdM� | j dPdQ� | j� D �dKdR� | j dSdQ� |D �� | j dTdQ� |D �dKdR� d S )UN�all_logsZ microcephZ ceph_confZceph_mon_log)z.*/ceph.confz$/var/log/ceph/(.*/)?ceph-.*mon.*.logz/etc/ceph/*keyring*z/var/lib/ceph/**/*keyring*z/var/lib/ceph/**/tmp/*mnt*z/etc/ceph/*bindpass*z/var/log/ceph/**/*ceph-mon*.logz /var/log/ceph/**/*ceph-mon*.log*z/run/ceph/**/ceph-mon*z/var/lib/ceph/**/kv_backendz'/var/snap/microceph/common/**/*keyring*z(/var/snap/microceph/current/**/*keyring*z./var/snap/microceph/common/data/mon/*/store.dbz"/var/snap/microceph/common/state/*z./var/snap/microceph/common/logs/*ceph-mon*.logz//var/snap/microceph/common/logs/*ceph-mon*.log*z%/var/snap/microceph/common/data/mon/*z"/var/snap/microceph/current/conf/*zceph reportZceph_report)�tagszceph config dumpz!ceph config generate-minimal-confzceph config logzceph config-key dumpzceph crash statz
ceph featureszceph health detailz
ceph insightszceph log last 10000 debug auditz!ceph log last 10000 debug clusterz
ceph mgr dumpzceph mgr metadatazceph mgr module lszceph mgr serviceszceph mgr versionsz
ceph mon statzceph osd crush dumpzceph osd crush show-tunablesz!ceph osd crush tree --show-shadowz ceph osd erasure-code-profile lszceph osd metadatazceph quorum_statusz
ceph versionszceph-disk listz
ceph crash ls�statusr �output�*zceph crash info z device lsz df detailZdfzfs dumpzfs lszmds statzmon dumpzosd blocked-byzosd df treezosd dfzosd dumpzosd numa-statuszosd perfzosd pool autoscale-statuszosd pool ls detailzosd statzpg dumpzpg statztime-sync-statusz'ceph health detail --format json-prettyZjson_outputZceph_health_detail)�subdirr z"ceph osd tree --format json-prettyZ
ceph_osd_treec S s g | ]}d |� d��qS )zceph tell mon.z mon_status� )�.0Zmidr r �/usr/lib/python3.6/ceph_mon.py�
<listcomp>� s z!CephMON.setup.<locals>.<listcomp>)r c S s g | ]}d |� ��qS )zceph r )r �cmdr r r r � s c S s g | ]}d |� d��qS )zceph z --format json-prettyr )r r r r r r � s )Z
get_option�get_ceph_version�ceph_versionZpolicyZpackage_managerZpkg_by_nameZ
add_file_tagsZadd_forbidden_pathZ
add_copy_specZadd_cmd_outputZcollect_cmd_output�
splitlines�endswith�split�get_ceph_ids)�selfr Z
microceph_pkgZcrashesZcrashlnZcidZ ceph_cmdsr r r �setup, s�
z
CephMON.setupc C sz | j d�}|d dkrly"|d j� d }t|jd�d �S tk
rj } z| jd|� �� W Y dd}~X nX | jd � dS )
z% Get the versions of running daemons zceph --versionr r r � �.z"Could not determine ceph version: Nz?Failed to find ceph version, command collection will be limited)�exec_cmdr �int� Exception�
_log_debugZ
_log_error)r ZverZ_ver�errr r r r � s
"zCephMON.get_ceph_versionc C s$ g }| j dkr�| jd�}|d dkr�x�|d j� D ]b}|j� }|r2|d jd�r2y |jd�}|j||d � W q2 ttfk
r� | j d
� Y q2X q2W n�| j dk�r | jd�}|d dk�r y,t
jd
|d �}|j|j
� d jd�� W n4 tk
�r } z| jd|� �� W Y dd}~X nX |S )z! Get the IDs of the Ceph daemons � � zps -u ceph -o argsr r r zceph-monz--id� zUnable to find ceph IDs� zceph statusz!(\s*mon: .* quorum) (.*) (\(.*\))�,zid determination failed: N)r( r) )r r# r r r �index�append�
IndexError�
ValueErrorZ _log_warn�re�search�extend�groupsr% r&