ClickHouse/dbms/src/IO/tests/o_direct_and_dirty_pages.cpp

79 lines
1.7 KiB
C++
Raw Normal View History

2014-01-04 04:52:22 +00:00
#include <string>
#include <iostream>
#include <DB/Core/Types.h>
#include <DB/IO/WriteHelpers.h>
#include <DB/IO/ReadHelpers.h>
#include <DB/IO/WriteBufferFromFile.h>
#include <DB/IO/ReadBufferFromFile.h>
int main(int argc, char ** argv)
{
using namespace DB;
try
{
2014-04-02 07:14:40 +00:00
const size_t N = 100000;
const size_t BUF_SIZE = 1048576;
2014-01-04 04:52:22 +00:00
ReadBufferFromFile rand_in("/dev/urandom");
unsigned rand = 0;
readBinary(rand, rand_in);
String test = "Hello, world! " + toString(rand);
2017-03-25 20:12:56 +00:00
/// Write to file as usual, read with O_DIRECT.
2014-04-02 07:14:40 +00:00
{
WriteBufferFromFile wb("test1", BUF_SIZE);
for (size_t i = 0; i < N; ++i)
writeStringBinary(test, wb);
wb.next();
}
2014-01-04 04:52:22 +00:00
{
2014-04-02 07:14:40 +00:00
ReadBufferFromFile rb("test1", BUF_SIZE, O_RDONLY | O_DIRECT, nullptr, 4096);
String res;
for (size_t i = 0; i < N; ++i)
readStringBinary(res, rb);
std::cerr << "test: " << test << ", res: " << res << ", bytes: " << rb.count() << std::endl;
}
2017-03-25 20:12:56 +00:00
/// Write to file with O_DIRECT, read as usual.
2014-04-02 07:14:40 +00:00
{
WriteBufferFromFile wb("test2", BUF_SIZE, O_WRONLY | O_CREAT | O_TRUNC | O_DIRECT, 0666, nullptr, 4096);
for (size_t i = 0; i < N; ++i)
writeStringBinary(test, wb);
if (wb.offset() % 4096 != 0)
{
size_t pad = 4096 - wb.offset() % 4096;
memset(wb.position(), 0, pad);
wb.position() += pad;
}
2014-01-04 04:52:22 +00:00
wb.next();
}
{
2014-04-02 07:14:40 +00:00
ReadBufferFromFile rb("test2", BUF_SIZE);
2014-01-04 04:52:22 +00:00
String res;
2014-04-02 07:14:40 +00:00
for (size_t i = 0; i < N; ++i)
readStringBinary(res, rb);
2014-01-04 04:52:22 +00:00
2014-04-02 07:14:40 +00:00
std::cerr << "test: " << test << ", res: " << res << ", bytes: " << rb.count() << std::endl;
2014-01-04 04:52:22 +00:00
}
}
catch (const Exception & e)
{
std::cerr << e.what() << ", " << e.displayText() << std::endl;
return 1;
}
return 0;
}