Files
scylladb/transport/controller.hh
Pavel Emelyanov 990db016e9 transport: Untie transport and database
Both controller and server only need database to get config from.
Since controller creation only happens in main() code which has the
config itself, we may remove database mentioning from transport.

Previous attempt was not to carry the config down to the server
level, but it stepped on an updateable_value landmine -- the u._v.
isn't copyable cross-shard (despite the docs) and to properly
initialize server's max_concurrent_requests we need the config's
named_value member itself.

The db::config that flies through the stack is const reference, but
its named_values do not get copied along the way -- the updateable
value accepts both references and const references to subscribe on.

tests: start-stop in debug mode

Signed-off-by: Pavel Emelyanov <xemul@scylladb.com>
Message-Id: <20210607135656.18522-1-xemul@scylladb.com>
2021-06-09 20:04:12 +03:00

71 lines
2.2 KiB
C++

/*
* Copyright (C) 2020-present ScyllaDB
*/
/*
* This file is part of Scylla.
*
* Scylla is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Scylla 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 Scylla. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include <seastar/core/semaphore.hh>
#include <seastar/core/distributed.hh>
#include <seastar/core/future.hh>
using namespace seastar;
namespace cql_transport { class cql_server; }
namespace auth { class service; }
namespace service {
class migration_notifier;
class memory_limiter;
}
namespace gms { class gossiper; }
namespace cql3 { class query_processor; }
namespace qos { class service_level_controller; }
namespace db { class config; }
namespace cql_transport {
class controller {
std::unique_ptr<distributed<cql_transport::cql_server>> _server;
semaphore _ops_sem; /* protects start/stop operations on _server */
bool _stopped = false;
sharded<auth::service>& _auth_service;
sharded<service::migration_notifier>& _mnotifier;
gms::gossiper& _gossiper;
sharded<cql3::query_processor>& _qp;
sharded<service::memory_limiter>& _mem_limiter;
sharded<qos::service_level_controller>& _sl_controller;
const db::config& _config;
future<> set_cql_ready(bool ready);
future<> do_start_server();
future<> do_stop_server();
public:
controller(sharded<auth::service>&, sharded<service::migration_notifier>&, gms::gossiper&,
sharded<cql3::query_processor>&, sharded<service::memory_limiter>&,
sharded<qos::service_level_controller>&, const db::config& cfg);
future<> start_server();
future<> stop_server();
future<> stop();
future<bool> is_server_running();
};
} // namespace cql_transport