]> git.apps.os.sepia.ceph.com Git - ceph-ci.git/log
ceph-ci.git
2 years agoos/bluestore: fix bluefs log runway enospc
Pere Diaz Bou [Tue, 25 Jul 2023 15:28:14 +0000 (17:28 +0200)]
os/bluestore: fix bluefs log runway enospc

With these changes, every call to log compaction will try to expand its
runway in case of insufficient log space. async compaction will ignore
the `log_forbidden_to_expand` atomic since we know it should't be
harmful. In any other case, expansion of log will wait until compaction
is completed.

in order to ensure op_file_update_inc fits on disk we increase the size
of logs as previously used in _maybe_extend_log. This means we too bring
back _maybe_extend_log with a different usage.

_maybe_extend_log increases the size of the log if the runway is less
than the min runway and if the current transaction is too big to fit.

Fixes: https://tracker.ceph.com/issues/58759
Signed-off-by: Pere Diaz Bou <pere-altea@hotmail.com>
2 years agoos/bluestore: test log runway expansion error
Pere Diaz Bou [Tue, 25 Jul 2023 15:27:14 +0000 (17:27 +0200)]
os/bluestore: test log runway expansion error

Signed-off-by: Pere Diaz Bou <pere-altea@hotmail.com>
2 years agoMerge pull request #52395 from rhcs-dashboard/upgrade-ui-enhancements
Nizamudeen A [Mon, 7 Aug 2023 05:00:41 +0000 (10:30 +0530)]
Merge pull request #52395 from rhcs-dashboard/upgrade-ui-enhancements

mgr/dashboard: add logs and daemon version to upgrade UI

Reviewed-by: Avan Thakkar <athakkar@redhat.com>
Reviewed-by: cloudbehl <NOT@FOUND>
Reviewed-by: Ernesto Puerta <epuertat@redhat.com>
2 years agoMerge pull request #52647 from rhcs-dashboard/rbd-typing
Nizamudeen A [Mon, 7 Aug 2023 04:04:48 +0000 (09:34 +0530)]
Merge pull request #52647 from rhcs-dashboard/rbd-typing

mgr/dashboard: rbd type status

Reviewed-by: Nizamudeen A <nia@redhat.com>
2 years agoMerge pull request #52703 from zdover23/wip-doc-2023-07-31-documenting-ceph-linking...
zdover23 [Sun, 6 Aug 2023 23:27:22 +0000 (09:27 +1000)]
Merge pull request #52703 from zdover23/wip-doc-2023-07-31-documenting-ceph-linking-customs-2

doc/start: update linking conventions

Reviewed-by: Cole Mitchell <cole.mitchell@gmail.com>
2 years agoMerge pull request #52827 from zdover23/wip-doc-2023-08-05-troubleshooting-troublesho...
zdover23 [Sun, 6 Aug 2023 22:17:15 +0000 (08:17 +1000)]
Merge pull request #52827 from zdover23/wip-doc-2023-08-05-troubleshooting-troubleshooting-mon-2-of-x

doc/rados: edit troubleshooting-mon.rst (2 of x)

Reviewed-by: Anthony D'Atri <anthony.datri@gmail.com>
2 years agoMerge pull request #52785 from Matan-B/wip-matanb-crimson-add-asan-req
Matan Breizman [Sun, 6 Aug 2023 11:49:01 +0000 (14:49 +0300)]
Merge pull request #52785 from Matan-B/wip-matanb-crimson-add-asan-req

ceph.spec.in: add libasan to seastar requires

Reviewed-by: Samuel Just <sjust@redhat.com>
2 years agodoc/rados: edit troubleshooting-mon.rst (2 of x)
Zac Dover [Sat, 5 Aug 2023 12:06:13 +0000 (22:06 +1000)]
doc/rados: edit troubleshooting-mon.rst (2 of x)

Edit the second part of
doc/rados/troubleshooting/troubleshooting-mon.rst.

Signed-off-by: Zac Dover <zac.dover@proton.me>
2 years agoMerge pull request #52824 from bluikko/bluikko-doc-radosgw-config-language
zdover23 [Sun, 6 Aug 2023 11:29:03 +0000 (21:29 +1000)]
Merge pull request #52824 from bluikko/bluikko-doc-radosgw-config-language

doc/radosgw: Improve language and formatting in config-ref.rst

Reviewed-by: Zac Dover <zac.dover@proton.me>
2 years agodoc/radosgw: Improve language and formatting in config-ref.rst
Ville Ojamo [Sat, 5 Aug 2023 05:18:58 +0000 (12:18 +0700)]
doc/radosgw: Improve language and formatting in config-ref.rst

The "Topic persistency settings" section includes convoluted
and incomplete sentences so attempt to improve the
language. The section lacks context so add a link to the
relevant documentation about Notifications.

The "Garbage Collection settings" note includes a sentence
that looks incomplete so try to improve the language.

Don't capitalize "Ops" in "RGW Ops" especially when the
same sentence talks about "op queue" with lower case "o".

Also improve formatting: indentation of a note and wrap
several very long lines.

Signed-off-by: Ville Ojamo <14869000+bluikko@users.noreply.github.com>
2 years agoceph.spec.in: add sanitizers to seastar requires
Matan Breizman [Thu, 3 Aug 2023 08:14:49 +0000 (08:14 +0000)]
ceph.spec.in: add sanitizers to seastar requires

