2021-11-28 15:29:26 +08:00
|
|
|
// Copyright 2021, Roman Gershman. All rights reserved.
|
|
|
|
// See LICENSE for licensing terms.
|
2021-11-16 16:39:38 +08:00
|
|
|
//
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "base/varz_value.h"
|
2021-11-19 00:38:20 +08:00
|
|
|
#include "server/command_registry.h"
|
2021-11-17 18:51:47 +08:00
|
|
|
#include "server/engine_shard_set.h"
|
2021-11-19 00:38:20 +08:00
|
|
|
#include "util/http/http_handler.h"
|
2021-11-23 18:39:35 +08:00
|
|
|
#include "server/memcache_parser.h"
|
2022-01-08 06:01:35 +08:00
|
|
|
#include "server/server_family.h"
|
2021-11-16 16:39:38 +08:00
|
|
|
|
|
|
|
namespace util {
|
|
|
|
class AcceptServer;
|
|
|
|
} // namespace util
|
|
|
|
|
|
|
|
namespace dfly {
|
|
|
|
|
|
|
|
class Service {
|
|
|
|
public:
|
|
|
|
using error_code = std::error_code;
|
|
|
|
|
2022-01-03 17:20:08 +08:00
|
|
|
struct InitOpts {
|
|
|
|
bool disable_time_update;
|
|
|
|
|
|
|
|
InitOpts() : disable_time_update{false} {
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-11-16 16:39:38 +08:00
|
|
|
explicit Service(util::ProactorPool* pp);
|
|
|
|
~Service();
|
|
|
|
|
|
|
|
void RegisterHttp(util::HttpListenerBase* listener);
|
|
|
|
|
2022-01-03 17:20:08 +08:00
|
|
|
void Init(util::AcceptServer* acceptor, const InitOpts& opts = InitOpts{});
|
2021-11-16 16:39:38 +08:00
|
|
|
|
|
|
|
void Shutdown();
|
|
|
|
|
2021-11-19 00:38:20 +08:00
|
|
|
void DispatchCommand(CmdArgList args, ConnectionContext* cntx);
|
2021-11-23 18:39:35 +08:00
|
|
|
void DispatchMC(const MemcacheParser::Command& cmd, std::string_view value,
|
|
|
|
ConnectionContext* cntx);
|
2021-11-19 00:38:20 +08:00
|
|
|
|
2021-11-17 18:51:47 +08:00
|
|
|
uint32_t shard_count() const {
|
|
|
|
return shard_set_.size();
|
|
|
|
}
|
|
|
|
|
2022-01-06 21:48:51 +08:00
|
|
|
// Used by tests.
|
|
|
|
bool IsLocked(DbIndex db_index, std::string_view key) const;
|
2022-01-12 01:55:41 +08:00
|
|
|
bool IsShardSetLocked() const;
|
2022-01-06 21:48:51 +08:00
|
|
|
|
2021-11-17 18:51:47 +08:00
|
|
|
EngineShardSet& shard_set() {
|
|
|
|
return shard_set_;
|
|
|
|
}
|
|
|
|
|
2021-11-16 16:39:38 +08:00
|
|
|
util::ProactorPool& proactor_pool() {
|
|
|
|
return pp_;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2021-11-19 00:38:20 +08:00
|
|
|
|
2022-01-08 06:01:35 +08:00
|
|
|
static void Quit(CmdArgList args, ConnectionContext* cntx);
|
2022-01-06 21:48:51 +08:00
|
|
|
void Exec(CmdArgList args, ConnectionContext* cntx);
|
2022-01-08 06:01:35 +08:00
|
|
|
static void Multi(CmdArgList args, ConnectionContext* cntx);
|
2022-01-06 21:48:51 +08:00
|
|
|
|
2021-11-19 00:38:20 +08:00
|
|
|
void RegisterCommands();
|
2021-11-17 18:51:47 +08:00
|
|
|
|
2021-11-16 16:39:38 +08:00
|
|
|
base::VarzValue::Map GetVarzStats();
|
|
|
|
|
2021-11-19 00:38:20 +08:00
|
|
|
CommandRegistry registry_;
|
2021-11-17 18:51:47 +08:00
|
|
|
EngineShardSet shard_set_;
|
2021-11-16 16:39:38 +08:00
|
|
|
util::ProactorPool& pp_;
|
2022-01-08 06:01:35 +08:00
|
|
|
ServerFamily server_family_;
|
2021-11-16 16:39:38 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace dfly
|