-
Notifications
You must be signed in to change notification settings - Fork 1.2k
/
Copy pathpika_partition.h
120 lines (95 loc) · 2.7 KB
/
pika_partition.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
// Copyright (c) 2018-present, Qihoo, Inc. All rights reserved.
// This source code is licensed under the BSD-style license found in the
// LICENSE file in the root directory of this source tree. An additional grant
// of patent rights can be found in the PATENTS file in the same directory.
#ifndef PIKA_PARTITION_H_
#define PIKA_PARTITION_H_
#include <string>
#include <memory>
#include <fstream>
#include "iostream"
#include "blackwidow/blackwidow.h"
#include "blackwidow/backupable.h"
#include "include/pika_conf.h"
#include "include/pika_server.h"
#include "include/pika_binlog.h"
class Cmd;
class Binlog;
struct BGSaveInfo {
bool bgsaving;
time_t start_time;
std::string s_start_time;
std::string path;
uint32_t filenum;
uint64_t offset;
BGSaveInfo() : bgsaving(false), filenum(0), offset(0){}
void Clear() {
bgsaving = false;
path.clear();
filenum = 0;
offset = 0;
}
};
class Partition : public std::enable_shared_from_this<Partition> {
public:
Partition(const std::string& table_name,
uint32_t partition_id,
const std::string& table_db_path,
const std::string& table_log_path);
virtual ~Partition();
uint32_t partition_id() const;
std::string partition_name() const;
std::shared_ptr<Binlog> logger() const;
std::shared_ptr<blackwidow::BlackWidow> db() const;
void DoCommand(Cmd* const cmd);
void BinlogLock();
void BinlogUnLock();
void DbRWLockWriter();
void DbRWLockReader();
void DbRWUnLock();
void RecordLock(const std::string& key);
void RecordUnLock(const std::string& key);
void SetBinlogIoError(bool error);
bool IsBinlogIoError();
// BgSave use;
void BgSavePartition();
BGSaveInfo bgsave_info();
// Flushall & Flushdb use
bool FlushAll();
bool FlushDb(const std::string& db_name);
void RocksdbOptionInit(blackwidow::BlackwidowOptions* bw_option) const;
private:
std::string table_name_;
uint32_t partition_id_;
std::string db_path_;
std::string log_path_;
std::string partition_name_;
std::shared_ptr<Binlog> logger_;
std::atomic<bool> binlog_io_error_;
pthread_rwlock_t db_rwlock_;
slash::RecordMutex mutex_record_;
std::shared_ptr<blackwidow::BlackWidow> db_;
/*
* BgSave use
*/
static void DoBgSave(void* arg);
bool RunBgsaveEngine();
bool InitBgsaveEnv();
bool InitBgsaveEngine();
void ClearBgsave();
void FinishBgsave();
BGSaveInfo bgsave_info_;
slash::Mutex bgsave_protector_;
blackwidow::BackupEngine* bgsave_engine_;
/*
* Flushall & Flushdb use
*/
static void DoPurgeDir(void* arg);
void PurgeDir(std::string& path);
/*
* No allowed copy and copy assign
*/
Partition(const Partition&);
void operator=(const Partition&);
};
#endif