```
CMake Error at src/seastar/CMakeLists.txt:782 (message):
  Sanitizers not found!
```

Signed-off-by: Matan Breizman <mbreizma@redhat.com>
2 years agoMerge pull request #52784 from Matan-B/wip-matanb-crimson-only-centos-9
Matan Breizman [Sun, 6 Aug 2023 07:40:07 +0000 (10:40 +0300)]
Merge pull request #52784 from Matan-B/wip-matanb-crimson-only-centos-9

qa/suites/crimson-rados: add centos9 to supported distros

Reviewed-by: Samuel Just <sjust@redhat.com>
2 years agoMerge pull request #52778 from zdover23/wip-doc-2023-08-03-rados-operations-add-or...
zdover23 [Sat, 5 Aug 2023 11:46:34 +0000 (21:46 +1000)]
Merge pull request #52778 from zdover23/wip-doc-2023-08-03-rados-operations-add-or-rm-mons-2-of-x

doc/rados: edit operations/add-or-rm-mons (2 of x)

Reviewed-by: Anthony D'Atri <anthony.datri@gmail.com>
2 years agodoc/rados: edit operations/add-or-rm-mons (2 of x)
Zac Dover [Wed, 2 Aug 2023 23:24:05 +0000 (09:24 +1000)]
doc/rados: edit operations/add-or-rm-mons (2 of x)

Edit the second part of doc/rados/operations/add-or-rm-mons.rst.

Signed-off-by: Zac Dover <zac.dover@proton.me>
2 years agoMerge pull request #52802 from dvanders/support_the_foundation
Anthony D'Atri [Fri, 4 Aug 2023 20:59:41 +0000 (16:59 -0400)]
Merge pull request #52802 from dvanders/support_the_foundation

doc: Add a Ceph Foundation footer to docs.ceph.com

2 years agoMerge pull request #52814 from cbodley/wip-doc-rgw-zonegroup-feature-default
Anthony D'Atri [Fri, 4 Aug 2023 20:52:39 +0000 (16:52 -0400)]
Merge pull request #52814 from cbodley/wip-doc-rgw-zonegroup-feature-default

doc/rgw: correct statement about default zone features

2 years agoMerge pull request #52787 from rhcs-dashboard/fix-rgw-average-object-size
Nizamudeen A [Fri, 4 Aug 2023 17:51:17 +0000 (23:21 +0530)]
Merge pull request #52787 from rhcs-dashboard/fix-rgw-average-object-size

mgr/dashboard: fix average object size calculation in rgw overview dashboard

Reviewed-by: cloudbehl <NOT@FOUND>
Reviewed-by: Nizamudeen A <nia@redhat.com>
2 years agomgr/dashboard: update the upgrade layout by introducing new items
Nizamudeen A [Sun, 9 Jul 2023 13:36:02 +0000 (19:06 +0530)]
mgr/dashboard: update the upgrade layout by introducing new items

Shows Cluster Health
Shows the count of mgr daemons
Shows a table with all the daemon versions
Display the cluster logs

Fixes: https://tracker.ceph.com/issues/62016
Signed-off-by: Nizamudeen A <nia@redhat.com>
2 years agodoc/rgw: correct statement about default zone features
Casey Bodley [Fri, 4 Aug 2023 17:00:57 +0000 (13:00 -0400)]
doc/rgw: correct statement about default zone features

this sentence wasn't updated when we added the Default column to the
table below

Signed-off-by: Casey Bodley <cbodley@redhat.com>
2 years agoMerge pull request #52248 from cbodley/wip-46062
Casey Bodley [Fri, 4 Aug 2023 12:55:52 +0000 (08:55 -0400)]
Merge pull request #52248 from cbodley/wip-46062

rgw: fetch_remote_obj() preserves original part lengths for BlockDecrypt

Reviewed-by: Shilpa Jagannath <smanjara@redhat.com>
2 years agomgr/dashboard: fix average object size calculation in rgw overview
Aashish Sharma [Thu, 3 Aug 2023 12:14:55 +0000 (17:44 +0530)]
mgr/dashboard: fix average object size calculation in rgw overview
dashboard

Fixes: https://tracker.ceph.com/issues/62318
Signed-off-by: Aashish Sharma <aasharma@redhat.com>
2 years agoMerge pull request #52274 from cbodley/wip-61862
Casey Bodley [Fri, 4 Aug 2023 01:00:46 +0000 (21:00 -0400)]
Merge pull request #52274 from cbodley/wip-61862

qa/rgw: specify cluster name in 'radosgw-admin gc process'

Reviewed-by: Daniel Gryniewicz <dang@redhat.com>
2 years agoMerge pull request #52800 from cbodley/wip-62312
zdover23 [Thu, 3 Aug 2023 23:38:37 +0000 (09:38 +1000)]
Merge pull request #52800 from cbodley/wip-62312

doc/rgw: several response headers are supported

Reviewed-by: Zac Dover <zac.dover@proton.me>
2 years agodoc: Add a Ceph Foundation footer to docs.ceph.com
Dan van der Ster [Thu, 3 Aug 2023 23:10:38 +0000 (16:10 -0700)]
doc: Add a Ceph Foundation footer to docs.ceph.com

