]> git.apps.os.sepia.ceph.com Git - ceph.git/log
ceph.git
4 years agoosd: remove a ceph_assert() from a legitimate path 40226/head
Ronen Friedman [Wed, 17 Mar 2021 15:21:10 +0000 (17:21 +0200)]
osd: remove a ceph_assert() from a legitimate path

on_replica_init() might be legitimately called twice,
if the replica was waiting for updates to complete
before servicing the request.

Fixes: https://tracker.ceph.com/issues/49867
Signed-off-by: Ronen Friedman <rfriedma@redhat.com>
(cherry picked from commit 437456ecf9429dd5623cda105e1399234fcc86de)

4 years agoMerge pull request #40180 from linuxbox2/wip-pacific-lcloop
Matt Benjamin [Thu, 18 Mar 2021 20:04:40 +0000 (16:04 -0400)]
Merge pull request #40180 from linuxbox2/wip-pacific-lcloop

rgw: lc: fix infinite loop in bucket_lc_prepare

4 years agoMerge PR #40119 into pacific
Sage Weil [Thu, 18 Mar 2021 16:47:14 +0000 (11:47 -0500)]
Merge PR #40119 into pacific

* refs/pull/40119/head:
osd: propagate base pool application_metadata to tiers

Reviewed-by: Kefu Chai <kchai@redhat.com>
4 years agoMerge PR #40195 into pacific
Sage Weil [Thu, 18 Mar 2021 15:30:58 +0000 (10:30 -0500)]
Merge PR #40195 into pacific

* refs/pull/40195/head:
Revert "osd: Try other PGs when reservation failures occur"
Revert "test: Add test for scrub parallelism"

Reviewed-by: Josh Durgin <jdurgin@redhat.com>
4 years agoMerge PR #40156 into pacific
Sage Weil [Thu, 18 Mar 2021 15:16:37 +0000 (10:16 -0500)]
Merge PR #40156 into pacific

* refs/pull/40156/head:
qa/tests: changed image path to 'quay.ceph.io/ceph-ci/ceph:octopus'

Reviewed-by: Alfonso Martínez <almartin@redhat.com>
Reviewed-by: Sage Weil <sage@redhat.com>
4 years agoMerge PR #40181 into pacific
Sage Weil [Thu, 18 Mar 2021 15:16:22 +0000 (10:16 -0500)]
Merge PR #40181 into pacific

* refs/pull/40181/head:
mgr/prometheus: fix typo in get_collect_time_metrics

Reviewed-by: Kefu Chai <kchai@redhat.com>
4 years agoMerge PR #40137 into pacific
Sage Weil [Wed, 17 Mar 2021 21:18:53 +0000 (16:18 -0500)]
Merge PR #40137 into pacific

* refs/pull/40137/head:
qa/suites/rados/singletone: whitelist MON_DOWN when injecting msgr errors

Reviewed-by: Yuri Weinstein <yweins@redhat.com>
4 years agoMerge PR #40132 into pacific
Sage Weil [Wed, 17 Mar 2021 21:18:39 +0000 (16:18 -0500)]
Merge PR #40132 into pacific

* refs/pull/40132/head:
mgr: wait for ~3 beacons on startup if mons are pre-pacific
mon/MgrMonitor: populate available_modules from promote_standby()

Reviewed-by: Kefu Chai <kchai@redhat.com>
4 years agoRevert "osd: Try other PGs when reservation failures occur" 40195/head
Neha Ojha [Wed, 17 Mar 2021 16:26:44 +0000 (16:26 +0000)]
Revert "osd: Try other PGs when reservation failures occur"

This reverts commit e0ed0122526791547a317c6ca19ed081a92dfe69.

Signed-off-by: Neha Ojha <nojha@redhat.com>
4 years agoRevert "test: Add test for scrub parallelism"
Neha Ojha [Wed, 17 Mar 2021 16:26:31 +0000 (16:26 +0000)]
Revert "test: Add test for scrub parallelism"

This reverts commit 6f6553939a20ac01d6ce7daaa2a79e5f333c4311.

Signed-off-by: Neha Ojha <nojha@redhat.com>
4 years agomgr/prometheus: fix typo in get_collect_time_metrics 40181/head
Sage Weil [Tue, 16 Mar 2021 20:10:42 +0000 (15:10 -0500)]
mgr/prometheus: fix typo in get_collect_time_metrics

This causes a failure the first time through this function, but
subsequent calls succeed, making it a bit hard to notice.

Fixes: 58fd057e2c8799fa000b9937aa992e13cbbd485f
Fixes: https://tracker.ceph.com/issues/49846
Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit c80b944fd4f32dea6a153375d9bdeb4a6e1d0b4c)

4 years agoMerge pull request #39973 from singuliere/wip-49686-pacific
Venky Shankar [Wed, 17 Mar 2021 13:47:47 +0000 (19:17 +0530)]
Merge pull request #39973 from singuliere/wip-49686-pacific

pacific: cephfs-mirror: register mirror daemon as service daemon

4 years agoMerge pull request #39810 from vshankar/wip-49432
Venky Shankar [Wed, 17 Mar 2021 13:46:27 +0000 (19:16 +0530)]
Merge pull request #39810 from vshankar/wip-49432

pacific: tools/cephfs-mirror: fix a dangling pointer

4 years agoMerge PR #40107 into pacific
Patrick Donnelly [Wed, 17 Mar 2021 13:44:13 +0000 (06:44 -0700)]
Merge PR #40107 into pacific

* refs/pull/40107/head:
qa: use tcmalloc with valgrind in fs:valgrind

Reviewed-by: Rishabh Dave <ridave@redhat.com>
Reviewed-by: Patrick Donnelly <pdonnell@redhat.com>
4 years agoMerge pull request #40131 from cbodley/wip-qa-rgw-ignore-pg-avail-pacific
Casey Bodley [Wed, 17 Mar 2021 13:35:06 +0000 (09:35 -0400)]
Merge pull request #40131 from cbodley/wip-qa-rgw-ignore-pg-avail-pacific

pacific: qa/rgw: put PG_AVAILABILITY ignorelist override in its own file

Reviewed-by: Neha Ojha <nojha@redhat.com>
4 years agoMerge pull request #40134 from cbodley/wip-49814
Casey Bodley [Wed, 17 Mar 2021 13:34:23 +0000 (09:34 -0400)]
Merge pull request #40134 from cbodley/wip-49814

pacific: rgw: rgw::sal::RGWBucket initializes creation_time

Reviewed-by: Daniel Gryniewicz <dang@redhat.com>
4 years agorgw: lc: fix infinite loop in bucket_lc_prepare 40180/head
Ilsoo Byun [Mon, 7 Dec 2020 06:20:53 +0000 (15:20 +0900)]
rgw: lc: fix infinite loop in bucket_lc_prepare

