You've already forked mariadb-columnstore-engine
mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-07-27 21:01:50 +03:00
MCOL-4912 This patch introduces Extent Map index to improve EM scaleability
EM scaleability project has two parts: phase1 and phase2. This is phase1 that brings EM index to speed up(from O(n) down to the speed of boost::unordered_map) EM lookups looking for <dbroot, oid, partition> tuple to turn it into LBID, e.g. most bulk insertion meta info operations. The basis is boost::shared_managed_object where EMIndex is stored. Whilst it is not debug-friendly it allows to put a nested structs into shmem. EMIndex has 3 tiers. Top down description: vector of dbroots, map of oids to partition vectors, partition vectors that have EM indices. Separate EM methods now queries index before they do EM run. EMIndex has a separate shmem file with the fixed id MCS-shm-00060001.
This commit is contained in:
committed by
Leonid Fedorov
parent
fb3eaabd29
commit
4c26e4f960
@ -1,4 +1,5 @@
|
||||
/* Copyright (C) 2014 InfiniDB, Inc.
|
||||
Copyright (C) 2016-2022 MariaDB Corporation
|
||||
|
||||
This program is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU General Public License
|
||||
@ -22,6 +23,7 @@
|
||||
*/
|
||||
|
||||
#include <iostream>
|
||||
#include <string>
|
||||
#include <stdlib.h>
|
||||
#include <rwlock.h>
|
||||
|
||||
@ -32,14 +34,18 @@ char* name;
|
||||
|
||||
void usage()
|
||||
{
|
||||
cout << "Usage " << name << " which_lock_to_use which_side_to_use lock_or_unlock\n"
|
||||
<< " which_lock_to_use: 1=VSS 2=ExtentMap 3=FreeList 4=VBBM 5=CopyLocks\n";
|
||||
std::cout << "Usage " << name << " which_lock_to_use:" << std::endl;
|
||||
size_t lockId = 0;
|
||||
for (auto& lockName : RWLockNames)
|
||||
{
|
||||
std::cout << " " << lockId++ << "=" << lockName << std::endl;
|
||||
}
|
||||
exit(1);
|
||||
}
|
||||
|
||||
int main(int argc, char** argv)
|
||||
{
|
||||
uint32_t which_lock; // 1-5
|
||||
uint32_t which_lock; // 0-6
|
||||
RWLock* rwlock;
|
||||
LockState state;
|
||||
|
||||
@ -51,18 +57,35 @@ int main(int argc, char** argv)
|
||||
if (strlen(argv[1]) != 1)
|
||||
usage();
|
||||
|
||||
which_lock = atoi(argv[1]);
|
||||
try
|
||||
{
|
||||
which_lock = std::stoi(argv[1]);
|
||||
}
|
||||
catch (std::exception const& e)
|
||||
{
|
||||
std::cerr << "Cannot convert the lock id: " << e.what() << std::endl;
|
||||
usage();
|
||||
}
|
||||
|
||||
if (which_lock < 1 || which_lock > 5)
|
||||
if (which_lock >= RWLockNames.size())
|
||||
usage();
|
||||
|
||||
rwlock = new RWLock(0x10000 * which_lock);
|
||||
state = rwlock->getLockState();
|
||||
cout << "readers = " << state.reading << endl
|
||||
<< "writers = " << state.writing << endl
|
||||
<< "readers waiting = " << state.readerswaiting << endl
|
||||
<< "writers waiting = " << state.writerswaiting << endl
|
||||
<< "mutex locked = " << (int)state.mutexLocked << endl;
|
||||
size_t minLockId = (which_lock > 0) ? which_lock : 1;
|
||||
size_t maxLockId = (which_lock > 0) ? which_lock : RWLockNames.size() - 1;
|
||||
|
||||
for (size_t i = minLockId; i <= maxLockId; ++i)
|
||||
{
|
||||
rwlock = new RWLock(0x10000 * i);
|
||||
state = rwlock->getLockState();
|
||||
|
||||
cout << RWLockNames[i] << " RWLock" << std::endl
|
||||
<< " readers = " << state.reading << std::endl
|
||||
<< " writers = " << state.writing << std::endl
|
||||
<< " readers waiting = " << state.readerswaiting << std::endl
|
||||
<< " writers waiting = " << state.writerswaiting << std::endl
|
||||
<< " mutex locked = " << (int)state.mutexLocked << std::endl;
|
||||
delete rwlock;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
Reference in New Issue
Block a user