Add an info box to the footer of every docs page inviting visitors
to support the Ceph Foundation.

Signed-off-by: Dan van der Ster <dan.vanderster@clyso.com>
2 years agodoc/rgw: several response headers are supported
Casey Bodley [Thu, 3 Aug 2023 21:31:31 +0000 (17:31 -0400)]
doc/rgw: several response headers are supported

Signed-off-by: Casey Bodley <cbodley@redhat.com>
2 years agoReleaseNotes: document recovery of encrypted multipart objects
Casey Bodley [Thu, 3 Aug 2023 21:18:05 +0000 (17:18 -0400)]
ReleaseNotes: document recovery of encrypted multipart objects

Signed-off-by: Casey Bodley <cbodley@redhat.com>
2 years agoradosgw-admin: add command to resync encrypted multipart objects
Casey Bodley [Tue, 30 May 2023 17:56:25 +0000 (13:56 -0400)]
radosgw-admin: add command to resync encrypted multipart objects

Signed-off-by: Casey Bodley <cbodley@redhat.com>
2 years agorgw: RGWRados::set_attrs() takes optional mtime
Casey Bodley [Tue, 30 May 2023 21:23:36 +0000 (17:23 -0400)]
rgw: RGWRados::set_attrs() takes optional mtime

Signed-off-by: Casey Bodley <cbodley@redhat.com>
2 years agorgw: expose part id in RGWObjManifest iterator
Casey Bodley [Tue, 30 May 2023 17:53:02 +0000 (13:53 -0400)]
rgw: expose part id in RGWObjManifest iterator

Signed-off-by: Casey Bodley <cbodley@redhat.com>
2 years agoMerge pull request #51786 from cbodley/wip-61473
Casey Bodley [Thu, 3 Aug 2023 20:24:45 +0000 (16:24 -0400)]
Merge pull request #51786 from cbodley/wip-61473

rgw/crypt: apply rgw_crypt_default_encryption_key by default

Reviewed-by: Shilpa Jagannath <smanjara@redhat.com>
2 years agomgr/dashboard: make the logs component configurable and reusable
Nizamudeen A [Sun, 9 Jul 2023 13:30:32 +0000 (19:00 +0530)]
mgr/dashboard: make the logs component configurable and reusable

This will make the logs component easier to reuse for now in upgrade
component and later, wherever we want

Fixes: https://tracker.ceph.com/issues/62016
Signed-off-by: Nizamudeen A <nia@redhat.com>
2 years agoMerge pull request #52447 from liumiaomiaoIntel/qatzip_update
Casey Bodley [Thu, 3 Aug 2023 15:11:02 +0000 (11:11 -0400)]
Merge pull request #52447 from liumiaomiaoIntel/qatzip_update

common/compressor: update the interfaces and data structures

Reviewed-by: Casey Bodley <cbodley@redhat.com>
2 years agoMerge pull request #52634 from AliMasarweh/wip-alimasa-persistant-q-enhance
Ali Masarwa [Thu, 3 Aug 2023 14:28:18 +0000 (17:28 +0300)]
Merge pull request #52634 from AliMasarweh/wip-alimasa-persistant-q-enhance

RGW: control the persistency of the notification

2 years agoMerge pull request #52405 from rhcs-dashboard/rgw-overview-dashboard-graphs
Nizamudeen A [Thu, 3 Aug 2023 13:47:30 +0000 (19:17 +0530)]
Merge pull request #52405 from rhcs-dashboard/rgw-overview-dashboard-graphs

mgr/dashboard: add graphs to rgw overview dashboard

Reviewed-by: cloudbehl <NOT@FOUND>
Reviewed-by: Ernesto Puerta <epuertat@redhat.com>
Reviewed-by: Nizamudeen A <nia@redhat.com>
2 years agoMerge pull request #52711 from cbodley/wip-62250
Casey Bodley [Thu, 3 Aug 2023 13:04:05 +0000 (09:04 -0400)]
Merge pull request #52711 from cbodley/wip-62250

rgw: retry metadata cache notifications with INVALIDATE_OBJ

Reviewed-by: Adam Emerson <aemerson@redhat.com>
2 years agorgw: preserve RGW_ATTR_CRYPT_PARTS of already-replicated objects
Casey Bodley [Wed, 12 Jul 2023 20:13:34 +0000 (16:13 -0400)]
rgw: preserve RGW_ATTR_CRYPT_PARTS of already-replicated objects

Signed-off-by: Casey Bodley <cbodley@redhat.com>
2 years agorgw: fetch_remote_obj() preserves original part lengths for BlockDecrypt
Casey Bodley [Wed, 28 Jun 2023 21:14:16 +0000 (17:14 -0400)]
rgw: fetch_remote_obj() preserves original part lengths for BlockDecrypt

because multisite replicates multipart objects as a single part, we lose
information about the part sizes from the original manifest that is
necessary to correctly decrypt across those part boundaries

on replication, parse the part lengths out of the source object's
manifest, and store them in a separate RGW_ATTR_CRYPT_PARTS for use on
decryption