Fixes: https://tracker.ceph.com/issues/49862
Signed-off-by: Ilsoo Byun <ilsoobyun@linecorp.com>
(cherry picked from commit bc8f304a51afc1398a54cf254e65fd217af00c8a)

4 years agoMerge PR #40135 into pacific
Sage Weil [Tue, 16 Mar 2021 20:14:19 +0000 (15:14 -0500)]
Merge PR #40135 into pacific

* refs/pull/40135/head:
pybind/mgr: correct a MgrModule annotation
mgr/ceph_module: add type annotation to BaseMgrModule
mgr/prometheus: fix warning of possibly unbound variables
mgr/prometheus: flake8 cleanups
mgr/prometheus: fix import failure (flake8)
mgr/prometheus: add type annotations
mgr/prometheus: raise at seeing unknown status
mgr/prometheus: implement command using CLIReadCommand
mgr/{prometheus,telemetry}: appease mypy
mgr/prometheus: add prometheus to flake8 test
mgr/prometheus: escape special chars using r-string
pybind/mgr/prometheus: PEP8 cleanups
pybind/mgr/prometheus: add typing annotations
mgr/prometheus: introduce metric for collection time
mgr/cephadm: fix 'auth caps' fallback
mgr/cephadm: ensure mgr metadata is not none
qa/suites/rados/cephadm: add back centos+rhel with kubic podman
qa/suites/rados/cephadm/upgrade: deploy a legacy r.z-style rgw
qa/suites/rados/cephadm/upgrade: start at 15.2.9 to test iscsi upgrade
qa/tasks/cephadm.py: don't set mgr count to +1
doc/cephadm: add note about deprecation of NFSv3
doc/cephadm: remove step to restart the mgr
doc/cephadm: use `reconfig` instead of `redeploy`
doc/cephadm: update custom j2 config-key name
doc/cephadm: use 'apt' to install cephadm on Ubuntu
mgr/cephadm: remove duplicate labels when adding a host
mgr/cephadm: tolerate failure to update daemon caps
mgr/cephadm: fix get_keyring_with_caps
python-common: fix PlacementSpec target size method
python-common: count-per-host must be combined with label or hosts or host_pattern
mgr/cephadm: handle bare 'count-per-host:NNN', fix comments
mgr/cephadm/schedule: remove Scheduler abstraction (for now at least)
mgr/cephadm/schedule: calculate additions/removals in place()
mgr/cephadm/schedule: allow colocation of certain daemon types
mgr/cephadm/schedule: shuffle candidates, not final placements
mgr/cephadm/schedule: pass per-type allow_colo to the scheduler
mgr/cephadm/services/cephadmservice: fix typo
mgr/cephadm/schedule: pass daemons, not get_daemons_func
mgr/cephadm: use local var
mgr/cephadm/schedule: move host filtering into get_candidates()
python-common/ceph/deployment/service_spec: disallow max-per-host + explicit placement
mgr/cephadm/schedule: respect count-per-host
mgr/cephadm: adjust deployment logic to allow multiple daemons per host
python-common: add count-per-host to PlacementSpec
mgr/cephadm: do not worry about even # of monitors
mgr/cephadm: add iscsi and nfs to upgrade
mgr/cephadm: update caps if necessary when getting keyring
mgr/cephadm: add cephfs-mirror to CEPH_UPGRADE_ORDER
cephadm: Add cephfs-mirror
qa/cephadm: Add cephfs-mirror test
qa/tasks: some type annotations
mgr/orch: Add cephfs-mirror to enum
mgr/cephadm: Add CephfsMirrorService
mgr/orch: replace def add_{type}(...) with generic add_daemon()
mgr/cephadm: drop `create_func` arg from _add_daemon
mgr/cephadm: move CephadmExporter to new module
mgr/cephadm: fix CephadmExporter deployment
cephadm: exporter: use os.path.realpath(__file__)
mgr/cephadm: root mode: call (and deploy) cephadm binary
cephadm: Get rid of injected_argv
cephadm: Make path to cephadm binary unique
python-common: continue to allow RGWSpec(realm=r,zone=z)
PendingReleaseNodes: note changes in cephadm rgw behavior
qa/tasks/cephadm: drop realm.zone convention for rgw
doc: update docs
doc/cephadm: rewrite "adoption process"
doc/cephadm: rewrite "preparation" in adoption.rst
doc/cephadm: add prompts to adoption.rst
doc/cephadm: rewrite part of adoption.rst
python-common/ceph/deployment: RGWSpec: accept (and drop) subcluster arg
mgr/orchestrator: drop $realm.$zone naming convention
mgr/cephadm: rgw: do not mess with realm configuration
mgr/cephadm:Document the cephadm config-check feature
mgr/cephadm:fix to resolve mypy issue
mgr/cephadm:add unit test for the lookup_check helper
mgr/cephadm:Drop active healthcheck during a disable request
mgr/cephadm:Added helper function to return a specific healthcheck
mgr/cephadm:unit test added for nics better than most
mgr/cephadm:skip an alert if the linkspeed is better than most
mgr/cephadm:fix mypy warning
mgr/cephadm:Remove check from ceph metadata gathering
mgr/cephadm:Add unit test for hosts without public network NIC
mgr/cephadm:Minor updates to address review comments
mgr/cephadm:Added CLI interface for the configuration checker
mgr/cephadm:Multiple updates related to the addition of the CLI
mgr/cephadm:Moved 'ownership' of the checker to cephadm
mgr/cephadm:Unit tests updated to account for upgrades
mgr/cephadm:Updates to CephadmConfigChecks class
mgr/cephadm:Adds unit tests for the CephadmConfigChecks class
mgr/cephadm:add module option to enable configuration checks
mgr/cephadm:added ceph version consistency check
mgr/cephadm: added config checker to main serve loop
mgr/cephadm: adding check logic
mgr/cephadm: resolve rebase conflicts
mgr/cephadm:Document the intergration with libstoragemgmt
mgr/cephadm:Enable cephadm device scan to use LSM
mgr/cephadm: prevent traceback when invalid osd id passed to 'orch osd rm stop'
mgr/cephadm: do not prime service cache on reconfig
mgr/cephadm/osd: PEP-8 fix
mgr/cephadm: Activate existing OSDs
mgr/cephadm: osd: Use _run_cephadm_json()
mgr/cephadm: document ok_to_stop output argument for clarity
mgr/DaemonServer: make warning language a bit friendlier
mgr/cephadm/upgrade: improve language a bit
mgr/cephadm/upgrade: restart multiple osds at once
mgr/cephadm: gather other osds that are safe to stop
mgr/cephadm: optional pass 'known' through to ok_to_stop
mgr/cephadm/upgrade: log start/stop/pause/resume
mgr/cephadm: add CEPHADM_STRAY_DAEMON unittest
mgr/cephadm: alias rgw-nfs -> nfs
qa/tasks/cephadm: remove mirror code
cephadm: fixup `alrady` -> `already`
cephadm: Change outer quotes to avoid escaping inner quotes (Q003)
cephadm: Remove bad quotes from multiline string (Q001)
cephadm: Remove bad quotes (Q000)
cephadm: introduce flake8-quotes
cephadm: line break after binary operator (W504)
cephadm: blank line contains whitespace (W293)
cephadm: trailing whitespace (W291)
cephadm: local variable 'e' is assigned to but never used (F841)
cephadm: 'select' imported but unused (F401)
cephadm: ambiguous variable name 'l' (E741)
cephadm: do not use bare 'except' (E722)
cephadm: statement ends with a semicolon (E703)
cephadm: module level import not at top of file (E402)
cephadm: expected 1 blank line before a nested definition (E306)
cephadm: expected 2 blank lines after end of function or class (E305)
cephadm: too many blank lines (E303)
cephadm: expected 2 blank lines, found 1 (E302)
cephadm: expected 1 blank line, found 0 (E301)
cephadm: too many leading '#' for block comment (E266)
cephadm: block comment should start with '# ' (E265)
cephadm: at least two spaces before inline comment (E261)
cephadm: unexpected spaces around keyword / parameter equals (E251)
cephadm: multiple spaces after ',' (E241)
cephadm: missing whitespace after ':' (E231)
cephadm: missing whitespace around arithmetic operator (E226)
cephadm: missing whitespace around operator (E225)
cephadm: whitespace before ':' (E203)
cephadm: whitespace after '{' (E201)
cephadm: continuation line unaligned for hanging indent (E131)
cephadm: continuation line under-indented for visual indent (E128)
cephadm: continuation line over-indented for visual indent (E127)
cephadm: continuation line over-indented for hanging indent (E126)
cephadm: continuation line with same indent as next logical line (E125)
cephadm: closing bracket does not match visual indentation (E124)
cephadm: ... does not match indentation of opening bracket's line (E123)
cephadm: continuation line missing indentation or outdented (E122)
cephadm: continuation line under-indented for hanging indent (E121)
cephadm: over-indented (E117)
cephadm: introduce flake8

