2018-11-27 03:50:24 +00:00
|
|
|
.. _rgw_dynamic_bucket_index_resharding:
|
|
|
|
|
2017-06-26 11:58:49 +00:00
|
|
|
===================================
|
|
|
|
RGW Dynamic Bucket Index Resharding
|
|
|
|
===================================
|
|
|
|
|
|
|
|
.. versionadded:: Luminous
|
|
|
|
|
|
|
|
A large bucket index can lead to performance problems. In order
|
|
|
|
to address this problem we introduced bucket index sharding.
|
|
|
|
Until Luminous, changing the number of bucket shards (resharding)
|
2019-03-28 17:30:08 +00:00
|
|
|
needed to be done offline. Starting with Luminous we support
|
2017-06-26 11:58:49 +00:00
|
|
|
online bucket resharding.
|
|
|
|
|
|
|
|
Each bucket index shard can handle its entries efficiently up until
|
2019-10-07 23:38:07 +00:00
|
|
|
reaching a certain threshold number of entries. If this threshold is
|
2020-10-07 22:21:28 +00:00
|
|
|
exceeded the system can suffer from performance issues. The dynamic
|
2019-10-07 23:38:07 +00:00
|
|
|
resharding feature detects this situation and automatically increases
|
2020-10-07 22:21:28 +00:00
|
|
|
the number of shards used by the bucket index, resulting in a
|
2019-10-07 23:38:07 +00:00
|
|
|
reduction of the number of entries in each bucket index shard. This
|
2021-05-27 02:09:39 +00:00
|
|
|
process is transparent to the user. Write I/Os to the target bucket
|
|
|
|
are blocked and read I/Os are not during resharding process.
|
2019-10-07 23:38:07 +00:00
|
|
|
|
|
|
|
By default dynamic bucket index resharding can only increase the
|
2020-10-07 22:21:28 +00:00
|
|
|
number of bucket index shards to 1999, although this upper-bound is a
|
|
|
|
configuration parameter (see Configuration below). When
|
2019-10-07 23:38:07 +00:00
|
|
|
possible, the process chooses a prime number of bucket index shards to
|
2020-10-07 22:21:28 +00:00
|
|
|
spread the number of bucket index entries across the bucket index
|
2019-10-07 23:38:07 +00:00
|
|
|
shards more evenly.
|
|
|
|
|
|
|
|
The detection process runs in a background process that periodically
|
|
|
|
scans all the buckets. A bucket that requires resharding is added to
|
|
|
|
the resharding queue and will be scheduled to be resharded later. The
|
|
|
|
reshard thread runs in the background and execute the scheduled
|
|
|
|
resharding tasks, one at a time.
|
2017-06-26 11:58:49 +00:00
|
|
|
|
|
|
|
Multisite
|
|
|
|
=========
|
2019-03-28 17:30:08 +00:00
|
|
|
|
|
|
|
Dynamic resharding is not supported in a multisite environment.
|
2017-06-26 11:58:49 +00:00
|
|
|
|
|
|
|
|
|
|
|
Configuration
|
|
|
|
=============
|
|
|
|
|
2019-03-28 17:30:08 +00:00
|
|
|
Enable/Disable dynamic bucket index resharding:
|
2017-06-26 11:58:49 +00:00
|
|
|
|
2019-03-28 17:30:08 +00:00
|
|
|
- ``rgw_dynamic_resharding``: true/false, default: true
|
2017-06-26 11:58:49 +00:00
|
|
|
|
2019-03-28 17:30:08 +00:00
|
|
|
Configuration options that control the resharding process:
|
2017-06-26 11:58:49 +00:00
|
|
|
|
2019-10-07 23:38:07 +00:00
|
|
|
- ``rgw_max_objs_per_shard``: maximum number of objects per bucket index shard before resharding is triggered, default: 100000 objects
|
2017-06-26 11:58:49 +00:00
|
|
|
|
2019-10-07 23:38:07 +00:00
|
|
|
- ``rgw_max_dynamic_shards``: maximum number of shards that dynamic bucket index resharding can increase to, default: 1999
|
2017-06-26 11:58:49 +00:00
|
|
|
|
2019-10-07 23:38:07 +00:00
|
|
|
- ``rgw_reshard_bucket_lock_duration``: duration, in seconds, of lock on bucket obj during resharding, default: 360 seconds (i.e., 6 minutes)
|
2017-06-26 11:58:49 +00:00
|
|
|
|
2019-10-07 23:38:07 +00:00
|
|
|
- ``rgw_reshard_thread_interval``: maximum time, in seconds, between rounds of resharding queue processing, default: 600 seconds (i.e., 10 minutes)
|
2017-06-26 11:58:49 +00:00
|
|
|
|
2019-10-07 23:38:07 +00:00
|
|
|
- ``rgw_reshard_num_logs``: number of shards for the resharding queue, default: 16
|
2017-06-26 11:58:49 +00:00
|
|
|
|
|
|
|
Admin commands
|
|
|
|
==============
|
|
|
|
|
|
|
|
Add a bucket to the resharding queue
|
|
|
|
------------------------------------
|
2018-03-20 08:49:32 +00:00
|
|
|
|
2017-06-26 11:58:49 +00:00
|
|
|
::
|
2018-03-20 08:49:32 +00:00
|
|
|
|
|
|
|
# radosgw-admin reshard add --bucket <bucket_name> --num-shards <new number of shards>
|
2017-06-26 11:58:49 +00:00
|
|
|
|
|
|
|
List resharding queue
|
|
|
|
---------------------
|
2018-03-20 08:49:32 +00:00
|
|
|
|
2017-06-26 11:58:49 +00:00
|
|
|
::
|
2018-03-20 08:49:32 +00:00
|
|
|
|
2017-10-31 12:59:07 +00:00
|
|
|
# radosgw-admin reshard list
|
2017-06-26 11:58:49 +00:00
|
|
|
|
2019-03-28 17:30:08 +00:00
|
|
|
Process tasks on the resharding queue
|
|
|
|
-------------------------------------
|
2018-03-20 08:49:32 +00:00
|
|
|
|
|
|
|
::
|
|
|
|
|
2017-06-26 11:58:49 +00:00
|
|
|
# radosgw-admin reshard process
|
|
|
|
|
2018-03-20 08:49:32 +00:00
|
|
|
Bucket resharding status
|
2017-06-26 11:58:49 +00:00
|
|
|
------------------------
|
2018-03-20 08:49:32 +00:00
|
|
|
|
2017-06-26 11:58:49 +00:00
|
|
|
::
|
2018-03-20 08:49:32 +00:00
|
|
|
|
|
|
|
# radosgw-admin reshard status --bucket <bucket_name>
|
2017-06-26 11:58:49 +00:00
|
|
|
|
2018-12-11 17:43:32 +00:00
|
|
|
The output is a json array of 3 objects (reshard_status, new_bucket_instance_id, num_shards) per shard.
|
|
|
|
|
|
|
|
For example, the output at different Dynamic Resharding stages is shown below:
|
|
|
|
|
|
|
|
``1. Before resharding occurred:``
|
|
|
|
::
|
|
|
|
|
|
|
|
[
|
|
|
|
{
|
2019-05-12 13:45:30 +00:00
|
|
|
"reshard_status": "not-resharding",
|
2018-12-11 17:43:32 +00:00
|
|
|
"new_bucket_instance_id": "",
|
|
|
|
"num_shards": -1
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
``2. During resharding:``
|
|
|
|
::
|
|
|
|
|
|
|
|
[
|
|
|
|
{
|
2019-05-12 13:45:30 +00:00
|
|
|
"reshard_status": "in-progress",
|
2018-12-11 17:43:32 +00:00
|
|
|
"new_bucket_instance_id": "1179f470-2ebf-4630-8ec3-c9922da887fd.8652.1",
|
|
|
|
"num_shards": 2
|
|
|
|
},
|
|
|
|
{
|
2019-05-12 13:45:30 +00:00
|
|
|
"reshard_status": "in-progress",
|
2018-12-11 17:43:32 +00:00
|
|
|
"new_bucket_instance_id": "1179f470-2ebf-4630-8ec3-c9922da887fd.8652.1",
|
|
|
|
"num_shards": 2
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
``3, After resharding completed:``
|
|
|
|
::
|
|
|
|
|
|
|
|
[
|
|
|
|
{
|
2019-05-12 13:45:30 +00:00
|
|
|
"reshard_status": "not-resharding",
|
2018-12-11 17:43:32 +00:00
|
|
|
"new_bucket_instance_id": "",
|
|
|
|
"num_shards": -1
|
|
|
|
},
|
|
|
|
{
|
2019-05-12 13:45:30 +00:00
|
|
|
"reshard_status": "not-resharding",
|
2018-12-11 17:43:32 +00:00
|
|
|
"new_bucket_instance_id": "",
|
|
|
|
"num_shards": -1
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
|
2017-06-26 11:58:49 +00:00
|
|
|
Cancel pending bucket resharding
|
|
|
|
--------------------------------
|
|
|
|
|
2019-03-28 17:30:08 +00:00
|
|
|
Note: Ongoing bucket resharding operations cannot be cancelled. ::
|
2017-06-26 11:58:49 +00:00
|
|
|
|
2018-03-20 08:49:32 +00:00
|
|
|
# radosgw-admin reshard cancel --bucket <bucket_name>
|
2017-06-26 11:58:49 +00:00
|
|
|
|
2019-03-28 17:30:08 +00:00
|
|
|
Manual immediate bucket resharding
|
|
|
|
----------------------------------
|
2018-03-20 08:49:32 +00:00
|
|
|
|
2017-06-26 11:58:49 +00:00
|
|
|
::
|
|
|
|
|
2018-03-20 08:49:32 +00:00
|
|
|
# radosgw-admin bucket reshard --bucket <bucket_name> --num-shards <new number of shards>
|
2019-03-08 15:57:28 +00:00
|
|
|
|
2019-10-07 23:38:07 +00:00
|
|
|
When choosing a number of shards, the administrator should keep a
|
|
|
|
number of items in mind. Ideally the administrator is aiming for no
|
|
|
|
more than 100000 entries per shard, now and through some future point
|
|
|
|
in time.
|
|
|
|
|
|
|
|
Additionally, bucket index shards that are prime numbers tend to work
|
|
|
|
better in evenly distributing bucket index entries across the
|
|
|
|
shards. For example, 7001 bucket index shards is better than 7000
|
|
|
|
since the former is prime. A variety of web sites have lists of prime
|
|
|
|
numbers; search for "list of prime numbers" withy your favorite web
|
|
|
|
search engine to locate some web sites.
|
2019-03-08 15:57:28 +00:00
|
|
|
|
|
|
|
Troubleshooting
|
|
|
|
===============
|
|
|
|
|
|
|
|
Clusters prior to Luminous 12.2.11 and Mimic 13.2.5 left behind stale bucket
|
2019-03-28 17:30:08 +00:00
|
|
|
instance entries, which were not automatically cleaned up. The issue also affected
|
|
|
|
LifeCycle policies, which were not applied to resharded buckets anymore. Both of
|
2019-03-08 15:57:28 +00:00
|
|
|
these issues can be worked around using a couple of radosgw-admin commands.
|
|
|
|
|
2019-03-28 17:30:08 +00:00
|
|
|
Stale instance management
|
2019-03-08 15:57:28 +00:00
|
|
|
-------------------------
|
|
|
|
|
2019-03-28 17:30:08 +00:00
|
|
|
List the stale instances in a cluster that are ready to be cleaned up.
|
|
|
|
|
2019-03-08 15:57:28 +00:00
|
|
|
::
|
|
|
|
|
|
|
|
# radosgw-admin reshard stale-instances list
|
|
|
|
|
2019-03-28 17:30:08 +00:00
|
|
|
Clean up the stale instances in a cluster. Note: cleanup of these
|
|
|
|
instances should only be done on a single site cluster.
|
2019-03-08 15:57:28 +00:00
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
# radosgw-admin reshard stale-instances rm
|
|
|
|
|
|
|
|
|
|
|
|
Lifecycle fixes
|
|
|
|
---------------
|
|
|
|
|
2019-03-28 17:30:08 +00:00
|
|
|
For clusters that had resharded instances, it is highly likely that the old
|
|
|
|
lifecycle processes would have flagged and deleted lifecycle processing as the
|
2019-03-08 15:57:28 +00:00
|
|
|
bucket instance changed during a reshard. While this is fixed for newer clusters
|
2019-03-28 17:30:08 +00:00
|
|
|
(from Mimic 13.2.6 and Luminous 12.2.12), older buckets that had lifecycle policies and
|
|
|
|
that have undergone resharding will have to be manually fixed.
|
|
|
|
|
|
|
|
The command to do so is:
|
2019-03-08 15:57:28 +00:00
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
# radosgw-admin lc reshard fix --bucket {bucketname}
|
|
|
|
|
|
|
|
|
|
|
|
As a convenience wrapper, if the ``--bucket`` argument is dropped then this
|
2019-03-28 17:30:08 +00:00
|
|
|
command will try and fix lifecycle policies for all the buckets in the cluster.
|
2019-05-02 13:25:22 +00:00
|
|
|
|
|
|
|
Object Expirer fixes
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
Objects subject to Swift object expiration on older clusters may have
|
|
|
|
been dropped from the log pool and never deleted after the bucket was
|
|
|
|
resharded. This would happen if their expiration time was before the
|
|
|
|
cluster was upgraded, but if their expiration was after the upgrade
|
|
|
|
the objects would be correctly handled. To manage these expire-stale
|
|
|
|
objects, radosgw-admin provides two subcommands.
|
|
|
|
|
|
|
|
Listing:
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
# radosgw-admin objects expire-stale list --bucket {bucketname}
|
|
|
|
|
|
|
|
Displays a list of object names and expiration times in JSON format.
|
|
|
|
|
|
|
|
Deleting:
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
# radosgw-admin objects expire-stale rm --bucket {bucketname}
|
|
|
|
|
|
|
|
|
|
|
|
Initiates deletion of such objects, displaying a list of object names, expiration times, and deletion status in JSON format.
|