Fixes: https://tracker.ceph.com/issues/46062
Signed-off-by: Casey Bodley <cbodley@redhat.com>
2 years agorgw: BlockDecrypt filter parses manifest parts before construction
Casey Bodley [Wed, 28 Jun 2023 20:49:33 +0000 (16:49 -0400)]
rgw: BlockDecrypt filter parses manifest parts before construction

users now call a static read_manifest_parts() function, and pass the
resulting vector into the BlockDecrypt constructor

Signed-off-by: Casey Bodley <cbodley@redhat.com>
2 years agoMerge pull request #52657 from rhcs-dashboard/fs-subvolumes
Nizamudeen A [Thu, 3 Aug 2023 12:42:18 +0000 (18:12 +0530)]
Merge pull request #52657 from rhcs-dashboard/fs-subvolumes

mgr/dashboard: cephfs subvolume list

Reviewed-by: Pegonzal <NOT@FOUND>
Reviewed-by: cloudbehl <NOT@FOUND>
Reviewed-by: Ernesto Puerta <epuertat@redhat.com>
Reviewed-by: Pere Diaz Bou <pdiazbou@redhat.com>
2 years agomgr/dashboard: cephfs subvolume list
Nizamudeen A [Wed, 26 Jul 2023 13:11:16 +0000 (18:41 +0530)]
mgr/dashboard: cephfs subvolume list

Fixes: https://tracker.ceph.com/issues/62182
Signed-off-by: Nizamudeen A <nia@redhat.com>
2 years agoqa/suites/crimson-rados: use crimson-supported-all-distro
Matan Breizman [Thu, 3 Aug 2023 08:05:22 +0000 (08:05 +0000)]
qa/suites/crimson-rados: use crimson-supported-all-distro

Signed-off-by: Matan Breizman <mbreizma@redhat.com>
2 years agoqa/distros: add crimson-supported-all-distro
Matan Breizman [Thu, 3 Aug 2023 08:03:25 +0000 (08:03 +0000)]
qa/distros: add crimson-supported-all-distro

Signed-off-by: Matan Breizman <mbreizma@redhat.com>
2 years agoadd graphs to rgw overview dashboard
Aashish Sharma [Thu, 20 Jul 2023 09:08:59 +0000 (14:38 +0530)]
add graphs to rgw overview dashboard

Signed-off-by: Aashish Sharma <aasharma@redhat.com>
(cherry picked from commit a63026348cb4fcb287046c6dc5432d5709d5dff8)

2 years agoMerge pull request #52757 from aisakaki/wip-retire-cp
Yingxin [Thu, 3 Aug 2023 03:12:01 +0000 (11:12 +0800)]
Merge pull request #52757 from aisakaki/wip-retire-cp

crimson/os/seastore: retire_extent_addr clean up

Reviewed-by: Yingxin Cheng <yingxin.cheng@intel.com>
2 years agoMerge pull request #52775 from dvanders/kplus1
Anthony D'Atri [Thu, 3 Aug 2023 00:05:55 +0000 (20:05 -0400)]
Merge pull request #52775 from dvanders/kplus1

 doc/rados/operations: Correct EC min_size recommendation to K+1 in erasure-code.rst

2 years agoMerge pull request #52719 from cbodley/wip-rgw-get_ws_listing_op
Casey Bodley [Wed, 2 Aug 2023 22:43:32 +0000 (18:43 -0400)]
Merge pull request #52719 from cbodley/wip-rgw-get_ws_listing_op

rgw/swift: remove redundant moves of object name

Reviewed-by: Jiffin Tony Thottan <jthottan@redhat.com>
2 years agoMerge pull request #52714 from cbodley/wip-ec-clay-unit
Casey Bodley [Wed, 2 Aug 2023 22:43:06 +0000 (18:43 -0400)]
Merge pull request #52714 from cbodley/wip-ec-clay-unit

ec: initialize lost_chunk in ErasureCodeClay

Reviewed-by: Neha Ojha <nojha@redhat.com>
2 years agodoc: for EC we recommend K+1
Dan van der Ster [Wed, 2 Aug 2023 21:31:07 +0000 (14:31 -0700)]
doc: for EC we recommend K+1

Update the doc to match the reality in the code. I don't know where
the recommendation to have min_size = k+2 came from, but for awhile
now we've defaulted to K+1. See PR #8008.

Signed-off-by: Dan van der Ster <dan.vanderster@clyso.com>
2 years agoMerge pull request #52007 from tcoldrick-bb/fix-invalid-json
Casey Bodley [Wed, 2 Aug 2023 17:42:22 +0000 (13:42 -0400)]
Merge pull request #52007 from tcoldrick-bb/fix-invalid-json

rgw/rgw_admin.cc: Handle pg_ver and source_zone explicitly

Reviewed-by: Casey Bodley <cbodley@redhat.com>
2 years agoMerge PR #48732 into main
Venky Shankar [Wed, 2 Aug 2023 16:37:58 +0000 (22:07 +0530)]
Merge PR #48732 into main