Reviewed-by: Juan Miguel Olmo <jolmomar@redhat.com>
4 years agoqa/tests: changed image path to 'quay.ceph.io/ceph-ci/ceph:octopus' 40156/head
Yuri Weinstein [Tue, 16 Mar 2021 16:16:28 +0000 (09:16 -0700)]
qa/tests: changed image path to 'quay.ceph.io/ceph-ci/ceph:octopus'

Fixes: https://tracker.ceph.com/issues/49790
Signed-off-by: Yuri Weinstein <yweinste@redhat.com>
4 years agopybind/mgr: correct a MgrModule annotation 40135/head
Kefu Chai [Fri, 29 Jan 2021 03:25:31 +0000 (11:25 +0800)]
pybind/mgr: correct a MgrModule annotation

Signed-off-by: Kefu Chai <kchai@redhat.com>
(cherry picked from commit 3649ecf64ccb111c80218477f24021d70a78485f)

4 years agomgr/ceph_module: add type annotation to BaseMgrModule
Kefu Chai [Mon, 22 Feb 2021 05:45:31 +0000 (13:45 +0800)]
mgr/ceph_module: add type annotation to BaseMgrModule

Signed-off-by: Kefu Chai <kchai@redhat.com>
(cherry picked from commit b67e4341a3c3f4ceb7d03a731dcda31f18237eb2)

4 years agomgr/prometheus: fix warning of possibly unbound variables
Patrick Seidensal [Mon, 22 Feb 2021 14:52:56 +0000 (15:52 +0100)]
mgr/prometheus: fix warning of possibly unbound variables

Signed-off-by: Patrick Seidensal <pseidensal@suse.com>
(cherry picked from commit 0fdbdb45dcec57e6e108edfdbea6e6a661f34a7a)

4 years agomgr/prometheus: flake8 cleanups
Kefu Chai [Fri, 26 Feb 2021 09:57:32 +0000 (17:57 +0800)]
mgr/prometheus: flake8 cleanups

Signed-off-by: Kefu Chai <kchai@redhat.com>
(cherry picked from commit 48b70f28df652d61b035690329fb1a2611d79786)

4 years agomgr/prometheus: fix import failure (flake8)
Patrick Seidensal [Mon, 22 Feb 2021 15:45:40 +0000 (16:45 +0100)]
mgr/prometheus: fix import failure (flake8)

Signed-off-by: Patrick Seidensal <pseidensal@suse.com>
(cherry picked from commit 806ef8a1c513a52f50604ba223434d36a654eb81)

4 years agomgr/prometheus: add type annotations
Sage Weil [Tue, 16 Mar 2021 13:05:51 +0000 (08:05 -0500)]
mgr/prometheus: add type annotations

Signed-off-by: Kefu Chai <kchai@redhat.com>
(cherry picked from commit 7f438440f91dea588603b18cbfc00340cd535703)

# Conflicts:
# src/mypy.ini
  - surrounding modules are in master but not pacific

4 years agomgr/prometheus: raise at seeing unknown status
Kefu Chai [Fri, 26 Feb 2021 04:15:03 +0000 (12:15 +0800)]
mgr/prometheus: raise at seeing unknown status

Signed-off-by: Kefu Chai <kchai@redhat.com>
(cherry picked from commit f92aa2f48a8801d31dac092ca53b48d07315bed4)

4 years agomgr/prometheus: implement command using CLIReadCommand
Kefu Chai [Fri, 26 Feb 2021 03:47:11 +0000 (11:47 +0800)]
mgr/prometheus: implement command using CLIReadCommand

Signed-off-by: Kefu Chai <kchai@redhat.com>
(cherry picked from commit 3b9ecd14d7d714be7a7c72fa3d44d7781d360135)

4 years agomgr/{prometheus,telemetry}: appease mypy
Sage Weil [Tue, 16 Mar 2021 13:01:46 +0000 (08:01 -0500)]
mgr/{prometheus,telemetry}: appease mypy

update to adapt the type annotation of MgrModule.list_servers()

Signed-off-by: Kefu Chai <kchai@redhat.com>
(cherry picked from commit 19abd1e1f47da14dbd2be89e15b04d483e75a105)

# Conflicts:
# src/pybind/mgr/telemetry/module.py
  - drop telemetry portion

4 years agomgr/prometheus: add prometheus to flake8 test
Kefu Chai [Wed, 10 Feb 2021 07:49:03 +0000 (15:49 +0800)]
mgr/prometheus: add prometheus to flake8 test

