ClickHouse/src/Disks/VolumeJBOD.h

73 lines
2.0 KiB
C++
Raw Normal View History

#pragma once
#include <memory>
#include <optional>
#include <Disks/IVolume.h>
namespace DB
{
class VolumeJBOD;
using VolumeJBODPtr = std::shared_ptr<VolumeJBOD>;
using VolumesJBOD = std::vector<VolumeJBODPtr>;
/**
* Implements something similar to JBOD (https://en.wikipedia.org/wiki/Non-RAID_drive_architectures#JBOD).
* When MergeTree engine wants to write part it requests VolumeJBOD to reserve space on the next available
* disk and then writes new part to that disk.
*/
class VolumeJBOD : public IVolume
{
public:
VolumeJBOD(String name_, Disks disks_, UInt64 max_data_part_size_, bool are_merges_allowed_)
2020-07-30 10:04:49 +00:00
: IVolume(name_, disks_, max_data_part_size_)
, are_merges_allowed(are_merges_allowed_)
{
}
VolumeJBOD(
String name_,
const Poco::Util::AbstractConfiguration & config,
const String & config_prefix,
DiskSelectorPtr disk_selector
);
VolumeJBOD(
const VolumeJBOD & volume_jbod,
const Poco::Util::AbstractConfiguration & config,
const String & config_prefix,
DiskSelectorPtr disk_selector
);
VolumeType getType() const override { return VolumeType::JBOD; }
2020-07-30 10:04:49 +00:00
/// Always returns next disk (round-robin), ignores argument.
///
/// - Used with policy for temporary data
/// - Ignores all limitations
/// - Shares last access with reserve()
2020-07-30 11:08:56 +00:00
DiskPtr getDisk(size_t index) const override;
/// Uses Round-robin to choose disk for reservation.
/// Returns valid reservation or nullptr if there is no space left on any disk.
ReservationPtr reserve(UInt64 bytes) override;
bool areMergesAllowed() const override;
void setAllowMergesFromQuery(bool allow) override;
/// True if parts on this volume participate in merges according to configuration.
bool are_merges_allowed = true;
/// True if parts on this volume participate in merges according to START/STOP MERGES ON VOLUME.
std::optional<bool> are_merges_allowed_user_override;
private:
mutable std::atomic<size_t> last_used = 0;
};
}