diff options
author | Kefu Chai <kchai@redhat.com> | 2020-07-02 16:48:00 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-07-02 16:48:00 +0200 |
commit | 0e6004cc6e68d061411c8a1e776cb2ba7f479169 (patch) | |
tree | 89c8062623be16ae51529da9a86bb2e7c3ca4dbd | |
parent | Merge pull request #35745 from votdev/issue_46146_delete_host (diff) | |
parent | crimson/os/alienstore: assert on failure (diff) | |
download | ceph-0e6004cc6e68d061411c8a1e776cb2ba7f479169.tar.xz ceph-0e6004cc6e68d061411c8a1e776cb2ba7f479169.zip |
Merge pull request #35894 from tchaikov/wip-crimson-os
crimson/os: pin the last cpu core for the alien worker threads
Reviewed-by: Radoslaw Zarzynski <rzarzyns@redhat.com>
Reviewed-by: Deepika Upadhyay <dupadhya@redhat.com>
-rw-r--r-- | src/crimson/os/alienstore/alien_store.cc | 37 | ||||
-rw-r--r-- | src/crimson/os/alienstore/thread_pool.cc | 6 | ||||
-rw-r--r-- | src/crimson/os/alienstore/thread_pool.h | 2 |
3 files changed, 32 insertions, 13 deletions
diff --git a/src/crimson/os/alienstore/alien_store.cc b/src/crimson/os/alienstore/alien_store.cc index 1048f978ed7..66a350e0375 100644 --- a/src/crimson/os/alienstore/alien_store.cc +++ b/src/crimson/os/alienstore/alien_store.cc @@ -66,7 +66,15 @@ AlienStore::AlienStore(const std::string& path, const ConfigValues& values) g_ceph_context = cct.get(); cct->_conf.set_config_values(values); store = std::make_unique<BlueStore>(cct.get(), path); - tp = std::make_unique<crimson::os::ThreadPool>(1, 128, seastar::this_shard_id() + 10); + + long cpu_id = 0; + if (long nr_cpus = sysconf(_SC_NPROCESSORS_ONLN); nr_cpus != -1) { + cpu_id = nr_cpus - 1; + } else { + logger().error("{}: unable to get nproc: {}", __func__, errno); + cpu_id = -1; + } + tp = std::make_unique<crimson::os::ThreadPool>(1, 128, cpu_id); } seastar::future<> AlienStore::start() @@ -92,7 +100,8 @@ seastar::future<> AlienStore::mount() logger().debug("{}", __func__); return tp->submit([this] { return store->mount(); - }).then([] (int) { + }).then([] (int r) { + assert(r == 0); return seastar::now(); }); } @@ -104,7 +113,8 @@ seastar::future<> AlienStore::umount() return tp->submit([this] { return store->umount(); }); - }).then([] (int) { + }).then([] (int r) { + assert(r == 0); return seastar::now(); }); } @@ -115,7 +125,8 @@ seastar::future<> AlienStore::mkfs(uuid_d new_osd_fsid) osd_fsid = new_osd_fsid; return tp->submit([this] { return store->mkfs(); - }).then([] (int) { + }).then([] (int r) { + assert(r == 0); return seastar::now(); }); } @@ -135,7 +146,8 @@ AlienStore::list_objects(CollectionRef ch, return store->collection_list(c->collection, start, end, store->get_ideal_list_max(), &objects, &next); - }).then([&objects, &next] (int) { + }).then([&objects, &next] (int r) { + assert(r == 0); return seastar::make_ready_future<std::tuple<std::vector<ghobject_t>, ghobject_t>>( std::make_tuple(std::move(objects), std::move(next))); }); @@ -194,7 +206,8 @@ seastar::future<std::vector<coll_t>> AlienStore::list_collections() return seastar::do_with(std::vector<coll_t>{}, [=] (auto &ls) { return tp->submit([this, &ls] { return store->list_collections(ls); - }).then([&ls] (int) { + }).then([&ls] (int r) { + assert(r == 0); return seastar::make_ready_future<std::vector<coll_t>>(std::move(ls)); }); }); @@ -303,7 +316,8 @@ AlienStore::omap_get_values(CollectionRef ch, auto c = static_cast<AlienCollection*>(ch.get()); return store->omap_get_values(c->collection, oid, keys, reinterpret_cast<map<string, bufferlist>*>(&values)); - }).then([&values] (int) { + }).then([&values] (int r) { + assert(r == 0); return seastar::make_ready_future<omap_values_t>(std::move(values)); }); }); @@ -346,7 +360,8 @@ seastar::future<> AlienStore::do_transaction(CollectionRef ch, auto c = static_cast<AlienCollection*>(ch.get()); return store->queue_transaction(c->collection, std::move(txn)); }); - }).then([this, &done] (int) { + }).then([this, &done] (int r) { + assert(r == 0); tp_mutex.unlock(); return done.get_future(); }); @@ -360,7 +375,8 @@ seastar::future<> AlienStore::write_meta(const std::string& key, logger().debug("{}", __func__); return tp->submit([=] { return store->write_meta(key, value); - }).then([] (int) { + }).then([] (int r) { + assert(r == 0); return seastar::make_ready_future<>(); }); } @@ -398,7 +414,8 @@ seastar::future<store_statfs_t> AlienStore::stat() const return seastar::do_with(store_statfs_t{}, [this] (store_statfs_t &st) { return tp->submit([this, &st] { return store->statfs(&st, nullptr); - }).then([&st] (int) { + }).then([&st] (int r) { + assert(r == 0); return seastar::make_ready_future<store_statfs_t>(std::move(st)); }); }); diff --git a/src/crimson/os/alienstore/thread_pool.cc b/src/crimson/os/alienstore/thread_pool.cc index 323bea52024..488599e2748 100644 --- a/src/crimson/os/alienstore/thread_pool.cc +++ b/src/crimson/os/alienstore/thread_pool.cc @@ -13,14 +13,16 @@ namespace crimson::os { ThreadPool::ThreadPool(size_t n_threads, size_t queue_sz, - unsigned cpu_id) + long cpu_id) : queue_size{round_up_to(queue_sz, seastar::smp::count)}, pending{queue_size} { auto queue_max_wait = std::chrono::seconds(local_conf()->threadpool_empty_queue_max_wait); for (size_t i = 0; i < n_threads; i++) { threads.emplace_back([this, cpu_id, queue_max_wait] { - pin(cpu_id); + if (cpu_id >= 0) { + pin(cpu_id); + } crimson::os::AlienStore::configure_thread_memory(); loop(queue_max_wait); }); diff --git a/src/crimson/os/alienstore/thread_pool.h b/src/crimson/os/alienstore/thread_pool.h index ec3e450a578..f8d773319c7 100644 --- a/src/crimson/os/alienstore/thread_pool.h +++ b/src/crimson/os/alienstore/thread_pool.h @@ -101,7 +101,7 @@ public: * @note each @c Task has its own crimson::thread::Condition, which possesses * an fd, so we should keep the size of queue under a reasonable limit. */ - ThreadPool(size_t n_threads, size_t queue_sz, unsigned cpu); + ThreadPool(size_t n_threads, size_t queue_sz, long cpu); ~ThreadPool(); seastar::future<> start(); seastar::future<> stop(); |