for the explanation why we should add a line break before a binary
operator. see
https://www.python.org/dev/peps/pep-0008/#should-a-line-break-before-or-after-a-binary-operator

Signed-off-by: Kefu Chai <kchai@redhat.com>
(cherry picked from commit 5dd9db970994530002df3da6be075974bfef2767)

4 years agomgr/prometheus: escape special chars using r-string
Kefu Chai [Wed, 10 Feb 2021 07:47:31 +0000 (15:47 +0800)]
mgr/prometheus: escape special chars using r-string

so we don't need to worry about escaping the backslash anymore.

Signed-off-by: Kefu Chai <kchai@redhat.com>
(cherry picked from commit 734dd75f35fb24d319ee1ddbff09da53dfac8c72)

4 years agopybind/mgr/prometheus: PEP8 cleanups
Sage Weil [Tue, 16 Mar 2021 13:00:42 +0000 (08:00 -0500)]
pybind/mgr/prometheus: PEP8 cleanups

Signed-off-by: Kefu Chai <kchai@redhat.com>
(cherry picked from commit e69aad6c6191d0ff3288ae666a306d1c66f1039a)

# Conflicts:
# src/pybind/mgr/tox.ini
  - pacific telemetry not in tox.ini

4 years agopybind/mgr/prometheus: add typing annotations
Kefu Chai [Mon, 15 Mar 2021 11:35:16 +0000 (19:35 +0800)]
pybind/mgr/prometheus: add typing annotations

Signed-off-by: Kefu Chai <kchai@redhat.com>
(cherry picked from commit 58fd057e2c8799fa000b9937aa992e13cbbd485f)

4 years agomgr/prometheus: introduce metric for collection time
Patrick Seidensal [Fri, 24 Jul 2020 17:11:35 +0000 (19:11 +0200)]
mgr/prometheus: introduce metric for collection time

Introduces metric `prometheus_collect_duration_seconds` for the time it
takes the Prometheus manager module to collect all the metrics.

```
ceph_prometheus_collect_duration_seconds_sum{method="get_health"} 0.0002613067626953125
ceph_prometheus_collect_duration_seconds_sum{method="get_pool_stats"} 0.0018298625946044922
ceph_prometheus_collect_duration_seconds_sum{method="get_df"} 0.0005767345428466797
ceph_prometheus_collect_duration_seconds_sum{method="get_fs"} 0.0010402202606201172
ceph_prometheus_collect_duration_seconds_sum{method="get_quorum_status"} 0.0007524490356445312
ceph_prometheus_collect_duration_seconds_sum{method="get_mgr_status"} 0.0035364627838134766
ceph_prometheus_collect_duration_seconds_sum{method="get_pg_status"} 0.00021266937255859375
ceph_prometheus_collect_duration_seconds_sum{method="get_osd_stats"} 0.0018737316131591797
ceph_prometheus_collect_duration_seconds_sum{method="get_metadata_and_osd_status"} 0.0032796859741210938
ceph_prometheus_collect_duration_seconds_sum{method="get_num_objects"} 0.00011086463928222656
ceph_prometheus_collect_duration_seconds_sum{method="get_rbd_stats"} 0.00036144256591796875
ceph_prometheus_collect_duration_seconds_count{method="get_health"} 1.0
ceph_prometheus_collect_duration_seconds_count{method="get_pool_stats"} 1.0
ceph_prometheus_collect_duration_seconds_count{method="get_df"} 1.0
ceph_prometheus_collect_duration_seconds_count{method="get_fs"} 1.0
ceph_prometheus_collect_duration_seconds_count{method="get_quorum_status"} 1.0
ceph_prometheus_collect_duration_seconds_count{method="get_mgr_status"} 1.0
ceph_prometheus_collect_duration_seconds_count{method="get_pg_status"} 1.0
ceph_prometheus_collect_duration_seconds_count{method="get_osd_stats"} 1.0
ceph_prometheus_collect_duration_seconds_count{method="get_metadata_and_osd_status"} 1.0
ceph_prometheus_collect_duration_seconds_count{method="get_num_objects"} 1.0
ceph_prometheus_collect_duration_seconds_count{method="get_rbd_stats"} 1.0
```

Fixes: https://tracker.ceph.com/issues/46703
Signed-off-by: Patrick Seidensal <pseidensal@suse.com>
(cherry picked from commit 801d3f670330499fb9cd5f8674678908f2115fe8)

4 years agomgr/cephadm: fix 'auth caps' fallback
Sage Weil [Mon, 15 Mar 2021 22:34:57 +0000 (17:34 -0500)]
mgr/cephadm: fix 'auth caps' fallback

The first get-or-create attempt also needs to tolerate failure.

Fixes: 8ceea1961f818dc2d07edf9c256ebe5150b6b133
Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 19c75234433c4ce5073a13dbada88f437c2dd0ad)

4 years agomgr/cephadm: ensure mgr metadata is not none
Sage Weil [Mon, 15 Mar 2021 22:20:25 +0000 (17:20 -0500)]
mgr/cephadm: ensure mgr metadata is not none

This hunk is from aca45d7d08fd8c3f32849331eba4620e2726282a, a much
larger change in master that added type annotations all over the place.
It just brings src/pybind/mgr/cephadm fully in sync with master.

Signed-off-by: Sage Weil <sage@newdream.net>
4 years agoqa/suites/rados/cephadm: add back centos+rhel with kubic podman
Sage Weil [Thu, 11 Mar 2021 19:46:23 +0000 (13:46 -0600)]
qa/suites/rados/cephadm: add back centos+rhel with kubic podman

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit dbdd4d46e35d2fcf80a1b2cd9da77b6832c45aa3)

4 years agoqa/suites/rados/cephadm/upgrade: deploy a legacy r.z-style rgw
Sage Weil [Wed, 10 Mar 2021 13:20:45 +0000 (08:20 -0500)]
qa/suites/rados/cephadm/upgrade: deploy a legacy r.z-style rgw

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 04a3d4c927e714aed43a58fb57209bd5154240b2)

4 years agoqa/suites/rados/cephadm/upgrade: start at 15.2.9 to test iscsi upgrade
Sage Weil [Thu, 11 Mar 2021 03:58:33 +0000 (22:58 -0500)]
qa/suites/rados/cephadm/upgrade: start at 15.2.9 to test iscsi upgrade

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 6ccc3d83c004483f455690ec493c7ac7de483587)

4 years agoqa/tasks/cephadm.py: don't set mgr count to +1
Sage Weil [Thu, 11 Mar 2021 16:58:15 +0000 (11:58 -0500)]
qa/tasks/cephadm.py: don't set mgr count to +1

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 0a139c1ffc4a6c92d2f79e278955c62b2ceb36ba)