* refs/pull/48732/head:
doc: add MDS treatise on segments
pybind/mgr/dashboard: bump teuthology version
qa/tasks/vstart_runner: stop overriding _run_python
qa: stop overriding ceph_w prefix in vstart_runner
qa/tasks/vstart_runner: update teuthology helper tool paths
qa/tasks/vstart_runner: allow writing to command's stdin
vstart.sh: always add CEPH_CONF to vstart_environment.sh
qa: use stdin-killer for python3 command
qa: add killpoint testing for mds shutdown
qa: fix background exit condition
qa: add filesystem helper for setting transient config
qa: add helper for waiting for a rank to fail
mds: add incompat feature for minor log segments
mds: introduce ELid event to create/close log
mds: change EResetJournal to major segment boundary
mds: add killpoints for MDS shutdown
qa: add numerous subtree test
mds: track larger log events in perf dump
mds: add minor LogSegment boundaries
mds: obviate MDLog::start_entry
mds: retype to properly sized unsigned ints
mds: use unsigned type for event count
mds: use base Context class for generalization
mds: optimize segment lookup
mds: add stream dump for LogSegment
mds: handle conf changes in mdlog
mds: remove redundant comment
mds: remove unused method
mds: set a reasonable minimum number of segments
mds: sort configs

Reviewed-by: Venky Shankar <vshankar@redhat.com>
2 years agoMerge PR #52754 into main
Venky Shankar [Wed, 2 Aug 2023 16:36:09 +0000 (22:06 +0530)]
Merge PR #52754 into main

* refs/pull/52754/head:
test: explicitly link to ceph-common for some libcephfs tests

Reviewed-by: Xiubo Li <xiubli@redhat.com>
Reviewed-by: Laura Flores <lflores@redhat.com>
2 years agoMerge pull request #52761 from bluikko/patch-18
Anthony D'Atri [Wed, 2 Aug 2023 14:36:06 +0000 (10:36 -0400)]
Merge pull request #52761 from bluikko/patch-18

doc/rados/configuration: Avoid repeating "support" in msgr2.rst

2 years agoMerge pull request #52709 from rishabh-d-dave/cephfs-test_snapshots
Rishabh Dave [Wed, 2 Aug 2023 13:48:07 +0000 (19:18 +0530)]
Merge pull request #52709 from rishabh-d-dave/cephfs-test_snapshots

qa/cephfs: fix test_disallow_monitor_managed_snaps_for_fs_pools

Reviewed-by: Dhairya Parmar <dparmar@redhat.com>
Reviewed-by: Venky Shankar <vshankar@redhat.com>
2 years agoMerge pull request #52762 from yuvalif/wip-yuval-62264
Casey Bodley [Wed, 2 Aug 2023 13:41:36 +0000 (09:41 -0400)]
Merge pull request #52762 from yuvalif/wip-yuval-62264

rgw/amqp: skip idleness tests since it needs to sleep longer than 30s

Reviewed-by: Casey Bodley <cbodley@redhat.com>
2 years agoRGW: control the persistency of the notification
Ali Masarwa [Wed, 12 Jul 2023 10:41:47 +0000 (13:41 +0300)]
RGW: control the persistency of the notification
via adding expiry by number of retries and time
and controling the frequency of retries by sleep duration (in the options of vstart)

Signed-off-by: Ali Masarwa <ali.saed.masarwa@gmail.com>
2 years agoMerge pull request #52559 from adamemerson/wip-62097
Ilya Dryomov [Wed, 2 Aug 2023 11:36:17 +0000 (13:36 +0200)]
Merge pull request #52559 from adamemerson/wip-62097

build: Remove ceph-libboost* packages in install-deps

Reviewed-by: Ilya Dryomov <idryomov@gmail.com>
2 years agorgw/amqp: skip idleness tests since it needs to sleep longer than 30s
Yuval Lifshitz [Wed, 2 Aug 2023 10:19:00 +0000 (10:19 +0000)]
rgw/amqp: skip idleness tests since it needs to sleep longer than 30s

current idle timeout is 30s, so, making the test sleep for 30s may not
be enough. setting sleep time to be longer, and skippign the test so it
won't take too long.

Fixes: https://tracker.ceph.com/issues/62264
Signed-off-by: Yuval Lifshitz <ylifshit@redhat.com>
2 years agoMerge pull request #52698 from rhcs-dashboard/fix-instance-id-exporter
Avan [Wed, 2 Aug 2023 08:56:47 +0000 (14:26 +0530)]
Merge pull request #52698 from rhcs-dashboard/fix-instance-id-exporter

exporter: fix instance_id labeld value for rgw in exporter

Reviewed-by: Juan Miguel Olmo <jolmomar@redhat.com>
Reviewed-by: Pere Diaz Bou <pdiazbou@redhat.com>
2 years agoMerge pull request #51960 from rzarzynski/wip-doc-encoding
zdover23 [Wed, 2 Aug 2023 07:45:51 +0000 (17:45 +1000)]
Merge pull request #51960 from rzarzynski/wip-doc-encoding

doc: improve doc/dev/encoding.rst

Reviewed-by: Anthony D'Atri <anthony.datri@gmail.com>
Reviewed-by: Neha Ojha <nohja@redhat.com>
2 years agotest: explicitly link to ceph-common for some libcephfs tests
Venky Shankar [Tue, 1 Aug 2023 14:14:18 +0000 (10:14 -0400)]
test: explicitly link to ceph-common for some libcephfs tests

Fixes: http://tracker.ceph.com/issues/57206
Signed-off-by: Venky Shankar <vshankar@redhat.com>
2 years agoMerge PR #52569 into main
Venky Shankar [Wed, 2 Aug 2023 05:30:37 +0000 (11:00 +0530)]
Merge PR #52569 into main

