Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Service config parser to core configuration #28883

Merged
merged 28 commits into from
Feb 24, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
90cae9c
Service config parser to core configuration
ctiller Feb 15, 2022
8acedaa
x
ctiller Feb 15, 2022
9fe96bb
Automated change: Fix sanity tests
ctiller Feb 15, 2022
08d27ef
Merge pull request #444 from ctiller/create-pull-request/patch-8aceda…
ctiller Feb 15, 2022
f5189dd
Merge github.com:grpc/grpc into parserconfig
ctiller Feb 15, 2022
7c0be93
finish
ctiller Feb 15, 2022
7e0911b
Automated change: Fix sanity tests
ctiller Feb 15, 2022
2793e49
oops
ctiller Feb 15, 2022
da08716
fix race
ctiller Feb 15, 2022
bc429b8
Automated change: Fix sanity tests
ctiller Feb 15, 2022
807c260
Merge pull request #450 from ctiller/create-pull-request/patch-da0871…
ctiller Feb 15, 2022
8dca475
Merge pull request #446 from ctiller/create-pull-request/patch-7c0be9…
ctiller Feb 16, 2022
bb72aa9
Merge github.com:grpc/grpc into parserconfig
ctiller Feb 16, 2022
b9ab1c8
Merge github.com:grpc/grpc into parserconfig
ctiller Feb 22, 2022
033ddf0
Merge github.com:grpc/grpc into parserconfig
ctiller Feb 22, 2022
1abfebc
back out mutex
ctiller Feb 22, 2022
c150254
refactor
ctiller Feb 23, 2022
71d24af
optimize
ctiller Feb 23, 2022
98cfe19
Automated change: Fix sanity tests
ctiller Feb 23, 2022
964e475
Merge pull request #461 from ctiller/create-pull-request/patch-71d24a…
ctiller Feb 23, 2022
33238cb
fix
ctiller Feb 23, 2022
e8783a1
Merge branch 'parserconfig' of github.com:ctiller/grpc into parserconfig
ctiller Feb 23, 2022
707ce1b
fix
ctiller Feb 23, 2022
a532e21
Merge github.com:grpc/grpc into parserconfig
ctiller Feb 23, 2022
5d1055e
split out interface
ctiller Feb 23, 2022
d79852c
review feedback
ctiller Feb 23, 2022
934a9f8
x
ctiller Feb 23, 2022
cbe78b7
fixes
ctiller Feb 24, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
55 changes: 50 additions & 5 deletions BUILD
Original file line number Diff line number Diff line change
Expand Up @@ -978,6 +978,7 @@ grpc_cc_library(
"gpr_base",
"grpc_resolver",
"handshaker_registry",
"service_config_parser",
],
)