4 years agodoc/cephadm: add note about deprecation of NFSv3
Michael Fritch [Wed, 10 Mar 2021 17:28:11 +0000 (10:28 -0700)]
doc/cephadm: add note about deprecation of NFSv3

Signed-off-by: Michael Fritch <mfritch@suse.com>
(cherry picked from commit a52bd99a60c1d212bdcaa58250f8a4fdf88fbdf3)

4 years agodoc/cephadm: remove step to restart the mgr
Michael Fritch [Wed, 10 Mar 2021 04:06:27 +0000 (21:06 -0700)]
doc/cephadm: remove step to restart the mgr

a restart of the mgr does not appear to be necessary
after a `ceph config-key set ...`

Signed-off-by: Michael Fritch <mfritch@suse.com>
(cherry picked from commit 9441d66318d243789af6d22cae1a778b35694419)

4 years agodoc/cephadm: use `reconfig` instead of `redeploy`
Michael Fritch [Wed, 10 Mar 2021 04:06:20 +0000 (21:06 -0700)]
doc/cephadm: use `reconfig` instead of `redeploy`

`reconfig` can be used to apply a change to either
the tls/ssl cert or a custom configuration file (j2)

Signed-off-by: Michael Fritch <mfritch@suse.com>
(cherry picked from commit b4b6f359dfbbe17288457066f3f182e3095ea81d)

4 years agodoc/cephadm: update custom j2 config-key name
Michael Fritch [Wed, 10 Mar 2021 04:06:12 +0000 (21:06 -0700)]
doc/cephadm: update custom j2 config-key name

introduced by:
cd79c9912ab35ee6296d613edc7830410a141e05

Signed-off-by: Michael Fritch <mfritch@suse.com>
(cherry picked from commit b58b0de77710fd511d30b79a9cc8f32b19ff29b0)

4 years agodoc/cephadm: use 'apt' to install cephadm on Ubuntu
Josh [Sun, 7 Mar 2021 03:59:46 +0000 (21:59 -0600)]
doc/cephadm: use 'apt' to install cephadm on Ubuntu

Adjusted so Ubuntu command uses 'apt' and added Fedora since that uses 'dnf'.

(cherry picked from commit ffc08b930b32fa34e4d22164feda04719a34dd6b)

4 years agomgr/cephadm: remove duplicate labels when adding a host
Adam King [Fri, 5 Mar 2021 15:10:25 +0000 (10:10 -0500)]
mgr/cephadm: remove duplicate labels when adding a host

Fixes: https://tracker.ceph.com/issues/49626
Signed-off-by: Adam King <adking@redhat.com>
(cherry picked from commit 030fb9d30fbd0b6914ee1ec8283fe7618ed1b8a5)

4 years agomgr/cephadm: tolerate failure to update daemon caps
Sage Weil [Mon, 15 Mar 2021 16:55:36 +0000 (11:55 -0500)]
mgr/cephadm: tolerate failure to update daemon caps

If we're upgrading from 15.2.0, we may fail to update caps.  Instead of
failing the upgrade hard, warn to the log and continue.  This is less
than ideal, but the caps will get corrected the next time the daemon is
redeployed on the next upgrade, and most likely the previous caps will
continue to work (given they were presumably working before the upgrade).

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 8ceea1961f818dc2d07edf9c256ebe5150b6b133)

4 years agomgr/cephadm: fix get_keyring_with_caps
Sage Weil [Fri, 12 Mar 2021 16:15:35 +0000 (10:15 -0600)]
mgr/cephadm: fix get_keyring_with_caps

1- Pass caps to 'auth get-or-create'
2- Only try 'auth caps' if the get-or-create failed

Note that the 'auth caps' step can fail if upgrading from 15.2.0 since
'profile mgr' didn't include 'auth caps' until 15.2.1.  We're not
addressing that for now...

Fixes: 7c0d532f3a4839f4199a13773fb5fa8b6fb3f183
Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 6127d7f20bc8a6ad02d8ea144584eaf2bfc9590e)

4 years agopython-common: fix PlacementSpec target size method
Sage Weil [Wed, 10 Mar 2021 22:27:28 +0000 (17:27 -0500)]
python-common: fix PlacementSpec target size method

- Rename get_host_selection_size() to get_target_size() since the host
  part of the name was a bit misleading
- Take count-per-host into consideration.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 2904c5ece0e6d3cabaf16b2e977bdcdf5d8f68dd)

4 years agopython-common: count-per-host must be combined with label or hosts or host_pattern
Sage Weil [Wed, 10 Mar 2021 22:31:31 +0000 (17:31 -0500)]
python-common: count-per-host must be combined with label or hosts or host_pattern

I think this is better for the same reason we made PlacementSpec() not
mean 'all hosts' by default.  If you really want N daemons for every host
in the cluster, be specific with 'count-per-host:2 *'.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit c7e0fb1e8e7cb06097c23d9e1643b6ba852f0eb0)

4 years agomgr/cephadm: handle bare 'count-per-host:NNN', fix comments
Sage Weil [Wed, 10 Mar 2021 13:32:11 +0000 (08:32 -0500)]
mgr/cephadm: handle bare 'count-per-host:NNN', fix comments

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit b481b7de6b9944bcf4adfd9a6e76828ca85dae0f)

4 years agomgr/cephadm/schedule: remove Scheduler abstraction (for now at least)
Sage Weil [Wed, 10 Mar 2021 13:28:20 +0000 (08:28 -0500)]
mgr/cephadm/schedule: remove Scheduler abstraction (for now at least)

It no longer does anything except slice the array.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 36ef062c942df711afb55b188f4113195c59a499)

4 years agomgr/cephadm/schedule: calculate additions/removals in place()
Sage Weil [Wed, 10 Mar 2021 00:01:39 +0000 (19:01 -0500)]
mgr/cephadm/schedule: calculate additions/removals in place()

We already have to examine existing daemons to choose the placements.
There is no reason to make the caller call another method to (re)calculate
what the net additions and removals are.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 0000b21b71b2eb7dd2710a81fbf2e8f245f367fd)

4 years agomgr/cephadm/schedule: allow colocation of certain daemon types
Sage Weil [Tue, 9 Mar 2021 23:49:51 +0000 (18:49 -0500)]
mgr/cephadm/schedule: allow colocation of certain daemon types

For certain daemon types, we can deploy more than one per host (mds,
rbd-mirror, rgw).

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 6d0098d1cd6b639880e12a5f471dd8d31e7c0017)

4 years agomgr/cephadm/schedule: shuffle candidates, not final placements
Sage Weil [Tue, 9 Mar 2021 23:47:34 +0000 (18:47 -0500)]
mgr/cephadm/schedule: shuffle candidates, not final placements