* refs/pull/52569/head:
test/libcephfs: update delegation test assertions

Reviewed-by: Xiubo Li <xiubli@redhat.com>
Reviewed-by: Venky Shankar <vshankar@redhat.com>
2 years agodoc/rados/configuration: Avoid repeating "support" in msgr2.rst
Ville Ojamo [Wed, 2 Aug 2023 04:31:50 +0000 (11:31 +0700)]
doc/rados/configuration: Avoid repeating "support" in msgr2.rst

Instead of saying "[...] support is not supported"
change the first "support" to "operation".

Signed-off-by: Ville Ojamo <14869000+bluikko@users.noreply.github.com>
2 years agocrimson/os/seastore: retire_extent_addr clean up
Xinyu Huang [Wed, 2 Aug 2023 02:09:52 +0000 (10:09 +0800)]
crimson/os/seastore: retire_extent_addr clean up

Signed-off-by: Xinyu Huang <xinyu.huang@intel.com>
2 years agoMerge pull request #47573 from phlogistonjohn/jjm-cpatch-py
Adam King [Tue, 1 Aug 2023 21:51:32 +0000 (17:51 -0400)]
Merge pull request #47573 from phlogistonjohn/jjm-cpatch-py

cpatch.py:  a python based cpatch script

Reviewed-by: Adam King <adking@redhat.com>
2 years agoMerge pull request #52732 from cbodley/wip-qa-cephfs-flake8-random
Casey Bodley [Tue, 1 Aug 2023 20:26:23 +0000 (16:26 -0400)]
Merge pull request #52732 from cbodley/wip-qa-cephfs-flake8-random

qa/cephfs: redefinition of unused 'random' from line 7

Reviewed-by: Nizamudeen A <nia@redhat.com>
Reviewed-by: Adam King <adking@redhat.com>
2 years agoMerge PR #52675 into main
Patrick Donnelly [Tue, 1 Aug 2023 18:56:32 +0000 (14:56 -0400)]
Merge PR #52675 into main

* refs/pull/52675/head:
test/TestOSDMap: don't use the deprecated std::random_shuffle method

Reviewed-by: Ronen Friedman <rfriedma@redhat.com>
Reviewed-by: Samuel Just <sjust@redhat.com>
Reviewed-by: Laura Flores <lflores@redhat.com>
Reviewed-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoqa/cephfs: redefinition of unused 'random' from line 7
Casey Bodley [Tue, 1 Aug 2023 16:31:40 +0000 (12:31 -0400)]
qa/cephfs: redefinition of unused 'random' from line 7

seeing this run-tox-qa failure about tasks/cephfs/test_client_recovery.py:

246/285 Test #264: run-tox-qa ................................***Failed   58.54 sec
Requirement already satisfied: tox in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (4.6.4)
Requirement already satisfied: cachetools>=5.3.1 in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (from tox) (5.3.1)
Requirement already satisfied: chardet>=5.1 in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (from tox) (5.1.0)
Requirement already satisfied: colorama>=0.4.6 in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (from tox) (0.4.6)
Requirement already satisfied: filelock>=3.12.2 in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (from tox) (3.12.2)
Requirement already satisfied: packaging>=23.1 in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (from tox) (23.1)
Requirement already satisfied: platformdirs>=3.8 in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (from tox) (3.10.0)
Requirement already satisfied: pluggy>=1.2 in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (from tox) (1.2.0)
Requirement already satisfied: pyproject-api>=1.5.2 in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (from tox) (1.5.3)
Requirement already satisfied: tomli>=2.0.1 in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (from tox) (2.0.1)
Requirement already satisfied: virtualenv>=20.23.1 in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (from tox) (20.24.2)
Requirement already satisfied: distlib<1,>=0.3.7 in /home/jenkins-build/build/workspace/ceph-pull-requests/build/qa-virtualenv/lib/python3.10/site-packages (from virtualenv>=20.23.1->tox) (0.3.7)
flake8: install_deps /home/jenkins-build/build/workspace/ceph-pull-requests/qa> python -I -m pip install flake8
flake8: freeze /home/jenkins-build/build/workspace/ceph-pull-requests/qa> python -m pip freeze --all
flake8: flake8==6.1.0,mccabe==0.7.0,pip==22.3.1,pycodestyle==2.11.0,pyflakes==3.1.0,setuptools==65.6.3,wheel==0.38.4
flake8: commands[0] /home/jenkins-build/build/workspace/ceph-pull-requests/qa> flake8 --select=F,E9 --exclude=venv,.tox
./tasks/cephfs/test_client_recovery.py:12:1: F811 redefinition of unused 'random' from line 7
flake8: exit 1 (3.72 seconds) /home/jenkins-build/build/workspace/ceph-pull-requests/qa> flake8 --select=F,E9 --exclude=venv,.tox pid=706315
flake8: FAIL ✖ in 15.42 seconds

Signed-off-by: Casey Bodley <cbodley@redhat.com>
2 years agodoc: add MDS treatise on segments
Patrick Donnelly [Fri, 4 Nov 2022 12:56:49 +0000 (08:56 -0400)]
doc: add MDS treatise on segments

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agopybind/mgr/dashboard: bump teuthology version
Patrick Donnelly [Sun, 11 Jun 2023 12:49:25 +0000 (08:49 -0400)]
pybind/mgr/dashboard: bump teuthology version

