doc/mgr/telemetry.rst
.. _telemetry:
The telemetry module sends anonymous data about the cluster back to the developers to report how Ceph is used and to report problems experienced by users.
This data is visualized on the public dashboards <https://telemetry-public.ceph.com/>_ that allow the community to see a
summary of statistics including how many clusters are reporting, their total
capacity and OSD count, and version distribution trends.
The telemetry report is broken down into several "channels", each with a different type of information. When telemetry is enabled, individual channels can be turned on and off. (If telemetry is disabled, the per-channel setting has no effect.)
basic (default: on): Basic information about the cluster
crash (default: on): Information about daemon crashes, including
device (default: on): Information about device metrics, including
ident (default: off): User-provided identifying information about the cluster
perf (default: off): Various performance metrics of a cluster, which can be used to
The reported data does not contain any sensitive data. This means that the reported data does not include pool names, object names, object contents, hostnames, or device serial numbers.
The reported data contains counters and statistics pertaining to how the cluster has been deployed, the version of Ceph, the OS distribution, and other parameters that help the project develop a better understanding of the way Ceph is used.
Data is sent secured to
https://telemetry.ceph.com <https://telemetry.ceph.com>_.
Individual channels can be enabled or disabled by running the following commands:
.. prompt:: bash #
ceph telemetry enable channel basic ceph telemetry enable channel crash ceph telemetry enable channel device ceph telemetry enable channel ident ceph telemetry enable channel perf
ceph telemetry disable channel basic ceph telemetry disable channel crash ceph telemetry disable channel device ceph telemetry disable channel ident ceph telemetry disable channel perf
Multiple channels can be enabled or disabled at the same time by running commands of the following form:
.. prompt:: bash #
ceph telemetry enable channel basic crash device ident perf ceph telemetry disable channel basic crash device ident perf
All channels can be enabled or disabled at once by running the following commands:
.. prompt:: bash #
ceph telemetry enable channel all ceph telemetry disable channel all
Note that telemetry must be enabled for these commands to take effect.
List all channels with:
.. prompt:: bash #
ceph telemetry channel ls
.. code-block:: none
NAME ENABLED DEFAULT DESC basic ON ON Share basic cluster information (size, version) crash ON ON Share metadata about Ceph daemon crashes (version, stack straces, etc) device ON ON Share device health metrics (e.g., SMART data, minus potentially identifying info like serial numbers) ident OFF OFF Share a user-provided description and/or contact email for the cluster perf ON OFF Share various performance metrics of a cluster
To allow the telemetry module to share data, run the following command:
.. prompt:: bash #
ceph telemetry on
Please note: Telemetry data is licensed under the Community Data License Agreement - Sharing - Version 1.0 <https://cdla.io/sharing-1-0/>_. This means
that telemetry module can be enabled only after you add --license sharing-1-0 to the ceph telemetry on command. After telemetry is on,
consider enabling channels which are off by default, such as the
perf channel. ceph telemetry on output will list the exact command to
enable these channels.
Telemetry can be disabled at any time by running the following command:
.. prompt:: bash #
ceph telemetry off
Show reported data by running the following command:
.. prompt:: bash #
ceph telemetry show
If telemetry is disabled, run the following command to preview a sample report:
.. prompt:: bash #
ceph telemetry preview
The generation of a sample report for larger clusters might take some time.
To protect sensitive information, device reports are generated separately. Data including hostnames and device serial numbers are anonymized. The device telemetry is sent to a different endpoint and does not associate the device data with a particular cluster. To see a preview of the device report, run the following command:
.. prompt:: bash #
ceph telemetry show-device
If telemetry is disabled, run the following command to preview a sample device report:
.. prompt:: bash #
ceph telemetry preview-device
.. note:: smartmontools version 7.0 or later must be installed so that JSON
output can be specified and parsed. If you have any concerns about privacy
with regard to the information included in this report, contact the Ceph
developers.
When telemetry is enabled, run the following command to generate both reports in a single output:
.. prompt:: bash #
ceph telemetry show-all
When telemetry is disabled, run the following command to view both reports in a single output:
.. prompt:: bash #
ceph telemetry preview-all
Sample report by channel
Run the following command when telemetry is enabled to show the data reported by a specified channel:
.. prompt:: bash #
ceph telemetry show <channel_name>
Please note: If telemetry is on, and <channel_name> is disabled, the
command above will output a sample report by that channel, according to the
collections the user is enrolled to. However this data is not reported, since
the channel is disabled.
If telemetry is off you can preview a sample report by channel with:
.. prompt:: bash #
ceph telemetry preview <channel_name>
Collections represent different aspects of data collected within a channel.
To list all collections, run the following command:
.. prompt:: bash #
ceph telemetry collection ls
.. code-block:: none
NAME STATUS DESC basic_base NOT REPORTING: NOT OPTED-IN Basic information about the cluster (capacity, number and type of daemons, version, etc.) basic_mds_metadata NOT REPORTING: NOT OPTED-IN MDS metadata basic_pool_flags NOT REPORTING: NOT OPTED-IN Per-pool flags basic_pool_options_bluestore NOT REPORTING: NOT OPTED-IN Per-pool bluestore config options basic_pool_usage NOT REPORTING: NOT OPTED-IN Default pool application and usage statistics basic_rook_v01 NOT REPORTING: NOT OPTED-IN Basic Rook deployment data basic_stretch_cluster NOT REPORTING: NOT OPTED-IN Stretch mode information for stretch clusters basic_usage_by_class NOT REPORTING: NOT OPTED-IN Default device class usage statistics crash_base NOT REPORTING: NOT OPTED-IN Information about daemon crashes (daemon type and version, backtrace, etc.) device_base NOT REPORTING: NOT OPTED-IN Information about device health metrics ident_base NOT REPORTING: NOT OPTED-IN, CHANNEL ident IS OFF User-provided identifying information about the cluster perf_memory_metrics NOT REPORTING: NOT OPTED-IN, CHANNEL perf IS OFF Heap stats and mempools for mon and mds perf_perf NOT REPORTING: NOT OPTED-IN, CHANNEL perf IS OFF Information about performance counters of the cluster
Where:
.. glossary::
NAME
Collection name. The prefix indicates the channel to which the
collection belongs.
STATUS
Indicates whether the collection metrics are reported. This is
determined by the status (``enabled`` or ``disabled``) to which
the channel of the collection belongs, along with the
enrollment status of the collection (whether the user is
opted-in to this collection).
DESC
General description of the collection.
To display any difference between the currenty-enrolled collections and any new or available collections, run the following command:
.. prompt:: bash #
ceph telemetry diff
To enroll to the most recent collections, run the following command:
.. prompt:: bash #
ceph telemetry on
Enable a new channel that is currently disabled by running a command of the following form:
.. prompt:: bash #
ceph telemetry enable channel <channel_name>
The telemetry module compiles and sends a new report every 24 hours by default. Adjust this interval by running a command of the following form:
.. prompt:: bash #
ceph config set mgr mgr/telemetry/interval 72 # report every three days
To print the current configuration of the telemetry module, run a command of the following form:
.. prompt:: bash #
ceph telemetry status
To send an ansynchronous, one-time set of telemetry data, run the following command:
.. prompt:: bash #
ceph telemetry send
If telemetry has not been enabled (by running the command ceph telemetry on), add --license sharing-1-0 to the ceph telemetry send command.
If the cluster cannot directly connect to the configured telemetry
endpoint (default: telemetry.ceph.com), configure an HTTP/HTTPS
proxy server by running a command of the following form:
.. prompt:: bash #
ceph config set mgr mgr/telemetry/proxy https://10.0.0.1:8080
Include a colon-separated user and password (user:pass) if needed by
running a command of the following form:
.. prompt:: bash #
ceph config set mgr mgr/telemetry/proxy https://ceph:[email protected]:8080
A contact and description can be added to the report. This is optional and is disabled by default. Run commands of the following forms to add contacts and descriptions:
.. prompt:: bash #
ceph config set mgr mgr/telemetry/contact 'John Doe [email protected]' ceph config set mgr mgr/telemetry/description 'My first Ceph cluster' ceph config set mgr mgr/telemetry/channel_ident true
To participate in a leaderboard in the public dashboards <https://telemetry-public.ceph.com/>_, run the following command:
.. prompt:: bash #
ceph config set mgr mgr/telemetry/leaderboard true
The leaderboard displays basic information about the cluster. This includes the cluster's total storage capacity and the number of OSDs. To add a description of the cluster so that it can more easily be identified on the leaderboard, run a command of the following form:
.. prompt:: bash #
ceph config set mgr mgr/telemetry/leaderboard_description 'Ceph cluster for Computational Biology at the University of XYZ'
If the ident channel is enabled, its details will not be displayed in the
leaderboard.