Otherwise we may end out randomly doubling up on some hosts and none on
others (when we have more than one placement per host).

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 8931958580c3d876fb45b2cec864817b4321a1c2)

4 years agomgr/cephadm/schedule: pass per-type allow_colo to the scheduler
Sage Weil [Tue, 9 Mar 2021 23:26:43 +0000 (18:26 -0500)]
mgr/cephadm/schedule: pass per-type allow_colo to the scheduler

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 927694ba4aeed42b2fa70c962c96e3ef5882d46c)

4 years agomgr/cephadm/services/cephadmservice: fix typo
Sage Weil [Tue, 9 Mar 2021 23:19:35 +0000 (18:19 -0500)]
mgr/cephadm/services/cephadmservice: fix typo

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit eb932eec6340dd5890d0b0406530836eac99b4a8)

4 years agomgr/cephadm/schedule: pass daemons, not get_daemons_func
Sage Weil [Tue, 9 Mar 2021 23:17:49 +0000 (18:17 -0500)]
mgr/cephadm/schedule: pass daemons, not get_daemons_func

- simpler
- many/most callers already have the daemon list, so we save ourselves
duplicated effort

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 3201516ea0708873b2d93d4452b38e1802346932)

4 years agomgr/cephadm: use local var
Sage Weil [Tue, 9 Mar 2021 23:15:25 +0000 (18:15 -0500)]
mgr/cephadm: use local var

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 6244a857381f26c38207394af0d643d551c011cc)

4 years agomgr/cephadm/schedule: move host filtering into get_candidates()
Sage Weil [Tue, 9 Mar 2021 21:12:21 +0000 (16:12 -0500)]
mgr/cephadm/schedule: move host filtering into get_candidates()

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 1bf09d143990c5199f71a28c88d6e591b6fbd934)

4 years agopython-common/ceph/deployment/service_spec: disallow max-per-host + explicit placement
Sage Weil [Tue, 9 Mar 2021 21:09:12 +0000 (16:09 -0500)]
python-common/ceph/deployment/service_spec: disallow max-per-host + explicit placement

At least for now we don't have a reasonable way to stamp out N placements
when we're also constraining the name/network/ip--not in the general case.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 42d1f5a0a3843ecc369f1df998e867080d5f178f)

4 years agomgr/cephadm/schedule: respect count-per-host
Sage Weil [Sat, 6 Mar 2021 15:10:42 +0000 (10:10 -0500)]
mgr/cephadm/schedule: respect count-per-host

In the no-count cases, our job is simple: we have a set of hosts specified
via some other means (label, filter, explicit list) and simply need to
do N instances for each of those hosts.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit d8d808cf30eb5406e8cf6545d6c9900bc1e2be58)

4 years agomgr/cephadm: adjust deployment logic to allow multiple daemons per host
Sage Weil [Sat, 6 Mar 2021 15:09:31 +0000 (10:09 -0500)]
mgr/cephadm: adjust deployment logic to allow multiple daemons per host

If we are told to deploy multiple instances on a host, do it.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 7c083af2d8cd79518be279b37722297ca9c768c3)

4 years agopython-common: add count-per-host to PlacementSpec
Sage Weil [Thu, 4 Mar 2021 13:45:45 +0000 (08:45 -0500)]
python-common: add count-per-host to PlacementSpec

Cannot be combined with 'count'.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 04755fad72d4a7215ec251aba62d86fb3597c540)

4 years agomgr/cephadm: do not worry about even # of monitors
Sage Weil [Thu, 4 Mar 2021 23:30:35 +0000 (18:30 -0500)]
mgr/cephadm: do not worry about even # of monitors

Ceph works just fine with an even number of monitors.

Upside: more copies of critical cluster data
Downside: we can tolerate the same number of down mons as N-1, and now
 we are slightly more likely to have a failing mon because we have 1 more
 that might fail.

On balance it's not clear that have one fewer mon is any better, so avoid
the confusion and complexity of second-guessing ourselves.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit ba88a8e5bf81431c37011ba96ffc843eb970683f)

4 years agomgr/cephadm: add iscsi and nfs to upgrade
Adam King [Wed, 24 Feb 2021 21:44:57 +0000 (16:44 -0500)]
mgr/cephadm: add iscsi and nfs to upgrade

Fixes: https://tracker.ceph.com/issues/49462
Signed-off-by: Adam King <adking@redhat.com>
(cherry picked from commit 20e7b4d5aaaf60442f5600dc914080b3c9615795)

4 years agomgr/cephadm: update caps if necessary when getting keyring
Adam King [Wed, 24 Feb 2021 21:13:01 +0000 (16:13 -0500)]
mgr/cephadm: update caps if necessary when getting keyring

If the caps change from the old version to the new one it causes
issues in the upgrade. This allows the caps to be updated. Currently
only seeing this with iscsi but changing it for other as a precaution

Signed-off-by: Adam King <adking@redhat.com>
(cherry picked from commit 7c0d532f3a4839f4199a13773fb5fa8b6fb3f183)

4 years agomgr/cephadm: add cephfs-mirror to CEPH_UPGRADE_ORDER
Sebastian Wagner [Fri, 26 Feb 2021 12:34:52 +0000 (13:34 +0100)]
mgr/cephadm: add cephfs-mirror to CEPH_UPGRADE_ORDER

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit f885072ffa14dcbf74e42ec364867e36aacdd926)

4 years agocephadm: Add cephfs-mirror
Sebastian Wagner [Tue, 23 Feb 2021 15:06:56 +0000 (16:06 +0100)]
cephadm: Add cephfs-mirror

Fixes: https://tracker.ceph.com/issues/47261
Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit 8fa941b35d89db6a40f7d2912b69eadf40c5004c)

4 years agoqa/cephadm: Add cephfs-mirror test
Sebastian Wagner [Tue, 23 Feb 2021 15:05:47 +0000 (16:05 +0100)]
qa/cephadm: Add cephfs-mirror test

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit d4bf7157a13970e417e79469e9db0559d612ebbb)

4 years agoqa/tasks: some type annotations
Sebastian Wagner [Tue, 23 Feb 2021 15:05:22 +0000 (16:05 +0100)]
qa/tasks: some type annotations

Mostly for making my IDE aware of things

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit 340281fe76dc1d9170815f68a0553c50fb0b157f)

4 years agomgr/orch: Add cephfs-mirror to enum
Sebastian Wagner [Tue, 23 Feb 2021 14:48:29 +0000 (15:48 +0100)]
mgr/orch: Add cephfs-mirror to enum

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit d9d8d717335227a83812acbf33e8fa8bb3383de0)