So stdin-killer and other utilities are installed in the bin directory.
vstart_runner.py now relies on their presence.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoqa/tasks/vstart_runner: stop overriding _run_python
Patrick Donnelly [Thu, 18 May 2023 13:56:33 +0000 (09:56 -0400)]
qa/tasks/vstart_runner: stop overriding _run_python

Now that the teuthology tools can be run in vstart_runner, there's no
reason to override this method.

Importantly, this enables the use of the new stdin-killer tool [1].

[1] https://github.com/ceph/teuthology/pull/1846

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoqa: stop overriding ceph_w prefix in vstart_runner
Patrick Donnelly [Thu, 22 Jun 2023 02:39:13 +0000 (22:39 -0400)]
qa: stop overriding ceph_w prefix in vstart_runner

These tools are now available in the $PATH so it's no longer necessary
to remove them.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoqa/tasks/vstart_runner: update teuthology helper tool paths
Patrick Donnelly [Thu, 18 May 2023 13:54:23 +0000 (09:54 -0400)]
qa/tasks/vstart_runner: update teuthology helper tool paths

With [1], these tools are now installed in the teuthology virtualenv.
Update the path in the command arguments so these tools can be run via
sudo.

[1] https://github.com/ceph/teuthology/pull/1846

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoqa/tasks/vstart_runner: allow writing to command's stdin
Patrick Donnelly [Thu, 18 May 2023 13:52:10 +0000 (09:52 -0400)]
qa/tasks/vstart_runner: allow writing to command's stdin

There's no technical reason to disallow this. The original intent was to
avoid deadlocks but this possibility is already present when interacting
with a teuthology RemoteProcess. Avoiding it only for local processes
does not make sense.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agovstart.sh: always add CEPH_CONF to vstart_environment.sh
Patrick Donnelly [Tue, 20 Jun 2023 17:46:01 +0000 (13:46 -0400)]
vstart.sh: always add CEPH_CONF to vstart_environment.sh

This makes sourcing this for e.g. vstart_runner.py actually useful.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoqa: use stdin-killer for python3 command
Patrick Donnelly [Tue, 16 May 2023 15:49:07 +0000 (11:49 -0400)]
qa: use stdin-killer for python3 command

This relies on the new stdin-killer [1] teuthology helper that allows
interacting with the command's stdin.

[1] https://github.com/ceph/teuthology/pull/1846

Fixes: 8bb77ed9e18d134e2e9964e950cbcbfc65e1b97d
Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoqa: add killpoint testing for mds shutdown
Patrick Donnelly [Wed, 8 Mar 2023 14:39:34 +0000 (09:39 -0500)]
qa: add killpoint testing for mds shutdown

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoqa: fix background exit condition
Patrick Donnelly [Wed, 8 Mar 2023 14:38:00 +0000 (09:38 -0500)]
qa: fix background exit condition

This change causes the program to exit gracefully when stdin is closed
rather than with a Python exception.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoqa: add filesystem helper for setting transient config
Patrick Donnelly [Thu, 15 Sep 2022 13:55:28 +0000 (09:55 -0400)]
qa: add filesystem helper for setting transient config

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoqa: add helper for waiting for a rank to fail
Patrick Donnelly [Thu, 15 Sep 2022 13:55:47 +0000 (09:55 -0400)]
qa: add helper for waiting for a rank to fail

For killpoint testing.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: add incompat feature for minor log segments
Patrick Donnelly [Sat, 6 May 2023 19:52:55 +0000 (15:52 -0400)]
mds: add incompat feature for minor log segments

To prevent old MDS from joining a file system with the new log events.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: introduce ELid event to create/close log
Patrick Donnelly [Tue, 7 Mar 2023 18:24:38 +0000 (13:24 -0500)]
mds: introduce ELid event to create/close log

Prior to this set of commits, the MDS would write the ESubtreeMap to the
journal, trim everything up to that segment, then finally force the
trimming of that last segment (`MDLog::trim(0)`). This is awkward in the
new code which preserves a major segment boundary at the beginning of
the journal during trimming. Instead of writing a special case for this
situation, it seems more natural to just use a new "lid" or "cap" event
to mark the beginning of the journal when no subtree map can yet be
written but we need sequence numbers to tie in other MDS tables.

Like ESegment, ELid doesn't actually contain any state. It's just a
marker for the beginning the log after rank deactivation or rank
creation. It can appear in the middle of the log if the shutdown
sequence is interrupted while writing the event but the MDS will skip it
during replay in that case.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: change EResetJournal to major segment boundary
Patrick Donnelly [Tue, 7 Mar 2023 18:23:05 +0000 (13:23 -0500)]
mds: change EResetJournal to major segment boundary

When the MDS journal is wiped, EResetJournal is a major segment boundary
as it necessarily begins the journal.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: add killpoints for MDS shutdown
Patrick Donnelly [Tue, 7 Mar 2023 18:20:19 +0000 (13:20 -0500)]
mds: add killpoints for MDS shutdown

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoqa: add numerous subtree test
Patrick Donnelly [Mon, 30 Jan 2023 19:33:32 +0000 (14:33 -0500)]
qa: add numerous subtree test

