// Copyright (C) 2023 Speedb Ltd. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // 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. #include #include #include #include "rocksdb/db.h" #include "rocksdb/options.h" using namespace ROCKSDB_NAMESPACE; #if defined(OS_WIN) std::string kDBPath = "C:\\Windows\\TEMP\\speedb_thr_affinity"; #else std::string kDBPath = "/tmp/speedb_thr_affinity"; #endif int main() { // Open the storage DB* db = nullptr; Options options; // create the DB if it's not already present options.create_if_missing = true; auto f = [](std::thread::native_handle_type thr) { // callback to pin all Speedb threads to the first core. #if defined(OS_WIN) #include "winbase.h" SetThreadAffinityMask(thr, 0); #else #include "pthread.h" std::cout << "thread spawned, thread_id: " << thr << std::endl; cpu_set_t cpuset; CPU_ZERO(&cpuset); CPU_SET(0, &cpuset); pthread_setaffinity_np(thr, sizeof(cpu_set_t), &cpuset); #endif }; options.on_thread_start_callback = std::make_shared>(f); Status s = DB::Open(options, kDBPath, &db); assert(s.ok()); // append new entry std::string key = "key_1"; std::string put_value = "Speedb is awesome!"; s = db->Put(WriteOptions(), key, put_value); assert(s.ok()); // retrieve entry std::string get_value; s = db->Get(ReadOptions(), key, &get_value); assert(s.ok()); assert(get_value == put_value); std::cout << get_value << std::endl; // close DB s = db->Close(); assert(s.ok()); return 0; }