4 years agomgr/cephadm: Add CephfsMirrorService
Sebastian Wagner [Tue, 23 Feb 2021 13:45:02 +0000 (14:45 +0100)]
mgr/cephadm: Add CephfsMirrorService

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit f2f9f51d742c582c08fb590cdaa4d959ee9fb7f5)

4 years agomgr/orch: replace def add_{type}(...) with generic add_daemon()
Sebastian Wagner [Tue, 23 Feb 2021 14:42:01 +0000 (15:42 +0100)]
mgr/orch: replace def add_{type}(...) with generic add_daemon()

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit 175ee8390985ae12b1b67d602338a4d1b1c81b52)

4 years agomgr/cephadm: drop `create_func` arg from _add_daemon
Sebastian Wagner [Tue, 23 Feb 2021 13:42:38 +0000 (14:42 +0100)]
mgr/cephadm: drop `create_func` arg from _add_daemon

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit 2465f986680cc489bc82ec2a6f5652b24cdf171b)

4 years agomgr/cephadm: move CephadmExporter to new module
Sebastian Wagner [Tue, 23 Feb 2021 12:50:12 +0000 (13:50 +0100)]
mgr/cephadm: move CephadmExporter to new module

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit 935a15fd06421786096a37c4bae6571bf6467aec)

4 years agomgr/cephadm: fix CephadmExporter deployment
Sebastian Wagner [Tue, 16 Feb 2021 12:17:13 +0000 (13:17 +0100)]
mgr/cephadm: fix CephadmExporter deployment

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit c40436e70089322619ed00621354ae46a29ec9d1)

4 years agocephadm: exporter: use os.path.realpath(__file__)
Sebastian Wagner [Fri, 26 Feb 2021 10:20:35 +0000 (11:20 +0100)]
cephadm: exporter: use os.path.realpath(__file__)

Because we now always have a script on the remote hosts.

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit 470d79bee5101e7d4c11378450591f55e6ede4cc)

4 years agomgr/cephadm: root mode: call (and deploy) cephadm binary
Sebastian Wagner [Mon, 22 Feb 2021 15:30:42 +0000 (16:30 +0100)]
mgr/cephadm: root mode: call (and deploy) cephadm binary

Avoid copying cephadm all the time.

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit e7a8fac550aed5da9dbf4ef633602d3634c20da6)

4 years agocephadm: Get rid of injected_argv
Sebastian Wagner [Mon, 22 Feb 2021 14:12:39 +0000 (15:12 +0100)]
cephadm: Get rid of injected_argv

Removed the injected_argv parameter and the injection of code in the cephadm
script we send to hosts.
Now the script is copied and after that we execute the cephadm command.
I would like to copy it only one time (when adding new hosts) but this will be
part of a future PR, together with other prs to:

- Introduce cephadm version
- Get rid of packaged/root mode
- Use pex or eggs

Signed-off-by: Juan Miguel Olmo Martínez <jolmomar@redhat.com>
Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit 2142dcfc2bac3159b7a24f92ae75df2a14599377)

4 years agocephadm: Make path to cephadm binary unique
Sebastian Wagner [Fri, 26 Feb 2021 10:14:52 +0000 (11:14 +0100)]
cephadm: Make path to cephadm binary unique

right now, an upgrade might overwrite the existing
binary which would force us to have the CLI stable.

Signed-off-by: Sebastian Wagner <sebastian.wagner@suse.com>
(cherry picked from commit 8f05520d03c9fb9d57a0d7ed674d4d9dba8d699c)

4 years agopython-common: continue to allow RGWSpec(realm=r,zone=z)
Sage Weil [Mon, 8 Mar 2021 14:49:14 +0000 (09:49 -0500)]
python-common: continue to allow RGWSpec(realm=r,zone=z)

This is for backward compatibility: an octopus spec yaml can still be
applied to an existing cluster.  Note that it might not work on a new
cluster, since cephadm no longer tries to create the realm or zone if
they don't exist.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit cca7391f54b724730ea091669627731bc74f3519)

4 years agoPendingReleaseNodes: note changes in cephadm rgw behavior
Sage Weil [Mon, 8 Mar 2021 14:47:57 +0000 (09:47 -0500)]
PendingReleaseNodes: note changes in cephadm rgw behavior

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit f4ff70941fa585e14cdc628f913b001c208a3327)

4 years agoqa/tasks/cephadm: drop realm.zone convention for rgw
Sage Weil [Fri, 5 Mar 2021 21:30:20 +0000 (16:30 -0500)]
qa/tasks/cephadm: drop realm.zone convention for rgw

Note that cephadm.py will no longer do anything with rgw realms and
zones.  That means that the setup of rgw roles here is only useful
for the default zone and a non-multisite config.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 1bfb0cd84b86e23896a967214a3fa89941addd27)

4 years agodoc: update docs
Sage Weil [Tue, 9 Mar 2021 19:29:39 +0000 (14:29 -0500)]
doc: update docs

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 50bc4913735e684c7f0b7feda9444b38fc96588a)

4 years agodoc/cephadm: rewrite "adoption process"
Zac Dover [Mon, 8 Mar 2021 22:06:05 +0000 (08:06 +1000)]
doc/cephadm: rewrite "adoption process"

This rewrites the "Adoption Process" section
of the "Converting and Existing Cluster to
cephadm" chapter of the Cephadm guide.

Signed-off-by: Zac Dover <zac.dover@gmail.com>
(cherry picked from commit c01112189377e17966fb342262b2f0e16121c882)

4 years agodoc/cephadm: rewrite "preparation" in adoption.rst
Zac Dover [Mon, 8 Mar 2021 16:23:51 +0000 (02:23 +1000)]
doc/cephadm: rewrite "preparation" in adoption.rst

This rewrites the "Adoption" section of
preparation.rst in the Cephadm manual.

Signed-off-by: Zac Dover <zac.dover@gmail.com>
(cherry picked from commit 2a47caff720424c895724b7927139f9fbe3d3fee)

4 years agodoc/cephadm: add prompts to adoption.rst
Zac Dover [Tue, 2 Mar 2021 18:16:27 +0000 (04:16 +1000)]
doc/cephadm: add prompts to adoption.rst

This PR formats the bash prompts. It also formats the
bash output so that it appears in the correct (easily
copy-and-pasteable) format. This PR will be followed by
a grammar-improving PR, but this PR is just a
formatting PR.

Signed-off-by: Zac Dover <zac.dover@gmail.com>
(cherry picked from commit 7eb65fe2cfa5fe78f40f7978191848a7a2a49a71)

4 years agodoc/cephadm: rewrite part of adoption.rst
Zac Dover [Fri, 5 Mar 2021 18:37:01 +0000 (04:37 +1000)]
doc/cephadm: rewrite part of adoption.rst

