/* * This file is open source software, licensed to you under the terms * of the Apache License, Version 2.0 (the "License"). See the NOTICE file * distributed with this work for additional information regarding copyright * ownership. You may not use this file except in compliance with the License. * * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ /* * Copyright (C) 2021 ScyllaDB */ #include #include #include #include #include #include using namespace seastar; int main(int ac, char** av) { namespace bpo = boost::program_options; app_template app; auto opt_add = app.add_options(); opt_add ("directory", bpo::value()->default_value("."), "directory to work on") ("max-reqsize", bpo::value()->default_value(128u * 1024u), "maximum request size in bytes used when calculating capacity (default: 128kB)") ; return app.run(ac, av, [&] { return seastar::async([&] { auto& opts = app.configuration(); auto& storage = opts["directory"].as(); auto max_reqsz = opts["max-reqsize"].as(); YAML::Emitter out; out << YAML::BeginDoc; out << YAML::BeginMap; engine().open_file_dma(storage + "/tempfile", open_flags::rw | open_flags::create | open_flags::exclusive).then([&] (file f) { return with_closeable(std::move(f), [&out, &storage, max_reqsz] (file& f) { return remove_file(storage + "/tempfile").then([&out, &f] { out << YAML::Key << "disk_read_max_length" << YAML::Value << f.disk_read_max_length(); out << YAML::Key << "disk_write_max_length" << YAML::Value << f.disk_write_max_length(); }).then([&out, &f, max_reqsz] { return f.stat().then([&out, max_reqsz] (auto st) { auto& ioq = engine().get_io_queue(st.st_dev); auto& cfg = ioq.get_config(); out << YAML::Key << "io_latency_goal_ms" << YAML::Value << std::chrono::duration_cast>(cfg.rate_limit_duration).count(); out << YAML::Key << "io_queue" << YAML::BeginMap; out << YAML::Key << "req_count_rate" << YAML::Value << cfg.req_count_rate; out << YAML::Key << "blocks_count_rate" << YAML::Value << cfg.blocks_count_rate; out << YAML::Key << "disk_req_write_to_read_multiplier" << YAML::Value << cfg.disk_req_write_to_read_multiplier; out << YAML::Key << "disk_blocks_write_to_read_multiplier" << YAML::Value << cfg.disk_blocks_write_to_read_multiplier; out << YAML::EndMap; out << YAML::Key << "fair_queue" << YAML::BeginMap; out << YAML::Key << "capacities" << YAML::BeginMap; for (size_t sz = 512; sz <= max_reqsz; sz <<= 1) { out << YAML::Key << sz << YAML::BeginMap; out << YAML::Key << "read" << YAML::Value << ioq.request_capacity(internal::io_direction_and_length(internal::io_direction_and_length::read_idx, sz)); out << YAML::Key << "write" << YAML::Value << ioq.request_capacity(internal::io_direction_and_length(internal::io_direction_and_length::write_idx, sz)); out << YAML::EndMap; } out << YAML::EndMap; const auto& fg = internal::get_fair_group(ioq, internal::io_direction_and_length::write_idx); out << YAML::Key << "per_tick_grab_threshold" << YAML::Value << fg.per_tick_grab_threshold(); const auto& tb = fg.token_bucket(); out << YAML::Key << "token_bucket" << YAML::BeginMap; out << YAML::Key << "limit" << YAML::Value << tb.limit(); out << YAML::Key << "rate" << YAML::Value << tb.rate(); out << YAML::Key << "threshold" << YAML::Value << tb.threshold(); out << YAML::EndMap; out << YAML::EndMap; }); }); }); }).get(); out << YAML::EndMap; out << YAML::EndDoc; std::cout << out.c_str(); }); }); }