Expand Down Expand Up @@ -2236,25 +2237,62 @@ grpc_cc_library(

grpc_cc_library(
name = "grpc_service_config",
hdrs = [
"src/core/lib/service_config/service_config.h",
"src/core/lib/service_config/service_config_call_data.h",
],
external_deps = [
"absl/strings",
],
language = "c++",
deps = [
"error",
"gpr_base",
"json",
"service_config_parser",
"slice",
],
)

grpc_cc_library(
name = "grpc_service_config_impl",
srcs = [
"src/core/lib/service_config/service_config_impl.cc",
],
hdrs = [
"src/core/lib/service_config/service_config_impl.h",
],
external_deps = [
"absl/strings",
],
language = "c++",
deps = [
"config",
"error",
"gpr_base",
"grpc_service_config",
"json",
"service_config_parser",
"slice",
],
)

grpc_cc_library(
name = "service_config_parser",
srcs = [
"src/core/lib/service_config/service_config.cc",
"src/core/lib/service_config/service_config_parser.cc",
],
hdrs = [
"src/core/lib/service_config/service_config.h",
"src/core/lib/service_config/service_config_call_data.h",
"src/core/lib/service_config/service_config_parser.h",
],
external_deps = [
"absl/container:inlined_vector",
"absl/strings",
],
language = "c++",
deps = [
"error",
"gpr_base",
"json",
"slice",
],
)

Expand Down Expand Up @@ -2415,6 +2453,7 @@ grpc_cc_library(
"grpc_health_upb",
"grpc_resolver",
"grpc_service_config",
"grpc_service_config_impl",
"grpc_trace",
"handshaker_registry",
"httpcli",
Expand Down Expand Up @@ -2745,6 +2784,7 @@ grpc_cc_library(
"grpc_fake_credentials",
"grpc_resolver",
"grpc_security_base",
"grpc_service_config_impl",
"json",
"json_util",
"orphanable",
Expand Down Expand Up @@ -2919,6 +2959,7 @@ grpc_cc_library(
"grpc_base",
"grpc_server_config_selector",
"grpc_server_config_selector_filter",
"grpc_service_config_impl",
"grpc_sockaddr",
"grpc_xds_channel_stack_modifier",
"grpc_xds_client",
Expand Down Expand Up @@ -3419,6 +3460,7 @@ grpc_cc_library(
"grpc_resolver",
"grpc_resolver_dns_selection",
"grpc_service_config",
"grpc_service_config_impl",
"grpc_sockaddr",
"iomgr_port",
"json",
Expand Down Expand Up @@ -3515,6 +3557,7 @@ grpc_cc_library(
"grpc_client_channel",
"grpc_lb_policy_ring_hash",
"grpc_resolver",
"grpc_service_config_impl",
"grpc_xds_client",
],
)
Expand Down Expand Up @@ -4609,6 +4652,7 @@ grpc_cc_library(
"grpc_codegen",
"grpc_health_upb",
"grpc_service_config",
"grpc_service_config_impl",
"grpc_trace",
"grpc_transport_inproc",
"ref_counted",
Expand Down Expand Up @@ -4641,6 +4685,7 @@ grpc_cc_library(
"grpc_health_upb",
"grpc_insecure_credentials",
"grpc_service_config",
"grpc_service_config_impl",
"grpc_trace",
"grpc_transport_inproc",
"grpc_unsecure",
Expand Down
4 changes: 2 additions & 2 deletions CMakeLists.txt

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions Makefile

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 4 additions & 2 deletions build_autogenerated.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion config.m4

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion config.w32

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions gRPC-C++.podspec

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 3 additions & 1 deletion gRPC-Core.podspec

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion grpc.gemspec

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions grpc.gyp

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion package.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

24 changes: 12 additions & 12 deletions src/core/ext/filters/client_channel/client_channel.cc
Original file line number Diff line number Diff line change
Expand Up @@ -63,8 +63,8 @@
#include "src/core/lib/iomgr/work_serializer.h"
#include "src/core/lib/profiling/timers.h"
#include "src/core/lib/resolver/resolver_registry.h"
#include "src/core/lib/service_config/service_config.h"
#include "src/core/lib/service_config/service_config_call_data.h"
#include "src/core/lib/service_config/service_config_impl.h"
#include "src/core/lib/slice/slice_internal.h"
#include "src/core/lib/slice/slice_string_helpers.h"
#include "src/core/lib/surface/channel.h"
Expand Down Expand Up @@ -1036,6 +1036,8 @@ ClientChannel::ClientChannel(grpc_channel_element_args* args,
ClientChannelFactory::GetFromChannelArgs(args->channel_args)),
channelz_node_(GetChannelzNode(args->channel_args)),
interested_parties_(grpc_pollset_set_create()),
service_config_parser_index_(
internal::ClientChannelServiceConfigParser::ParserIndex()),
work_serializer_(std::make_shared<WorkSerializer>()),
state_tracker_("client_channel", GRPC_CHANNEL_IDLE),
subchannel_pool_(GetSubchannelPool(args->channel_args)) {
Expand All @@ -1058,7 +1060,7 @@ ClientChannel::ClientChannel(grpc_channel_element_args* args,
if (service_config_json == nullptr) service_config_json = "{}";
*error = GRPC_ERROR_NONE;
default_service_config_ =
ServiceConfig::Create(args->channel_args, service_config_json, error);
ServiceConfigImpl::Create(args->channel_args, service_config_json, error);
if (*error != GRPC_ERROR_NONE) {
default_service_config_.reset();
return;
Expand Down Expand Up @@ -1278,7 +1280,7 @@ void ClientChannel::OnResolverResultChangedLocked(Resolver::Result result) {
const internal::ClientChannelGlobalParsedConfig* parsed_service_config =
static_cast<const internal::ClientChannelGlobalParsedConfig*>(
service_config->GetGlobalParsedConfig(
internal::ClientChannelServiceConfigParser::ParserIndex()));
service_config_parser_index_));
// Choose LB policy config.
RefCountedPtr<LoadBalancingPolicy::Config> lb_policy_config =
ChooseLbPolicy(result, parsed_service_config);
Expand Down Expand Up @@ -1438,21 +1440,19 @@ void ClientChannel::RemoveResolverQueuedCall(ResolverQueuedCall* to_remove,

void ClientChannel::UpdateServiceConfigInControlPlaneLocked(
RefCountedPtr<ServiceConfig> service_config,
RefCountedPtr<ConfigSelector> config_selector, const char* lb_policy_name) {
UniquePtr<char> service_config_json(
gpr_strdup(service_config->json_string().c_str()));
RefCountedPtr<ConfigSelector> config_selector, std::string lb_policy_name) {
std::string service_config_json(service_config->json_string());
if (GRPC_TRACE_FLAG_ENABLED(grpc_client_channel_routing_trace)) {
gpr_log(GPR_INFO,
"chand=%p: resolver returned updated service config: \"%s\"", this,
service_config_json.get());
service_config_json.c_str());
}
// Save service config.
saved_service_config_ = std::move(service_config);
// Swap out the data used by GetChannelInfo().
UniquePtr<char> lb_policy_name_owned(gpr_strdup(lb_policy_name));
{
MutexLock lock(&info_mu_);
info_lb_policy_name_ = std::move(lb_policy_name_owned);
info_lb_policy_name_ = std::move(lb_policy_name);
info_service_config_json_ = std::move(service_config_json);
}
// Save config selector.
Expand Down Expand Up @@ -1784,11 +1784,11 @@ void ClientChannel::GetChannelInfo(grpc_channel_element* elem,
ClientChannel* chand = static_cast<ClientChannel*>(elem->channel_data);
MutexLock lock(&chand->info_mu_);
if (info->lb_policy_name != nullptr) {
*info->lb_policy_name = gpr_strdup(chand->info_lb_policy_name_.get());
*info->lb_policy_name = gpr_strdup(chand->info_lb_policy_name_.c_str());
}
if (info->service_config_json != nullptr) {
*info->service_config_json =
gpr_strdup(chand->info_service_config_json_.get());
gpr_strdup(chand->info_service_config_json_.c_str());
}
}

Expand Down Expand Up @@ -2223,7 +2223,7 @@ grpc_error_handle ClientChannel::CallData::ApplyServiceConfigToCallLocked(
// Apply our own method params to the call.
auto* method_params = static_cast<ClientChannelMethodParsedConfig*>(
service_config_call_data->GetMethodParsedConfig(
internal::ClientChannelServiceConfigParser::ParserIndex()));
chand->service_config_parser_index_));
if (method_params != nullptr) {
// If the deadline from the service config is shorter than the one
// from the client API, reset the deadline timer.
Expand Down
Loading