This PR adds a bit of explanatory text to the
section of the cephadm docs that explains how
to convert Ceph deployments that were not deployed
with cephadm to deployments that can be managed by
the cephadm command line tool.

(cherry picked from commit a445653511b07af360bda37175eadf2870e053f7)

4 years agopython-common/ceph/deployment: RGWSpec: accept (and drop) subcluster arg
Sage Weil [Fri, 5 Mar 2021 21:01:00 +0000 (16:01 -0500)]
python-common/ceph/deployment: RGWSpec: accept (and drop) subcluster arg

This is just so we can load up a stored spec after upgrade.  We'll silently
drop it, since we have the service_id, and this was only used to generate
that anyway.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit d35e1d791bedd8d2ed48a456fd1f5bba978f7f37)

4 years agomgr/orchestrator: drop $realm.$zone naming convention
Sage Weil [Mon, 15 Mar 2021 22:05:45 +0000 (17:05 -0500)]
mgr/orchestrator: drop $realm.$zone naming convention

- Let users name the rgw service(s) whatever they like
- Make the rgw_zone and rgw_realm arguments optional, so that they can
  omit them and let radosgw start up in the generic single-cluster
  configuration (whichk, notably, has no realm).
- Continue to set the rgw_realm and rgw_zone options for the daemon(s),
  but only when those values are specified.
- Adjust the CLI accordingly.  Drop the subcluster argument, which was
  only used to generate a service_id.
- Adjust rook. This is actually a simplification and improved mapping onto
  the rook CRD, *except* that for octopus we enforced the realm.zone
  naming *and* realm==zone.  I doubt a single user actually did this
  so it is not be worth dealing with, but we need a special case for
  where there is a . in the service name.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit af0216d93fb522d239b10b5d7d18208ee02fed77)

# Conflicts:
# src/pybind/mgr/rook/rook_cluster.py
  - pacific branch does not have type annotation on apply_objectstore()

4 years agomgr/cephadm: rgw: do not mess with realm configuration
Sage Weil [Fri, 5 Mar 2021 18:13:56 +0000 (13:13 -0500)]
mgr/cephadm: rgw: do not mess with realm configuration

It is simpler to consider this out of scope for the orchestrator.  The
user should set up their multisite realms/zones before deploying the
daemons (or the daemons will not start).  In the future we can wrap this
with a more friendly tool, perhaps.

Signed-off-by: Sage Weil <sage@newdream.net>
(cherry picked from commit 4498f7dc204cada316ba0ea73ca9954d23c437d2)

4 years agomgr/cephadm:Document the cephadm config-check feature
Paul Cuzner [Tue, 2 Mar 2021 02:40:46 +0000 (15:40 +1300)]
mgr/cephadm:Document the cephadm config-check feature

This patch updates the docs to describe the config-check feature,
describing how these checks can be enabled and managed.

Signed-off-by: Paul Cuzner <pcuzner@redhat.com>
(cherry picked from commit e407c6343d419b7003d143c213fdf3f69462cd83)

4 years agomgr/cephadm:fix to resolve mypy issue
Paul Cuzner [Tue, 2 Mar 2021 01:18:37 +0000 (14:18 +1300)]
mgr/cephadm:fix to resolve mypy issue

Build of ceph metadata needed addition type hints.

Signed-off-by: Paul Cuzner <pcuzner@redhat.com>
(cherry picked from commit 14074887db099c7b9b4cf89ccad10f224453696c)

4 years agomgr/cephadm:add unit test for the lookup_check helper
Paul Cuzner [Fri, 19 Feb 2021 02:09:58 +0000 (15:09 +1300)]
mgr/cephadm:add unit test for the lookup_check helper

Signed-off-by: Paul Cuzner <pcuzner@redhat.com>
(cherry picked from commit c29e6ac3dc6df27dfb777588690d8b6a21a27a6d)

4 years agomgr/cephadm:Drop active healthcheck during a disable request
Paul Cuzner [Fri, 19 Feb 2021 02:09:02 +0000 (15:09 +1300)]
mgr/cephadm:Drop active healthcheck during a disable request

The healthcheck could already be active when the admin attempts
to disable it. This patch removes the related healthcheck if it's set
during a config-check disable request.

Signed-off-by: Paul Cuzner <pcuzner@redhat.com>
(cherry picked from commit f3cf41f98955a2c3b8c31374981e5ecbf5d4eda9)

4 years agomgr/cephadm:Added helper function to return a specific healthcheck
Paul Cuzner [Fri, 19 Feb 2021 02:06:45 +0000 (15:06 +1300)]
mgr/cephadm:Added helper function to return a specific healthcheck

Signed-off-by: Paul Cuzner <pcuzner@redhat.com>
(cherry picked from commit baa2c9313ade4dcd40e5b42e367ab4c0f8d4b9d9)

4 years agomgr/cephadm:unit test added for nics better than most
Paul Cuzner [Thu, 18 Feb 2021 23:52:24 +0000 (12:52 +1300)]
mgr/cephadm:unit test added for nics better than most

checks that we're not raising a healthcheck for a host if it's
nic speed it better than the rest!

Signed-off-by: Paul Cuzner <pcuzner@redhat.com>
(cherry picked from commit 0d7ecb18e33b05bb957f4da7c43199086c7d8ab9)

4 years agomgr/cephadm:skip an alert if the linkspeed is better than most
Paul Cuzner [Thu, 18 Feb 2021 23:50:22 +0000 (12:50 +1300)]
mgr/cephadm:skip an alert if the linkspeed is better than most

The logic was issuing a healthcheck if the linkspeed was different
to the majority. But if the difference is good (i.e. better!) we should
not be raising a healthcheck

Signed-off-by: Paul Cuzner <pcuzner@redhat.com>
(cherry picked from commit 74a3599a83b5b1dde094721f7754d284e8acf8fa)

4 years agomgr/cephadm:fix mypy warning
Paul Cuzner [Thu, 18 Feb 2021 23:41:12 +0000 (12:41 +1300)]
mgr/cephadm:fix mypy warning

Since switching how the roles for a host are determining the
type hint was missed..this patch addresses that

Signed-off-by: Paul Cuzner <pcuzner@redhat.com>
(cherry picked from commit 83f531239b8d2e148bfae2eba6f1effab359b4b8)

4 years agomgr/cephadm:Remove check from ceph metadata gathering
Paul Cuzner [Thu, 18 Feb 2021 23:37:36 +0000 (12:37 +1300)]
mgr/cephadm:Remove check from ceph metadata gathering

A check for _ceph_get_server was included for unit testing, but
the tests have been updated to make this obsolete.

Signed-off-by: Paul Cuzner <pcuzner@redhat.com>
(cherry picked from commit b2f0b6f6d29cbe33bfe200e9fa709284677cd6b9)