When the ESubtreeMap is very large (~5k+ subtrees), the MDS will
end up logging only a few events (as bad as 1) per segment as the
subtree map dominates the segment size.

This test simply creates an artificially large subtree and confirms that
other file system activity completes in a timely manner. This is now
taking advantage of the minor segments which allows for a normal set of
events per log segment (and fewer subtree maps). The test fails on the
current main HEAD.

Historical note: when I first observed this abberant behavior, the
vstart cluster was actually using mds_debug_subtrees = True (the default
for every vstart cluster). This caused the MDS to write out the subtree
map (for debugging reasons) with every event. When testing the MDS with
large subtrees (distributed ephemeral pinning), this caused the MDS to
slow to a trickle of operations per second. Despite this unintentional
misconfiguration, the problem still exists but the number of auth
subtrees must be large for a particlar rank to replicate the behavior.

On main HEAD, the creation of 10k files (workload stage) takes ~110
seconds. On this branch, it takes ~30 seconds.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: track larger log events in perf dump
Patrick Donnelly [Wed, 1 Feb 2023 20:01:37 +0000 (15:01 -0500)]
mds: track larger log events in perf dump

Fixes: https://tracker.ceph.com/issues/58550
Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: add minor LogSegment boundaries
Patrick Donnelly [Fri, 4 Nov 2022 17:50:13 +0000 (13:50 -0400)]
mds: add minor LogSegment boundaries

This commit adds a new ESegment event type which can delineate
LogSegments. This event can be used as an alternative to the heavy
weight ESubtreeMap which can be very expensive to generate when the MDS
has a large subtree map.

Fixes: https://tracker.ceph.com/issues/58154
Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: obviate MDLog::start_entry
Patrick Donnelly [Fri, 4 Nov 2022 12:58:46 +0000 (08:58 -0400)]
mds: obviate MDLog::start_entry

The major problem here is that the MDLog::_start_entry method puts the
current event sequence number in the EMetaBlob of the event (if
present). Because of this, no other event can be submitted as this would
invalidate the event sequence. Instead, fixup the event sequence during
submission and simplify related logic that uses it during EMetaBlob
construction.

Secondarily, for the purposes of this commit series, _start_entry
introduced recursive locks when generating the ESubtreeMap within
MDLog::_segment_upkeep. So, this commit is a necessary cleanup.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: retype to properly sized unsigned ints
Patrick Donnelly [Fri, 4 Nov 2022 13:42:52 +0000 (09:42 -0400)]
mds: retype to properly sized unsigned ints

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: use unsigned type for event count
Patrick Donnelly [Wed, 1 Feb 2023 19:14:52 +0000 (14:14 -0500)]
mds: use unsigned type for event count

To resolve comparison warnings in subsequent commit.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: use base Context class for generalization
Patrick Donnelly [Fri, 4 Nov 2022 01:43:10 +0000 (21:43 -0400)]
mds: use base Context class for generalization

No reason to specialize to MDSContext.

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: optimize segment lookup
Patrick Donnelly [Fri, 4 Nov 2022 01:41:32 +0000 (21:41 -0400)]
mds: optimize segment lookup

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: add stream dump for LogSegment
Patrick Donnelly [Thu, 3 Nov 2022 14:30:53 +0000 (10:30 -0400)]
mds: add stream dump for LogSegment

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: handle conf changes in mdlog
Patrick Donnelly [Wed, 1 Feb 2023 15:08:19 +0000 (10:08 -0500)]
mds: handle conf changes in mdlog

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: remove redundant comment
Patrick Donnelly [Wed, 2 Nov 2022 14:09:19 +0000 (10:09 -0400)]
mds: remove redundant comment

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: remove unused method
Patrick Donnelly [Wed, 2 Nov 2022 16:53:52 +0000 (12:53 -0400)]
mds: remove unused method

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: set a reasonable minimum number of segments
Patrick Donnelly [Wed, 1 Feb 2023 16:07:01 +0000 (11:07 -0500)]
mds: set a reasonable minimum number of segments

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agomds: sort configs
Patrick Donnelly [Wed, 1 Feb 2023 16:05:47 +0000 (11:05 -0500)]
mds: sort configs

Signed-off-by: Patrick Donnelly <pdonnell@redhat.com>
2 years agoMerge PR #51995 into main
Venky Shankar [Tue, 1 Aug 2023 15:06:59 +0000 (20:36 +0530)]
Merge PR #51995 into main

* refs/pull/51995/head:
qa: wait for file to have correct size

Reviewed-by: Milind Changire <mchangir@redhat.com>
2 years agoMerge pull request #52305 from Posrabi/wip-disk-frag-sim-metrics
Adam Kupczyk [Tue, 1 Aug 2023 13:50:41 +0000 (15:50 +0200)]
Merge pull request #52305 from Posrabi/wip-disk-frag-sim-metrics

test/objectstore: Disk Fragmentation Simulator Metrics

2 years agoexporter: fix instance_id labeld value for rgw in exporter
avanthakkar [Sun, 30 Jul 2023 21:09:36 +0000 (02:39 +0530)]
exporter: fix instance_id labeld value for rgw in exporter

Signed-off-by: avanthakkar <avanjohn@gmail.com>