You've already forked mariadb-columnstore-engine
mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-07-30 19:23:07 +03:00
MCOL-5722 Tool to move meta from files to fdb for existing installation.
This commit is contained in:
committed by
Leonid Fedorov
parent
66778933ce
commit
f877b17841
@ -14,4 +14,5 @@ add_subdirectory(rebuildEM)
|
|||||||
add_subdirectory(passwd)
|
add_subdirectory(passwd)
|
||||||
add_subdirectory(configMgt)
|
add_subdirectory(configMgt)
|
||||||
add_subdirectory(parquetGen)
|
add_subdirectory(parquetGen)
|
||||||
add_subdirectory(parquetDDL)
|
add_subdirectory(parquetDDL)
|
||||||
|
add_subdirectory(updateMeta)
|
||||||
|
6
tools/updateMeta/CMakeLists.txt
Normal file
6
tools/updateMeta/CMakeLists.txt
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
include_directories(${ENGINE_COMMON_INCLUDES})
|
||||||
|
|
||||||
|
set(updateMeta_SRCS updateMeta.cpp)
|
||||||
|
add_executable(updateMeta ${updateMeta_SRCS})
|
||||||
|
target_link_libraries(updateMeta ${ENGINE_LDFLAGS} fdbcs)
|
||||||
|
install(TARGETS updateMeta DESTINATION ${ENGINE_BINDIR} COMPONENT columnstore-engine)
|
141
tools/updateMeta/updateMeta.cpp
Normal file
141
tools/updateMeta/updateMeta.cpp
Normal file
@ -0,0 +1,141 @@
|
|||||||
|
/* Copyright (C) 2024 MariaDB Corporation
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU General Public License
|
||||||
|
as published by the Free Software Foundation; version 2 of
|
||||||
|
the License.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
MA 02110-1301, USA. */
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
#include <string>
|
||||||
|
#include <filesystem>
|
||||||
|
#include <vector>
|
||||||
|
#include "fdbcs.hpp"
|
||||||
|
#include <fstream>
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
std::unique_ptr<FDBCS::FDBNetwork> fdbNetworkInstance;
|
||||||
|
|
||||||
|
static std::shared_ptr<FDBCS::FDBDataBase> getStorageInstance()
|
||||||
|
{
|
||||||
|
if (!FDBCS::setAPIVersion())
|
||||||
|
{
|
||||||
|
cerr << "Update meta: FDB setAPIVersion failed." << endl;
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
fdbNetworkInstance = std::make_unique<FDBCS::FDBNetwork>();
|
||||||
|
if (!fdbNetworkInstance->setUpAndRunNetwork())
|
||||||
|
{
|
||||||
|
cerr << "Update meta: FDB setUpAndRunNetwork failed." << endl;
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string clusterFilePath = "/etc/foundationdb/fdb.cluster";
|
||||||
|
auto fdbDataBaseInstance = FDBCS::DataBaseCreator::createDataBase(clusterFilePath);
|
||||||
|
if (!fdbDataBaseInstance)
|
||||||
|
{
|
||||||
|
cerr << "Update meta: FDB createDataBase failed." << endl;
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
return fdbDataBaseInstance;
|
||||||
|
}
|
||||||
|
|
||||||
|
class MetaCollector
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
MetaCollector(const std::string& metaPath) : metaPath(metaPath)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
bool collect(const std::string& dbRoot)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
auto path = metaPath + dbRoot;
|
||||||
|
for (auto const& file : std::filesystem::recursive_directory_iterator{path})
|
||||||
|
{
|
||||||
|
if (std::filesystem::is_regular_file(file))
|
||||||
|
{
|
||||||
|
files.push_back(file.path());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (std::exception& e)
|
||||||
|
{
|
||||||
|
std::cerr << e.what() << std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool commit()
|
||||||
|
{
|
||||||
|
auto kvStorage = getStorageInstance();
|
||||||
|
if (!kvStorage)
|
||||||
|
{
|
||||||
|
cerr << "Cannot get a storage instance" << endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
auto keyGen = std::make_shared<FDBCS::BoostUIDKeyGenerator>();
|
||||||
|
|
||||||
|
for (const auto& file : files)
|
||||||
|
{
|
||||||
|
auto fileName = file.string();
|
||||||
|
cout << fileName << endl;
|
||||||
|
ifstream iFile(fileName);
|
||||||
|
if (!iFile.is_open())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
std::stringstream metaDataStream;
|
||||||
|
metaDataStream << iFile.rdbuf();
|
||||||
|
FDBCS::BlobHandler blobWriter(keyGen);
|
||||||
|
auto metaKey = metaPrefix + fileName;
|
||||||
|
if (!blobWriter.writeBlob(kvStorage, metaKey, metaDataStream.str()))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::vector<filesystem::path> files;
|
||||||
|
string metaPrefix = "SM_M_";
|
||||||
|
string metaPath;
|
||||||
|
string dbRoot;
|
||||||
|
};
|
||||||
|
|
||||||
|
int main(int argc, char** argv)
|
||||||
|
{
|
||||||
|
if (argc != 2)
|
||||||
|
{
|
||||||
|
cout << "Have to provide dbroot name. For example: updateMeta data1 " << endl;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
std::string metaPath = "/var/lib/columnstore/storagemanager/metadata/";
|
||||||
|
MetaCollector collector(metaPath);
|
||||||
|
string dbRootName = argv[1];
|
||||||
|
if (!collector.collect(dbRootName))
|
||||||
|
{
|
||||||
|
cerr << "Cannot collect metadata files " << endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
if (!collector.commit())
|
||||||
|
{
|
||||||
|
cerr << "Cannot commit metadata to kv storage " << endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
Reference in New Issue
Block a user