grpc 1.66.0 → 1.67.0.pre1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Makefile +19 -10
- data/include/grpc/credentials.h +1 -1
- data/include/grpc/event_engine/README.md +1 -1
- data/include/grpc/event_engine/internal/slice_cast.h +1 -1
- data/include/grpc/event_engine/slice.h +0 -1
- data/include/grpc/event_engine/slice_buffer.h +0 -1
- data/include/grpc/grpc_crl_provider.h +1 -1
- data/include/grpc/impl/channel_arg_names.h +1 -1
- data/include/grpc/support/log.h +34 -32
- data/include/grpc/support/sync_generic.h +2 -4
- data/src/core/channelz/channelz.cc +0 -1
- data/src/core/channelz/channelz_registry.cc +0 -1
- data/src/core/client_channel/client_channel.cc +10 -7
- data/src/core/client_channel/client_channel.h +1 -1
- data/src/core/client_channel/client_channel_filter.cc +21 -18
- data/src/core/client_channel/client_channel_filter.h +1 -1
- data/src/core/client_channel/client_channel_internal.h +0 -2
- data/src/core/client_channel/config_selector.h +0 -1
- data/src/core/client_channel/dynamic_filters.cc +0 -2
- data/src/core/client_channel/local_subchannel_pool.cc +0 -2
- data/src/core/client_channel/retry_filter.h +0 -1
- data/src/core/client_channel/retry_filter_legacy_call_data.cc +175 -257
- data/src/core/client_channel/subchannel.cc +21 -27
- data/src/core/client_channel/subchannel_stream_client.cc +1 -1
- data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +8 -9
- data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.cc +0 -1
- data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +3 -4
- data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.cc +167 -0
- data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.h +82 -0
- data/src/core/ext/filters/gcp_authentication/gcp_authentication_service_config_parser.cc +81 -0
- data/src/core/ext/filters/gcp_authentication/gcp_authentication_service_config_parser.h +87 -0
- data/src/core/ext/filters/http/message_compress/compression_filter.cc +7 -9
- data/src/core/ext/filters/http/server/http_server_filter.cc +2 -4
- data/src/core/ext/filters/message_size/message_size_filter.cc +6 -7
- data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +0 -2
- data/src/core/ext/transport/chttp2/alpn/alpn.cc +0 -1
- data/src/core/ext/transport/chttp2/server/chttp2_server.cc +6 -8
- data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +0 -1
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +288 -265
- data/src/core/ext/transport/chttp2/transport/flow_control.cc +3 -4
- data/src/core/ext/transport/chttp2/transport/flow_control.h +0 -1
- data/src/core/ext/transport/chttp2/transport/frame.cc +0 -1
- data/src/core/ext/transport/chttp2/transport/frame_data.cc +0 -1
- data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +0 -1
- data/src/core/ext/transport/chttp2/transport/frame_ping.cc +6 -6
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +3 -4
- data/src/core/ext/transport/chttp2/transport/frame_settings.cc +5 -6
- data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +0 -1
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +2 -3
- data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +0 -1
- data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +0 -1
- data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +3 -3
- data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +37 -5
- data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +27 -6
- data/src/core/ext/transport/chttp2/transport/internal.h +2 -3
- data/src/core/ext/transport/chttp2/transport/parsing.cc +21 -32
- data/src/core/ext/transport/chttp2/transport/ping_callbacks.cc +0 -1
- data/src/core/ext/transport/chttp2/transport/stream_lists.cc +6 -8
- data/src/core/ext/transport/chttp2/transport/varint.h +0 -1
- data/src/core/ext/transport/chttp2/transport/write_size_policy.cc +0 -1
- data/src/core/ext/transport/chttp2/transport/writing.cc +22 -22
- data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb.h +431 -0
- data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb_minitable.c +129 -0
- data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb_minitable.h +33 -0
- data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb.h +16 -0
- data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb_minitable.c +13 -2
- data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb.h +397 -22
- data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.c +94 -20
- data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.h +2 -0
- data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.c +86 -0
- data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.h +47 -0
- data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.c +108 -107
- data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.c +101 -78
- data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.h +10 -0
- data/src/core/handshaker/handshaker.cc +21 -29
- data/src/core/handshaker/security/secure_endpoint.cc +3 -3
- data/src/core/handshaker/security/security_handshaker.cc +60 -72
- data/src/core/handshaker/tcp_connect/tcp_connect_handshaker.cc +0 -1
- data/src/core/lib/backoff/backoff.cc +7 -10
- data/src/core/lib/backoff/backoff.h +4 -6
- data/src/core/lib/channel/channel_stack.cc +0 -1
- data/src/core/lib/channel/channel_stack.h +0 -1
- data/src/core/lib/channel/channel_stack_builder_impl.cc +0 -1
- data/src/core/lib/channel/connected_channel.cc +0 -1
- data/src/core/lib/channel/promise_based_filter.cc +146 -194
- data/src/core/lib/channel/promise_based_filter.h +1 -1
- data/src/core/lib/compression/compression_internal.cc +0 -1
- data/src/core/lib/config/config_vars.cc +11 -1
- data/src/core/lib/config/config_vars.h +8 -0
- data/src/core/lib/config/core_configuration.cc +0 -1
- data/src/core/lib/config/core_configuration.h +0 -1
- data/src/core/lib/debug/event_log.cc +0 -1
- data/src/core/lib/debug/trace_flags.cc +4 -18
- data/src/core/lib/debug/trace_flags.h +2 -5
- data/src/core/lib/debug/trace_impl.h +6 -0
- data/src/core/lib/event_engine/ares_resolver.cc +89 -56
- data/src/core/lib/event_engine/ares_resolver.h +0 -9
- data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +14 -1
- data/src/core/lib/event_engine/cf_engine/cftype_unique_ref.h +1 -1
- data/src/core/lib/event_engine/forkable.cc +0 -1
- data/src/core/lib/event_engine/forkable.h +0 -1
- data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +1 -1
- data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +4 -4
- data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +0 -1
- data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +0 -1
- data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +9 -1
- data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +0 -1
- data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +2 -2
- data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +1 -2
- data/src/core/lib/event_engine/posix_engine/timer_manager.cc +4 -9
- data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +0 -1
- data/src/core/lib/event_engine/resolved_address.cc +0 -1
- data/src/core/lib/event_engine/slice.cc +0 -1
- data/src/core/lib/event_engine/thread_pool/thread_count.cc +0 -1
- data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +3 -5
- data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.cc +121 -93
- data/src/core/lib/experiments/config.cc +12 -10
- data/src/core/lib/experiments/experiments.cc +45 -66
- data/src/core/lib/experiments/experiments.h +22 -27
- data/src/core/lib/gprpp/chunked_vector.h +0 -1
- data/src/core/lib/gprpp/down_cast.h +0 -1
- data/src/core/lib/gprpp/host_port.cc +0 -1
- data/src/core/lib/gprpp/load_file.cc +0 -1
- data/src/core/lib/gprpp/mpscq.h +0 -1
- data/src/core/lib/gprpp/single_set_ptr.h +0 -1
- data/src/core/lib/gprpp/status_helper.cc +0 -1
- data/src/core/lib/gprpp/sync.h +0 -1
- data/src/core/lib/gprpp/table.h +28 -0
- data/src/core/lib/gprpp/thd.h +0 -1
- data/src/core/lib/gprpp/time.h +0 -1
- data/src/core/lib/gprpp/time_util.cc +0 -1
- data/src/core/lib/gprpp/windows/directory_reader.cc +0 -2
- data/src/core/lib/gprpp/windows/thd.cc +0 -1
- data/src/core/lib/gprpp/work_serializer.cc +23 -34
- data/src/core/lib/iomgr/buffer_list.cc +0 -1
- data/src/core/lib/iomgr/call_combiner.h +6 -8
- data/src/core/lib/iomgr/cfstream_handle.cc +6 -8
- data/src/core/lib/iomgr/closure.h +5 -8
- data/src/core/lib/iomgr/combiner.cc +6 -8
- data/src/core/lib/iomgr/endpoint_cfstream.cc +17 -22
- data/src/core/lib/iomgr/endpoint_pair_posix.cc +0 -1
- data/src/core/lib/iomgr/error.h +0 -1
- data/src/core/lib/iomgr/ev_apple.cc +13 -18
- data/src/core/lib/iomgr/ev_epoll1_linux.cc +47 -85
- data/src/core/lib/iomgr/ev_poll_posix.cc +17 -24
- data/src/core/lib/iomgr/ev_posix.cc +55 -44
- data/src/core/lib/iomgr/ev_posix.h +0 -5
- data/src/core/lib/iomgr/event_engine_shims/closure.cc +7 -9
- data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +3 -4
- data/src/core/lib/iomgr/exec_ctx.cc +6 -9
- data/src/core/lib/iomgr/exec_ctx.h +26 -16
- data/src/core/lib/iomgr/executor.cc +43 -33
- data/src/core/lib/iomgr/fork_windows.cc +0 -1
- data/src/core/lib/iomgr/internal_errqueue.cc +0 -1
- data/src/core/lib/iomgr/iocp_windows.cc +0 -1
- data/src/core/lib/iomgr/iomgr_windows.cc +0 -2
- data/src/core/lib/iomgr/lockfree_event.cc +7 -11
- data/src/core/lib/iomgr/polling_entity.cc +10 -3
- data/src/core/lib/iomgr/pollset_windows.cc +0 -2
- data/src/core/lib/iomgr/resolve_address.cc +0 -1
- data/src/core/lib/iomgr/resolve_address_posix.cc +0 -1
- data/src/core/lib/iomgr/resolve_address_windows.cc +0 -1
- data/src/core/lib/iomgr/sockaddr_utils_posix.cc +0 -1
- data/src/core/lib/iomgr/socket_mutator.cc +0 -1
- data/src/core/lib/iomgr/socket_utils_linux.cc +0 -2
- data/src/core/lib/iomgr/socket_utils_posix.cc +0 -1
- data/src/core/lib/iomgr/socket_utils_windows.cc +0 -2
- data/src/core/lib/iomgr/tcp_client_cfstream.cc +7 -12
- data/src/core/lib/iomgr/tcp_client_posix.cc +8 -12
- data/src/core/lib/iomgr/tcp_client_windows.cc +0 -1
- data/src/core/lib/iomgr/tcp_posix.cc +32 -68
- data/src/core/lib/iomgr/tcp_server_posix.cc +7 -11
- data/src/core/lib/iomgr/tcp_windows.cc +4 -12
- data/src/core/lib/iomgr/timer_generic.cc +46 -65
- data/src/core/lib/iomgr/timer_manager.cc +4 -5
- data/src/core/lib/iomgr/unix_sockets_posix.cc +0 -1
- data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +0 -2
- data/src/core/lib/iomgr/vsock.cc +0 -1
- data/src/core/lib/iomgr/wakeup_fd_eventfd.cc +0 -2
- data/src/core/lib/promise/activity.h +0 -1
- data/src/core/lib/promise/context.h +0 -1
- data/src/core/lib/promise/detail/join_state.h +44 -44
- data/src/core/lib/promise/detail/seq_state.h +1101 -1356
- data/src/core/lib/promise/for_each.h +8 -15
- data/src/core/lib/promise/interceptor_list.h +17 -27
- data/src/core/lib/promise/latch.h +16 -24
- data/src/core/lib/promise/map.h +1 -1
- data/src/core/lib/promise/party.cc +238 -114
- data/src/core/lib/promise/party.h +105 -308
- data/src/core/lib/promise/pipe.h +3 -4
- data/src/core/lib/promise/poll.h +0 -1
- data/src/core/lib/promise/status_flag.h +0 -1
- data/src/core/lib/resource_quota/connection_quota.cc +0 -1
- data/src/core/lib/resource_quota/memory_quota.cc +11 -19
- data/src/core/lib/resource_quota/memory_quota.h +2 -4
- data/src/core/lib/resource_quota/periodic_update.cc +2 -3
- data/src/core/lib/resource_quota/thread_quota.cc +0 -1
- data/src/core/lib/security/authorization/audit_logging.cc +0 -1
- data/src/core/lib/security/authorization/grpc_authorization_engine.cc +0 -1
- data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +14 -19
- data/src/core/lib/security/authorization/stdout_logger.cc +0 -1
- data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +0 -1
- data/src/core/lib/security/credentials/alts/check_gcp_environment_windows.cc +0 -1
- data/src/core/lib/security/credentials/call_creds_util.cc +0 -1
- data/src/core/lib/security/credentials/composite/composite_credentials.cc +0 -1
- data/src/core/lib/security/credentials/composite/composite_credentials.h +2 -0
- data/src/core/lib/security/credentials/credentials.h +1 -2
- data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +322 -324
- data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +53 -42
- data/src/core/lib/security/credentials/external/external_account_credentials.cc +391 -353
- data/src/core/lib/security/credentials/external/external_account_credentials.h +121 -51
- data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +83 -44
- data/src/core/lib/security/credentials/external/file_external_account_credentials.h +27 -7
- data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +91 -116
- data/src/core/lib/security/credentials/external/url_external_account_credentials.h +14 -17
- data/src/core/lib/security/credentials/fake/fake_credentials.h +2 -0
- data/src/core/lib/security/credentials/gcp_service_account_identity/gcp_service_account_identity_credentials.cc +196 -0
- data/src/core/lib/security/credentials/gcp_service_account_identity/gcp_service_account_identity_credentials.h +90 -0
- data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +27 -41
- data/src/core/lib/security/credentials/iam/iam_credentials.cc +0 -1
- data/src/core/lib/security/credentials/iam/iam_credentials.h +2 -0
- data/src/core/lib/security/credentials/jwt/jwt_credentials.h +2 -0
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +163 -259
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +34 -56
- data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +12 -16
- data/src/core/lib/security/credentials/plugin/plugin_credentials.h +2 -0
- data/src/core/lib/security/credentials/ssl/ssl_credentials.h +0 -1
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +0 -1
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +0 -1
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +0 -1
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +0 -1
- data/src/core/lib/security/credentials/token_fetcher/token_fetcher_credentials.cc +298 -0
- data/src/core/lib/security/credentials/token_fetcher/token_fetcher_credentials.h +176 -0
- data/src/core/lib/security/credentials/xds/xds_credentials.cc +0 -1
- data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +0 -1
- data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +0 -1
- data/src/core/lib/security/security_connector/load_system_roots_windows.cc +0 -1
- data/src/core/lib/security/transport/server_auth_filter.cc +4 -6
- data/src/core/lib/slice/percent_encoding.cc +0 -1
- data/src/core/lib/slice/slice.cc +0 -1
- data/src/core/lib/slice/slice.h +0 -1
- data/src/core/lib/slice/slice_buffer.cc +0 -1
- data/src/core/lib/slice/slice_internal.h +0 -1
- data/src/core/lib/slice/slice_refcount.h +6 -8
- data/src/core/lib/surface/byte_buffer_reader.cc +0 -1
- data/src/core/lib/surface/call.cc +3 -5
- data/src/core/lib/surface/call_utils.h +0 -1
- data/src/core/lib/surface/channel.cc +0 -1
- data/src/core/lib/surface/channel_create.cc +0 -1
- data/src/core/lib/surface/channel_init.h +0 -1
- data/src/core/lib/surface/client_call.cc +0 -1
- data/src/core/lib/surface/client_call.h +0 -1
- data/src/core/lib/surface/completion_queue.cc +28 -4
- data/src/core/lib/surface/completion_queue_factory.cc +0 -1
- data/src/core/lib/surface/filter_stack_call.cc +9 -9
- data/src/core/lib/surface/filter_stack_call.h +0 -1
- data/src/core/lib/surface/lame_client.cc +0 -1
- data/src/core/lib/surface/server_call.cc +0 -1
- data/src/core/lib/surface/server_call.h +0 -1
- data/src/core/lib/surface/validate_metadata.h +0 -1
- data/src/core/lib/surface/version.cc +2 -2
- data/src/core/lib/transport/bdp_estimator.cc +9 -12
- data/src/core/lib/transport/bdp_estimator.h +6 -8
- data/src/core/lib/transport/call_arena_allocator.cc +2 -16
- data/src/core/lib/transport/call_arena_allocator.h +20 -5
- data/src/core/lib/transport/call_filters.cc +6 -9
- data/src/core/lib/transport/call_spine.h +24 -13
- data/src/core/lib/transport/connectivity_state.cc +34 -42
- data/src/core/lib/transport/metadata_batch.h +41 -1
- data/src/core/lib/transport/timeout_encoding.cc +0 -1
- data/src/core/lib/transport/transport.h +6 -8
- data/src/core/lib/transport/transport_op_string.cc +0 -1
- data/src/core/lib/uri/uri_parser.cc +0 -1
- data/src/core/load_balancing/grpclb/grpclb.cc +55 -71
- data/src/core/load_balancing/health_check_client.cc +31 -42
- data/src/core/load_balancing/oob_backend_metric.cc +2 -4
- data/src/core/load_balancing/outlier_detection/outlier_detection.cc +99 -129
- data/src/core/load_balancing/pick_first/pick_first.cc +168 -228
- data/src/core/load_balancing/priority/priority.cc +77 -106
- data/src/core/load_balancing/ring_hash/ring_hash.cc +32 -46
- data/src/core/load_balancing/rls/rls.cc +142 -187
- data/src/core/load_balancing/round_robin/round_robin.cc +36 -55
- data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.cc +0 -1
- data/src/core/load_balancing/weighted_round_robin/weighted_round_robin.cc +85 -110
- data/src/core/load_balancing/weighted_target/weighted_target.cc +52 -75
- data/src/core/load_balancing/xds/cds.cc +26 -43
- data/src/core/load_balancing/xds/xds_cluster_impl.cc +57 -54
- data/src/core/load_balancing/xds/xds_cluster_manager.cc +36 -50
- data/src/core/load_balancing/xds/xds_override_host.cc +95 -131
- data/src/core/load_balancing/xds/xds_wrr_locality.cc +15 -23
- data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +3 -0
- data/src/core/resolver/binder/binder_resolver.cc +0 -2
- data/src/core/resolver/dns/c_ares/dns_resolver_ares.cc +62 -44
- data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +0 -2
- data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +110 -89
- data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.cc +132 -96
- data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.h +0 -7
- data/src/core/resolver/dns/dns_resolver_plugin.cc +0 -1
- data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +40 -39
- data/src/core/resolver/dns/native/dns_resolver.cc +8 -14
- data/src/core/resolver/endpoint_addresses.cc +0 -1
- data/src/core/resolver/fake/fake_resolver.cc +0 -1
- data/src/core/resolver/polling_resolver.cc +6 -15
- data/src/core/resolver/polling_resolver.h +1 -1
- data/src/core/resolver/xds/xds_config.cc +96 -0
- data/src/core/resolver/xds/xds_config.h +109 -0
- data/src/core/resolver/xds/xds_dependency_manager.cc +59 -154
- data/src/core/resolver/xds/xds_dependency_manager.h +1 -69
- data/src/core/resolver/xds/xds_resolver.cc +51 -55
- data/src/core/server/server.cc +2 -2
- data/src/core/server/server_config_selector_filter.cc +0 -1
- data/src/core/server/xds_server_config_fetcher.cc +4 -6
- data/src/core/service_config/service_config_call_data.h +2 -3
- data/src/core/service_config/service_config_channel_arg_filter.cc +0 -1
- data/src/core/service_config/service_config_impl.h +0 -1
- data/src/core/telemetry/call_tracer.cc +0 -1
- data/src/core/telemetry/metrics.h +0 -1
- data/src/core/telemetry/stats_data.cc +67 -0
- data/src/core/telemetry/stats_data.h +48 -0
- data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +0 -1
- data/src/core/tsi/alts/handshaker/transport_security_common_api.h +0 -1
- data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +0 -1
- data/src/core/tsi/fake_transport_security.cc +6 -5
- data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +0 -1
- data/src/core/util/alloc.cc +0 -1
- data/src/core/util/gcp_metadata_query.cc +0 -1
- data/src/core/util/http_client/httpcli.cc +12 -15
- data/src/core/util/http_client/httpcli.h +16 -11
- data/src/core/util/http_client/parser.cc +3 -4
- data/src/core/util/json/json_reader.cc +0 -1
- data/src/core/util/latent_see.cc +29 -9
- data/src/core/util/latent_see.h +122 -27
- data/src/core/util/log.cc +36 -55
- data/src/core/util/lru_cache.h +104 -0
- data/src/core/util/msys/tmpfile.cc +0 -1
- data/src/core/util/posix/sync.cc +0 -1
- data/src/core/util/posix/time.cc +0 -1
- data/src/core/util/ring_buffer.h +123 -0
- data/src/core/util/spinlock.h +1 -2
- data/src/core/util/string.cc +7 -7
- data/src/core/util/sync.cc +0 -1
- data/src/core/util/sync_abseil.cc +0 -1
- data/src/core/util/time.cc +0 -1
- data/src/core/util/unique_ptr_with_bitset.h +86 -0
- data/src/core/util/useful.h +0 -24
- data/src/core/util/windows/cpu.cc +0 -1
- data/src/core/util/windows/sync.cc +0 -1
- data/src/core/util/windows/time.cc +0 -1
- data/src/core/util/windows/tmpfile.cc +0 -1
- data/src/core/xds/grpc/xds_bootstrap_grpc.cc +0 -32
- data/src/core/xds/grpc/xds_bootstrap_grpc.h +0 -5
- data/src/core/xds/grpc/xds_certificate_provider.cc +0 -1
- data/src/core/xds/grpc/xds_client_grpc.cc +11 -16
- data/src/core/xds/grpc/xds_cluster.cc +2 -8
- data/src/core/xds/grpc/xds_cluster.h +4 -4
- data/src/core/xds/grpc/xds_cluster_parser.cc +58 -96
- data/src/core/xds/grpc/xds_cluster_specifier_plugin.cc +0 -1
- data/src/core/xds/grpc/xds_common_types_parser.cc +4 -4
- data/src/core/xds/grpc/xds_common_types_parser.h +17 -0
- data/src/core/xds/grpc/xds_endpoint_parser.cc +14 -14
- data/src/core/xds/grpc/xds_http_fault_filter.cc +15 -6
- data/src/core/xds/grpc/xds_http_fault_filter.h +5 -1
- data/src/core/xds/grpc/xds_http_filter.h +11 -1
- data/src/core/xds/grpc/xds_http_filter_registry.cc +7 -1
- data/src/core/xds/grpc/xds_http_filter_registry.h +8 -1
- data/src/core/xds/grpc/xds_http_gcp_authn_filter.cc +142 -0
- data/src/core/xds/grpc/xds_http_gcp_authn_filter.h +61 -0
- data/src/core/xds/grpc/xds_http_rbac_filter.cc +14 -6
- data/src/core/xds/grpc/xds_http_rbac_filter.h +5 -1
- data/src/core/xds/grpc/xds_http_stateful_session_filter.cc +9 -1
- data/src/core/xds/grpc/xds_http_stateful_session_filter.h +5 -1
- data/src/core/xds/grpc/xds_lb_policy_registry.cc +14 -16
- data/src/core/xds/grpc/xds_listener_parser.cc +10 -11
- data/src/core/xds/grpc/xds_metadata.cc +62 -0
- data/src/core/xds/grpc/xds_metadata.h +127 -0
- data/src/core/xds/grpc/xds_metadata_parser.cc +143 -0
- data/src/core/xds/grpc/xds_metadata_parser.h +36 -0
- data/src/core/xds/grpc/xds_route_config_parser.cc +12 -17
- data/src/core/xds/grpc/xds_routing.cc +57 -22
- data/src/core/xds/grpc/xds_routing.h +10 -2
- data/src/core/xds/grpc/xds_transport_grpc.cc +0 -1
- data/src/core/xds/xds_client/xds_client.cc +124 -165
- data/src/core/xds/xds_client/xds_client_stats.cc +20 -27
- data/src/ruby/ext/grpc/rb_call.c +1 -1
- data/src/ruby/ext/grpc/rb_call_credentials.c +34 -27
- data/src/ruby/ext/grpc/rb_channel.c +22 -16
- data/src/ruby/ext/grpc/rb_event_thread.c +3 -2
- data/src/ruby/ext/grpc/rb_grpc.c +9 -8
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +6 -10
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +9 -15
- data/src/ruby/ext/grpc/rb_server.c +10 -8
- data/src/ruby/lib/grpc/generic/active_call.rb +8 -5
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/spec/call_spec.rb +53 -40
- data/src/ruby/spec/channel_spec.rb +4 -2
- data/src/ruby/spec/client_server_spec.rb +148 -507
- data/src/ruby/spec/generic/active_call_spec.rb +64 -86
- data/src/ruby/spec/support/services.rb +3 -0
- data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/rand/fork_detect.h → bcm_support.h} +51 -6
- data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/internal.h +43 -0
- data/third_party/boringssl-with-bazel/src/crypto/cpu_intel.c +72 -23
- data/third_party/boringssl-with-bazel/src/crypto/crypto.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/ecdsa_extra/ecdsa_asn1.c +160 -14
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +2 -0
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +79 -78
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm_interface.h +89 -0
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{div.c → div.c.inc} +146 -179
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{random.c → random.c.inc} +6 -8
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{sqrt.c → sqrt.c.inc} +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/{e_aes.c → e_aes.c.inc} +9 -8
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{ec_key.c → ec_key.c.inc} +11 -7
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p256-nistz.c → p256-nistz.c.inc} +104 -12
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.h +65 -8
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/{ecdsa.c → ecdsa.c.inc} +52 -107
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/internal.h +28 -11
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +1 -80
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/{rand.c → rand.c.inc} +26 -40
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/{padding.c → padding.c.inc} +2 -5
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/{rsa_impl.c → rsa_impl.c.inc} +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/{self_check.c → self_check.c.inc} +9 -35
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/internal.h +2 -2
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/{service_indicator.c → service_indicator.c.inc} +2 -2
- data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +293 -2
- data/third_party/boringssl-with-bazel/src/crypto/internal.h +69 -14
- data/third_party/boringssl-with-bazel/src/crypto/mem.c +7 -3
- data/third_party/boringssl-with-bazel/src/crypto/mldsa/internal.h +73 -0
- data/third_party/boringssl-with-bazel/src/crypto/mldsa/mldsa.c +1687 -0
- data/third_party/boringssl-with-bazel/src/crypto/mlkem/internal.h +90 -0
- data/third_party/boringssl-with-bazel/src/crypto/mlkem/mlkem.cc +1097 -0
- data/third_party/boringssl-with-bazel/src/crypto/obj/obj_dat.h +4 -1
- data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +4 -5
- data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +2 -3
- data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +1 -0
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/deterministic.c +9 -1
- data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/rand → rand_extra}/fork_detect.c +26 -28
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/getentropy.c +9 -1
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/ios.c +9 -1
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/passive.c +19 -3
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/rand_extra.c +26 -23
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/sysrand_internal.h +37 -0
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/trusty.c +9 -1
- data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/rand → rand_extra}/urandom.c +19 -19
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/windows.c +8 -1
- data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/internal.h +2 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +14 -1
- data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +14 -9
- data/third_party/boringssl-with-bazel/src/include/openssl/experimental/dilithium.h +13 -15
- data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +8 -6
- data/third_party/boringssl-with-bazel/src/include/openssl/mldsa.h +136 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/mlkem.h +246 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/nid.h +3 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +3 -4
- data/third_party/boringssl-with-bazel/src/include/openssl/service_indicator.h +2 -2
- data/third_party/boringssl-with-bazel/src/include/openssl/span.h +22 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +35 -5
- data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +5 -6
- data/third_party/boringssl-with-bazel/src/ssl/d1_lib.cc +6 -0
- data/third_party/boringssl-with-bazel/src/ssl/d1_pkt.cc +6 -1
- data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +13 -1
- data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +289 -55
- data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +2 -0
- data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +69 -38
- data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +14 -3
- data/third_party/boringssl-with-bazel/src/ssl/internal.h +107 -14
- data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +44 -16
- data/third_party/boringssl-with-bazel/src/ssl/s3_pkt.cc +21 -1
- data/third_party/boringssl-with-bazel/src/ssl/ssl_aead_ctx.cc +86 -1
- data/third_party/boringssl-with-bazel/src/ssl/ssl_buffer.cc +7 -4
- data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +97 -3
- data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +31 -2
- data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +6 -0
- data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +18 -4
- data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +96 -34
- data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +15 -5
- data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +3 -23
- metadata +113 -87
- data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.cc +0 -45
- data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.h +0 -67
- data/src/core/util/android/log.cc +0 -48
- data/src/core/util/linux/log.cc +0 -69
- data/src/core/util/posix/log.cc +0 -69
- data/src/core/util/windows/log.cc +0 -73
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/{aes.c → aes.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/{aes_nohw.c → aes_nohw.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/{key_wrap.c → key_wrap.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/{mode_wrappers.c → mode_wrappers.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{add.c → add.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/asm/{x86_64-gcc.c → x86_64-gcc.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{bn.c → bn.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{bytes.c → bytes.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{cmp.c → cmp.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{ctx.c → ctx.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{div_extra.c → div_extra.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{exponentiation.c → exponentiation.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{gcd.c → gcd.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{gcd_extra.c → gcd_extra.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{generic.c → generic.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{jacobi.c → jacobi.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{montgomery.c → montgomery.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{montgomery_inv.c → montgomery_inv.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{mul.c → mul.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{prime.c → prime.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{rsaz_exp.c → rsaz_exp.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{shift.c → shift.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/{aead.c → aead.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/{cipher.c → cipher.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/{e_aesccm.c → e_aesccm.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cmac/{cmac.c → cmac.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/{check.c → check.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/{dh.c → dh.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/{digest.c → digest.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/{digests.c → digests.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digestsign/{digestsign.c → digestsign.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{ec.c → ec.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{ec_montgomery.c → ec_montgomery.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{felem.c → felem.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{oct.c → oct.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p224-64.c → p224-64.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p256.c → p256.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{scalar.c → scalar.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{simple.c → simple.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{simple_mul.c → simple_mul.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{util.c → util.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{wnaf.c → wnaf.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdh/{ecdh.c → ecdh.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hkdf/{hkdf.c → hkdf.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hmac/{hmac.c → hmac.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md4/{md4.c → md4.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/{md5.c → md5.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{cbc.c → cbc.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{cfb.c → cfb.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{ctr.c → ctr.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{gcm.c → gcm.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{gcm_nohw.c → gcm_nohw.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{ofb.c → ofb.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{polyval.c → polyval.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/{ctrdrbg.c → ctrdrbg.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/{blinding.c → blinding.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/{rsa.c → rsa.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/{fips.c → fips.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/{sha1.c → sha1.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/{sha256.c → sha256.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/{sha512.c → sha512.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/{kdf.c → kdf.c.inc} +0 -0
- /data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/rand → rand_extra}/getrandom_fillin.h +0 -0
@@ -526,7 +526,7 @@ class RlsLb final : public LoadBalancingPolicy {
|
|
526
526
|
private:
|
527
527
|
class BackoffTimer final : public InternallyRefCounted<BackoffTimer> {
|
528
528
|
public:
|
529
|
-
BackoffTimer(RefCountedPtr<Entry> entry,
|
529
|
+
BackoffTimer(RefCountedPtr<Entry> entry, Duration delay);
|
530
530
|
|
531
531
|
// Note: We are forced to disable lock analysis here because
|
532
532
|
// Orphan() is called by OrphanablePtr<>, which cannot have lock
|
@@ -826,11 +826,9 @@ RlsLb::ChildPolicyWrapper::ChildPolicyWrapper(RefCountedPtr<RlsLb> lb_policy,
|
|
826
826
|
}
|
827
827
|
|
828
828
|
void RlsLb::ChildPolicyWrapper::Orphaned() {
|
829
|
-
|
830
|
-
|
831
|
-
|
832
|
-
<< "]: shutdown";
|
833
|
-
}
|
829
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
830
|
+
<< "[rlslb " << lb_policy_.get() << "] ChildPolicyWrapper=" << this
|
831
|
+
<< " [" << target_ << "]: shutdown";
|
834
832
|
is_shutdown_ = true;
|
835
833
|
lb_policy_->child_policy_map_.erase(target_);
|
836
834
|
if (child_policy_ != nullptr) {
|
@@ -887,22 +885,18 @@ void RlsLb::ChildPolicyWrapper::StartUpdate(
|
|
887
885
|
lb_policy_->config_->child_policy_config_target_field_name(), target_,
|
888
886
|
lb_policy_->config_->child_policy_config(), &errors);
|
889
887
|
CHECK(child_policy_config.has_value());
|
890
|
-
|
891
|
-
|
892
|
-
|
893
|
-
|
894
|
-
<< JsonDump(*child_policy_config);
|
895
|
-
}
|
888
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
889
|
+
<< "[rlslb " << lb_policy_.get() << "] ChildPolicyWrapper=" << this
|
890
|
+
<< " [" << target_
|
891
|
+
<< "]: validating update, config: " << JsonDump(*child_policy_config);
|
896
892
|
auto config =
|
897
893
|
CoreConfiguration::Get().lb_policy_registry().ParseLoadBalancingConfig(
|
898
894
|
*child_policy_config);
|
899
895
|
// Returned RLS target fails the validation.
|
900
896
|
if (!config.ok()) {
|
901
|
-
|
902
|
-
|
903
|
-
|
904
|
-
<< "]: config failed to parse: " << config.status();
|
905
|
-
}
|
897
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
898
|
+
<< "[rlslb " << lb_policy_.get() << "] ChildPolicyWrapper=" << this
|
899
|
+
<< " [" << target_ << "]: config failed to parse: " << config.status();
|
906
900
|
pending_config_.reset();
|
907
901
|
picker_ = MakeRefCounted<TransientFailurePicker>(
|
908
902
|
absl::UnavailableError(config.status().message()));
|
@@ -925,21 +919,18 @@ absl::Status RlsLb::ChildPolicyWrapper::MaybeFinishUpdate() {
|
|
925
919
|
create_args.args = lb_policy_->channel_args_;
|
926
920
|
child_policy_ = MakeOrphanable<ChildPolicyHandler>(std::move(create_args),
|
927
921
|
&rls_lb_trace);
|
928
|
-
|
929
|
-
|
930
|
-
|
931
|
-
|
932
|
-
<< child_policy_.get();
|
933
|
-
}
|
922
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
923
|
+
<< "[rlslb " << lb_policy_.get() << "] ChildPolicyWrapper=" << this
|
924
|
+
<< " [" << target_ << "], created new child policy handler "
|
925
|
+
<< child_policy_.get();
|
934
926
|
grpc_pollset_set_add_pollset_set(child_policy_->interested_parties(),
|
935
927
|
lb_policy_->interested_parties());
|
936
928
|
}
|
937
929
|
// Send the child the updated config.
|
938
|
-
|
939
|
-
|
940
|
-
|
941
|
-
|
942
|
-
}
|
930
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
931
|
+
<< "[rlslb " << lb_policy_.get() << "] ChildPolicyWrapper=" << this
|
932
|
+
<< " [" << target_ << "], updating child policy handler "
|
933
|
+
<< child_policy_.get();
|
943
934
|
UpdateArgs update_args;
|
944
935
|
update_args.config = std::move(pending_config_);
|
945
936
|
update_args.addresses = lb_policy_->addresses_;
|
@@ -954,13 +945,12 @@ absl::Status RlsLb::ChildPolicyWrapper::MaybeFinishUpdate() {
|
|
954
945
|
void RlsLb::ChildPolicyWrapper::ChildPolicyHelper::UpdateState(
|
955
946
|
grpc_connectivity_state state, const absl::Status& status,
|
956
947
|
RefCountedPtr<SubchannelPicker> picker) {
|
957
|
-
|
958
|
-
|
959
|
-
|
960
|
-
|
961
|
-
|
962
|
-
|
963
|
-
}
|
948
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
949
|
+
<< "[rlslb " << wrapper_->lb_policy_.get()
|
950
|
+
<< "] ChildPolicyWrapper=" << wrapper_.get() << " [" << wrapper_->target_
|
951
|
+
<< "] ChildPolicyHelper=" << this
|
952
|
+
<< ": UpdateState(state=" << ConnectivityStateName(state)
|
953
|
+
<< ", status=" << status << ", picker=" << picker.get() << ")";
|
964
954
|
if (wrapper_->is_shutdown_) return;
|
965
955
|
{
|
966
956
|
MutexLock lock(&wrapper_->lb_policy_->mu_);
|
@@ -1062,10 +1052,9 @@ LoadBalancingPolicy::PickResult RlsLb::Picker::Pick(PickArgs args) {
|
|
1062
1052
|
BuildKeyMap(config_->key_builder_map(), args.path,
|
1063
1053
|
lb_policy_->channel_control_helper()->GetAuthority(),
|
1064
1054
|
args.initial_metadata)};
|
1065
|
-
|
1066
|
-
|
1067
|
-
|
1068
|
-
}
|
1055
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1056
|
+
<< "[rlslb " << lb_policy_.get() << "] picker=" << this
|
1057
|
+
<< ": request keys: " << key.ToString();
|
1069
1058
|
Timestamp now = Timestamp::Now();
|
1070
1059
|
MutexLock lock(&lb_policy_->mu_);
|
1071
1060
|
if (lb_policy_->is_shutdown_) {
|
@@ -1100,10 +1089,9 @@ LoadBalancingPolicy::PickResult RlsLb::Picker::Pick(PickArgs args) {
|
|
1100
1089
|
if (entry != nullptr) {
|
1101
1090
|
// If the entry has non-expired data, use it.
|
1102
1091
|
if (entry->data_expiration_time() >= now) {
|
1103
|
-
|
1104
|
-
|
1105
|
-
|
1106
|
-
}
|
1092
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1093
|
+
<< "[rlslb " << lb_policy_.get() << "] picker=" << this
|
1094
|
+
<< ": using cache entry " << entry;
|
1107
1095
|
return entry->Pick(args);
|
1108
1096
|
}
|
1109
1097
|
// If the entry is in backoff, then use the default target if set,
|
@@ -1116,29 +1104,26 @@ LoadBalancingPolicy::PickResult RlsLb::Picker::Pick(PickArgs args) {
|
|
1116
1104
|
}
|
1117
1105
|
}
|
1118
1106
|
// RLS call pending. Queue the pick.
|
1119
|
-
|
1120
|
-
|
1121
|
-
|
1122
|
-
}
|
1107
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1108
|
+
<< "[rlslb " << lb_policy_.get() << "] picker=" << this
|
1109
|
+
<< ": RLS request pending; queuing pick";
|
1123
1110
|
return PickResult::Queue();
|
1124
1111
|
}
|
1125
1112
|
|
1126
1113
|
LoadBalancingPolicy::PickResult RlsLb::Picker::PickFromDefaultTargetOrFail(
|
1127
1114
|
const char* reason, PickArgs args, absl::Status status) {
|
1128
1115
|
if (default_child_policy_ != nullptr) {
|
1129
|
-
|
1130
|
-
|
1131
|
-
|
1132
|
-
}
|
1116
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1117
|
+
<< "[rlslb " << lb_policy_.get() << "] picker=" << this << ": "
|
1118
|
+
<< reason << "; using default target";
|
1133
1119
|
auto pick_result = default_child_policy_->Pick(args);
|
1134
1120
|
lb_policy_->MaybeExportPickCount(kMetricDefaultTargetPicks,
|
1135
1121
|
config_->default_target(), pick_result);
|
1136
1122
|
return pick_result;
|
1137
1123
|
}
|
1138
|
-
|
1139
|
-
|
1140
|
-
|
1141
|
-
}
|
1124
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1125
|
+
<< "[rlslb " << lb_policy_.get() << "] picker=" << this << ": " << reason
|
1126
|
+
<< "; failing pick";
|
1142
1127
|
auto& stats_plugins =
|
1143
1128
|
lb_policy_->channel_control_helper()->GetStatsPluginGroup();
|
1144
1129
|
stats_plugins.AddCounter(kMetricFailedPicks, 1,
|
@@ -1153,12 +1138,11 @@ LoadBalancingPolicy::PickResult RlsLb::Picker::PickFromDefaultTargetOrFail(
|
|
1153
1138
|
//
|
1154
1139
|
|
1155
1140
|
RlsLb::Cache::Entry::BackoffTimer::BackoffTimer(RefCountedPtr<Entry> entry,
|
1156
|
-
|
1141
|
+
Duration delay)
|
1157
1142
|
: entry_(std::move(entry)) {
|
1158
1143
|
backoff_timer_task_handle_ =
|
1159
1144
|
entry_->lb_policy_->channel_control_helper()->GetEventEngine()->RunAfter(
|
1160
|
-
|
1161
|
-
[self = Ref(DEBUG_LOCATION, "BackoffTimer")]() mutable {
|
1145
|
+
delay, [self = Ref(DEBUG_LOCATION, "BackoffTimer")]() mutable {
|
1162
1146
|
ApplicationCallbackExecCtx callback_exec_ctx;
|
1163
1147
|
ExecCtx exec_ctx;
|
1164
1148
|
auto self_ptr = self.get();
|
@@ -1172,13 +1156,12 @@ void RlsLb::Cache::Entry::BackoffTimer::Orphan() {
|
|
1172
1156
|
if (backoff_timer_task_handle_.has_value() &&
|
1173
1157
|
entry_->lb_policy_->channel_control_helper()->GetEventEngine()->Cancel(
|
1174
1158
|
*backoff_timer_task_handle_)) {
|
1175
|
-
|
1176
|
-
|
1177
|
-
|
1178
|
-
|
1179
|
-
|
1180
|
-
|
1181
|
-
}
|
1159
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1160
|
+
<< "[rlslb " << entry_->lb_policy_.get()
|
1161
|
+
<< "] cache entry=" << entry_.get() << " "
|
1162
|
+
<< (entry_->is_shutdown_ ? "(shut down)"
|
1163
|
+
: entry_->lru_iterator_->ToString())
|
1164
|
+
<< ", backoff timer canceled";
|
1182
1165
|
}
|
1183
1166
|
backoff_timer_task_handle_.reset();
|
1184
1167
|
Unref(DEBUG_LOCATION, "Orphan");
|
@@ -1187,13 +1170,12 @@ void RlsLb::Cache::Entry::BackoffTimer::Orphan() {
|
|
1187
1170
|
void RlsLb::Cache::Entry::BackoffTimer::OnBackoffTimerLocked() {
|
1188
1171
|
{
|
1189
1172
|
MutexLock lock(&entry_->lb_policy_->mu_);
|
1190
|
-
|
1191
|
-
|
1192
|
-
|
1193
|
-
|
1194
|
-
|
1195
|
-
|
1196
|
-
}
|
1173
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1174
|
+
<< "[rlslb " << entry_->lb_policy_.get()
|
1175
|
+
<< "] cache entry=" << entry_.get() << " "
|
1176
|
+
<< (entry_->is_shutdown_ ? "(shut down)"
|
1177
|
+
: entry_->lru_iterator_->ToString())
|
1178
|
+
<< ", backoff timer fired";
|
1197
1179
|
// Skip the update if Orphaned
|
1198
1180
|
if (!backoff_timer_task_handle_.has_value()) return;
|
1199
1181
|
backoff_timer_task_handle_.reset();
|
@@ -1258,28 +1240,25 @@ LoadBalancingPolicy::PickResult RlsLb::Cache::Entry::Pick(PickArgs args) {
|
|
1258
1240
|
if (child_policy_wrapper->connectivity_state() ==
|
1259
1241
|
GRPC_CHANNEL_TRANSIENT_FAILURE &&
|
1260
1242
|
i < child_policy_wrappers_.size() - 1) {
|
1261
|
-
|
1262
|
-
|
1263
|
-
|
1264
|
-
|
1265
|
-
|
1266
|
-
|
1267
|
-
}
|
1243
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1244
|
+
<< "[rlslb " << lb_policy_.get() << "] cache entry=" << this << " "
|
1245
|
+
<< lru_iterator_->ToString() << ": target "
|
1246
|
+
<< child_policy_wrapper->target() << " (" << i << " of "
|
1247
|
+
<< child_policy_wrappers_.size()
|
1248
|
+
<< ") in state TRANSIENT_FAILURE; skipping";
|
1268
1249
|
continue;
|
1269
1250
|
}
|
1270
1251
|
break;
|
1271
1252
|
}
|
1272
1253
|
// Child policy not in TRANSIENT_FAILURE or is the last target in
|
1273
1254
|
// the list, so delegate.
|
1274
|
-
|
1275
|
-
|
1276
|
-
|
1277
|
-
|
1278
|
-
|
1279
|
-
|
1280
|
-
|
1281
|
-
<< "; delegating";
|
1282
|
-
}
|
1255
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1256
|
+
<< "[rlslb " << lb_policy_.get() << "] cache entry=" << this << " "
|
1257
|
+
<< lru_iterator_->ToString() << ": target "
|
1258
|
+
<< child_policy_wrapper->target() << " (" << i << " of "
|
1259
|
+
<< child_policy_wrappers_.size() << ") in state "
|
1260
|
+
<< ConnectivityStateName(child_policy_wrapper->connectivity_state())
|
1261
|
+
<< "; delegating";
|
1283
1262
|
auto pick_result = child_policy_wrapper->Pick(args);
|
1284
1263
|
lb_policy_->MaybeExportPickCount(kMetricTargetPicks,
|
1285
1264
|
child_policy_wrapper->target(), pick_result);
|
@@ -1331,11 +1310,12 @@ RlsLb::Cache::Entry::OnRlsResponseLocked(
|
|
1331
1310
|
} else {
|
1332
1311
|
backoff_state_ = MakeCacheEntryBackoff();
|
1333
1312
|
}
|
1334
|
-
|
1335
|
-
Timestamp now = Timestamp::Now();
|
1336
|
-
|
1313
|
+
const Duration delay = backoff_state_->NextAttemptDelay();
|
1314
|
+
const Timestamp now = Timestamp::Now();
|
1315
|
+
backoff_time_ = now + delay;
|
1316
|
+
backoff_expiration_time_ = now + delay * 2;
|
1337
1317
|
backoff_timer_ = MakeOrphanable<BackoffTimer>(
|
1338
|
-
Ref(DEBUG_LOCATION, "BackoffTimer"),
|
1318
|
+
Ref(DEBUG_LOCATION, "BackoffTimer"), delay);
|
1339
1319
|
lb_policy_->UpdatePickerAsync();
|
1340
1320
|
return {};
|
1341
1321
|
}
|
@@ -1430,17 +1410,15 @@ RlsLb::Cache::Entry* RlsLb::Cache::FindOrInsert(
|
|
1430
1410
|
lb_policy_->RefAsSubclass<RlsLb>(DEBUG_LOCATION, "CacheEntry"), key);
|
1431
1411
|
map_.emplace(key, OrphanablePtr<Entry>(entry));
|
1432
1412
|
size_ += entry_size;
|
1433
|
-
|
1434
|
-
|
1435
|
-
|
1436
|
-
}
|
1413
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1414
|
+
<< "[rlslb " << lb_policy_ << "] key=" << key.ToString()
|
1415
|
+
<< ": cache entry added, entry=" << entry;
|
1437
1416
|
return entry;
|
1438
1417
|
}
|
1439
1418
|
// Entry found, so use it.
|
1440
|
-
|
1441
|
-
|
1442
|
-
|
1443
|
-
}
|
1419
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1420
|
+
<< "[rlslb " << lb_policy_ << "] key=" << key.ToString()
|
1421
|
+
<< ": found cache entry " << it->second.get();
|
1444
1422
|
it->second->MarkUsed();
|
1445
1423
|
return it->second.get();
|
1446
1424
|
}
|
@@ -1472,9 +1450,8 @@ std::vector<RefCountedPtr<RlsLb::ChildPolicyWrapper>> RlsLb::Cache::Shutdown() {
|
|
1472
1450
|
if (cleanup_timer_handle_.has_value() &&
|
1473
1451
|
lb_policy_->channel_control_helper()->GetEventEngine()->Cancel(
|
1474
1452
|
*cleanup_timer_handle_)) {
|
1475
|
-
|
1476
|
-
|
1477
|
-
}
|
1453
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1454
|
+
<< "[rlslb " << lb_policy_ << "] cache cleanup timer canceled";
|
1478
1455
|
}
|
1479
1456
|
cleanup_timer_handle_.reset();
|
1480
1457
|
return child_policy_wrappers_to_delete;
|
@@ -1544,19 +1521,16 @@ void RlsLb::Cache::MaybeShrinkSize(
|
|
1544
1521
|
auto map_it = map_.find(*lru_it);
|
1545
1522
|
CHECK(map_it != map_.end());
|
1546
1523
|
if (!map_it->second->CanEvict()) break;
|
1547
|
-
|
1548
|
-
|
1549
|
-
|
1550
|
-
}
|
1524
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1525
|
+
<< "[rlslb " << lb_policy_ << "] LRU eviction: removing entry "
|
1526
|
+
<< map_it->second.get() << " " << lru_it->ToString();
|
1551
1527
|
size_ -= map_it->second->Size();
|
1552
1528
|
map_it->second->TakeChildPolicyWrappers(child_policy_wrappers_to_delete);
|
1553
1529
|
map_.erase(map_it);
|
1554
1530
|
}
|
1555
|
-
|
1556
|
-
|
1557
|
-
|
1558
|
-
<< " size=" << size_;
|
1559
|
-
}
|
1531
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1532
|
+
<< "[rlslb " << lb_policy_
|
1533
|
+
<< "] LRU pass complete: desired size=" << bytes << " size=" << size_;
|
1560
1534
|
}
|
1561
1535
|
|
1562
1536
|
//
|
@@ -1566,11 +1540,10 @@ void RlsLb::Cache::MaybeShrinkSize(
|
|
1566
1540
|
void RlsLb::RlsChannel::StateWatcher::OnConnectivityStateChange(
|
1567
1541
|
grpc_connectivity_state new_state, const absl::Status& status) {
|
1568
1542
|
auto* lb_policy = rls_channel_->lb_policy_.get();
|
1569
|
-
|
1570
|
-
|
1571
|
-
|
1572
|
-
|
1573
|
-
}
|
1543
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1544
|
+
<< "[rlslb " << lb_policy << "] RlsChannel=" << rls_channel_.get()
|
1545
|
+
<< " StateWatcher=" << this << ": state changed to "
|
1546
|
+
<< ConnectivityStateName(new_state) << " (" << status << ")";
|
1574
1547
|
if (rls_channel_->is_shutdown_) return;
|
1575
1548
|
MutexLock lock(&lb_policy->mu_);
|
1576
1549
|
if (new_state == GRPC_CHANNEL_READY && was_transient_failure_) {
|
@@ -1663,11 +1636,10 @@ RlsLb::RlsChannel::RlsChannel(RefCountedPtr<RlsLb> lb_policy)
|
|
1663
1636
|
channel_.reset(Channel::FromC(
|
1664
1637
|
grpc_channel_create(lb_policy_->config_->lookup_service().c_str(),
|
1665
1638
|
creds.get(), args.ToC().get())));
|
1666
|
-
|
1667
|
-
|
1668
|
-
|
1669
|
-
|
1670
|
-
}
|
1639
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1640
|
+
<< "[rlslb " << lb_policy_.get() << "] RlsChannel=" << this
|
1641
|
+
<< ": created channel " << channel_.get() << " for "
|
1642
|
+
<< lb_policy_->config_->lookup_service();
|
1671
1643
|
if (channel_ != nullptr) {
|
1672
1644
|
// Set up channelz linkage.
|
1673
1645
|
channelz::ChannelNode* child_channelz_node = channel_->channelz_node();
|
@@ -1686,10 +1658,9 @@ RlsLb::RlsChannel::RlsChannel(RefCountedPtr<RlsLb> lb_policy)
|
|
1686
1658
|
}
|
1687
1659
|
|
1688
1660
|
void RlsLb::RlsChannel::Orphan() {
|
1689
|
-
|
1690
|
-
|
1691
|
-
|
1692
|
-
}
|
1661
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1662
|
+
<< "[rlslb " << lb_policy_.get() << "] RlsChannel=" << this
|
1663
|
+
<< ", channel=" << channel_.get() << ": shutdown";
|
1693
1664
|
is_shutdown_ = true;
|
1694
1665
|
if (channel_ != nullptr) {
|
1695
1666
|
// Remove channelz linkage.
|
@@ -1753,10 +1724,9 @@ RlsLb::RlsRequest::RlsRequest(
|
|
1753
1724
|
backoff_state_(std::move(backoff_state)),
|
1754
1725
|
reason_(reason),
|
1755
1726
|
stale_header_data_(std::move(stale_header_data)) {
|
1756
|
-
|
1757
|
-
|
1758
|
-
|
1759
|
-
}
|
1727
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1728
|
+
<< "[rlslb " << lb_policy_.get() << "] rls_request=" << this
|
1729
|
+
<< ": RLS request created for key " << key_.ToString();
|
1760
1730
|
GRPC_CLOSURE_INIT(&call_complete_cb_, OnRlsCallComplete, this, nullptr);
|
1761
1731
|
ExecCtx::Run(
|
1762
1732
|
DEBUG_LOCATION,
|
@@ -1769,10 +1739,9 @@ RlsLb::RlsRequest::~RlsRequest() { CHECK_EQ(call_, nullptr); }
|
|
1769
1739
|
|
1770
1740
|
void RlsLb::RlsRequest::Orphan() {
|
1771
1741
|
if (call_ != nullptr) {
|
1772
|
-
|
1773
|
-
|
1774
|
-
|
1775
|
-
}
|
1742
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1743
|
+
<< "[rlslb " << lb_policy_.get() << "] rls_request=" << this << " "
|
1744
|
+
<< key_.ToString() << ": cancelling RLS call";
|
1776
1745
|
grpc_call_cancel_internal(call_);
|
1777
1746
|
}
|
1778
1747
|
Unref(DEBUG_LOCATION, "Orphan");
|
@@ -1873,11 +1842,9 @@ void RlsLb::RlsRequest::OnRlsCallCompleteLocked(grpc_error_handle error) {
|
|
1873
1842
|
grpc_call_unref(call_);
|
1874
1843
|
call_ = nullptr;
|
1875
1844
|
// Return result to cache.
|
1876
|
-
|
1877
|
-
|
1878
|
-
|
1879
|
-
<< ": response info: " << response.ToString();
|
1880
|
-
}
|
1845
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
1846
|
+
<< "[rlslb " << lb_policy_.get() << "] rls_request=" << this << " "
|
1847
|
+
<< key_.ToString() << ": response info: " << response.ToString();
|
1881
1848
|
std::vector<ChildPolicyWrapper*> child_policies_to_finish_update;
|
1882
1849
|
std::vector<RefCountedPtr<ChildPolicyWrapper>>
|
1883
1850
|
child_policy_wrappers_to_delete;
|
@@ -1989,17 +1956,8 @@ RlsLb::RlsLb(Args args)
|
|
1989
1956
|
instance_uuid_(channel_args()
|
1990
1957
|
.GetOwnedString(GRPC_ARG_TEST_ONLY_RLS_INSTANCE_ID)
|
1991
1958
|
.value_or(GenerateUUID())),
|
1992
|
-
cache_(this)
|
1993
|
-
|
1994
|
-
channel_control_helper()->GetStatsPluginGroup().RegisterCallback(
|
1995
|
-
[this](CallbackMetricReporter& reporter) {
|
1996
|
-
MutexLock lock(&mu_);
|
1997
|
-
cache_.ReportMetricsLocked(reporter);
|
1998
|
-
},
|
1999
|
-
Duration::Seconds(5), kMetricCacheSize, kMetricCacheEntries)) {
|
2000
|
-
if (GRPC_TRACE_FLAG_ENABLED(rls_lb)) {
|
2001
|
-
LOG(INFO) << "[rlslb " << this << "] policy created";
|
2002
|
-
}
|
1959
|
+
cache_(this) {
|
1960
|
+
GRPC_TRACE_LOG(rls_lb, INFO) << "[rlslb " << this << "] policy created";
|
2003
1961
|
}
|
2004
1962
|
|
2005
1963
|
bool EndpointsEqual(
|
@@ -2024,9 +1982,7 @@ bool EndpointsEqual(
|
|
2024
1982
|
}
|
2025
1983
|
|
2026
1984
|
absl::Status RlsLb::UpdateLocked(UpdateArgs args) {
|
2027
|
-
|
2028
|
-
LOG(INFO) << "[rlslb " << this << "] policy updated";
|
2029
|
-
}
|
1985
|
+
GRPC_TRACE_LOG(rls_lb, INFO) << "[rlslb " << this << "] policy updated";
|
2030
1986
|
update_in_progress_ = true;
|
2031
1987
|
// Swap out config.
|
2032
1988
|
RefCountedPtr<RlsLbConfig> old_config = std::move(config_);
|
@@ -2059,25 +2015,21 @@ absl::Status RlsLb::UpdateLocked(UpdateArgs args) {
|
|
2059
2015
|
if (old_config == nullptr ||
|
2060
2016
|
config_->default_target() != old_config->default_target()) {
|
2061
2017
|
if (config_->default_target().empty()) {
|
2062
|
-
|
2063
|
-
|
2064
|
-
}
|
2018
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
2019
|
+
<< "[rlslb " << this << "] unsetting default target";
|
2065
2020
|
default_child_policy_.reset();
|
2066
2021
|
} else {
|
2067
2022
|
auto it = child_policy_map_.find(config_->default_target());
|
2068
2023
|
if (it == child_policy_map_.end()) {
|
2069
|
-
|
2070
|
-
|
2071
|
-
}
|
2024
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
2025
|
+
<< "[rlslb " << this << "] creating new default target";
|
2072
2026
|
default_child_policy_ = MakeRefCounted<ChildPolicyWrapper>(
|
2073
2027
|
RefAsSubclass<RlsLb>(DEBUG_LOCATION, "ChildPolicyWrapper"),
|
2074
2028
|
config_->default_target());
|
2075
2029
|
created_default_child = true;
|
2076
2030
|
} else {
|
2077
|
-
|
2078
|
-
|
2079
|
-
<< "] using existing child for default target";
|
2080
|
-
}
|
2031
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
2032
|
+
<< "[rlslb " << this << "] using existing child for default target";
|
2081
2033
|
default_child_policy_ =
|
2082
2034
|
it->second->Ref(DEBUG_LOCATION, "DefaultChildPolicy");
|
2083
2035
|
}
|
@@ -2103,9 +2055,8 @@ absl::Status RlsLb::UpdateLocked(UpdateArgs args) {
|
|
2103
2055
|
}
|
2104
2056
|
// Start update of child policies if needed.
|
2105
2057
|
if (update_child_policies) {
|
2106
|
-
|
2107
|
-
|
2108
|
-
}
|
2058
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
2059
|
+
<< "[rlslb " << this << "] starting child policy updates";
|
2109
2060
|
for (auto& p : child_policy_map_) {
|
2110
2061
|
p.second->StartUpdate(&child_policy_to_delete);
|
2111
2062
|
}
|
@@ -2118,9 +2069,8 @@ absl::Status RlsLb::UpdateLocked(UpdateArgs args) {
|
|
2118
2069
|
// Now that we've released the lock, finish update of child policies.
|
2119
2070
|
std::vector<std::string> errors;
|
2120
2071
|
if (update_child_policies) {
|
2121
|
-
|
2122
|
-
|
2123
|
-
}
|
2072
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
2073
|
+
<< "[rlslb " << this << "] finishing child policy updates";
|
2124
2074
|
for (auto& p : child_policy_map_) {
|
2125
2075
|
absl::Status status = p.second->MaybeFinishUpdate();
|
2126
2076
|
if (!status.ok()) {
|
@@ -2129,10 +2079,8 @@ absl::Status RlsLb::UpdateLocked(UpdateArgs args) {
|
|
2129
2079
|
}
|
2130
2080
|
}
|
2131
2081
|
} else if (created_default_child) {
|
2132
|
-
|
2133
|
-
|
2134
|
-
<< "] finishing default child policy update";
|
2135
|
-
}
|
2082
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
2083
|
+
<< "[rlslb " << this << "] finishing default child policy update";
|
2136
2084
|
absl::Status status = default_child_policy_->MaybeFinishUpdate();
|
2137
2085
|
if (!status.ok()) {
|
2138
2086
|
errors.emplace_back(absl::StrCat("target ", config_->default_target(),
|
@@ -2140,6 +2088,20 @@ absl::Status RlsLb::UpdateLocked(UpdateArgs args) {
|
|
2140
2088
|
}
|
2141
2089
|
}
|
2142
2090
|
update_in_progress_ = false;
|
2091
|
+
// On the initial update only, we set the gauge metric callback. We
|
2092
|
+
// can't do this before the initial update, because otherwise the
|
2093
|
+
// callback could be invoked before we've set state that we need for
|
2094
|
+
// the label values (e.g., we'd add metrics with empty string for the
|
2095
|
+
// RLS server name).
|
2096
|
+
if (registered_metric_callback_ == nullptr) {
|
2097
|
+
registered_metric_callback_ =
|
2098
|
+
channel_control_helper()->GetStatsPluginGroup().RegisterCallback(
|
2099
|
+
[this](CallbackMetricReporter& reporter) {
|
2100
|
+
MutexLock lock(&mu_);
|
2101
|
+
cache_.ReportMetricsLocked(reporter);
|
2102
|
+
},
|
2103
|
+
Duration::Seconds(5), kMetricCacheSize, kMetricCacheEntries);
|
2104
|
+
}
|
2143
2105
|
// In principle, we need to update the picker here only if the config
|
2144
2106
|
// fields used by the picker have changed. However, it seems fragile
|
2145
2107
|
// to check individual fields, since the picker logic could change in
|
@@ -2174,9 +2136,7 @@ void RlsLb::ResetBackoffLocked() {
|
|
2174
2136
|
}
|
2175
2137
|
|
2176
2138
|
void RlsLb::ShutdownLocked() {
|
2177
|
-
|
2178
|
-
LOG(INFO) << "[rlslb " << this << "] policy shutdown";
|
2179
|
-
}
|
2139
|
+
GRPC_TRACE_LOG(rls_lb, INFO) << "[rlslb " << this << "] policy shutdown";
|
2180
2140
|
registered_metric_callback_.reset();
|
2181
2141
|
RefCountedPtr<ChildPolicyWrapper> child_policy_to_delete;
|
2182
2142
|
std::vector<RefCountedPtr<ChildPolicyWrapper>>
|
@@ -2224,9 +2184,7 @@ void RlsLb::UpdatePickerLocked() {
|
|
2224
2184
|
// all children. This avoids unnecessary picker churn while an update
|
2225
2185
|
// is being propagated to our children.
|
2226
2186
|
if (update_in_progress_) return;
|
2227
|
-
|
2228
|
-
LOG(INFO) << "[rlslb " << this << "] updating picker";
|
2229
|
-
}
|
2187
|
+
GRPC_TRACE_LOG(rls_lb, INFO) << "[rlslb " << this << "] updating picker";
|
2230
2188
|
grpc_connectivity_state state = GRPC_CHANNEL_IDLE;
|
2231
2189
|
if (!child_policy_map_.empty()) {
|
2232
2190
|
state = GRPC_CHANNEL_TRANSIENT_FAILURE;
|
@@ -2237,10 +2195,9 @@ void RlsLb::UpdatePickerLocked() {
|
|
2237
2195
|
if (is_shutdown_) return;
|
2238
2196
|
for (auto& p : child_policy_map_) {
|
2239
2197
|
grpc_connectivity_state child_state = p.second->connectivity_state();
|
2240
|
-
|
2241
|
-
|
2242
|
-
|
2243
|
-
}
|
2198
|
+
GRPC_TRACE_LOG(rls_lb, INFO)
|
2199
|
+
<< "[rlslb " << this << "] target " << p.second->target()
|
2200
|
+
<< " in state " << ConnectivityStateName(child_state);
|
2244
2201
|
if (child_state == GRPC_CHANNEL_READY) {
|
2245
2202
|
state = GRPC_CHANNEL_READY;
|
2246
2203
|
break;
|
@@ -2259,10 +2216,8 @@ void RlsLb::UpdatePickerLocked() {
|
|
2259
2216
|
}
|
2260
2217
|
}
|
2261
2218
|
}
|
2262
|
-
|
2263
|
-
|
2264
|
-
<< ConnectivityStateName(state);
|
2265
|
-
}
|
2219
|
+
GRPC_TRACE_LOG(rls_lb, INFO) << "[rlslb " << this << "] reporting state "
|
2220
|
+
<< ConnectivityStateName(state);
|
2266
2221
|
absl::Status status;
|
2267
2222
|
if (state == GRPC_CHANNEL_TRANSIENT_FAILURE) {
|
2268
2223
|
status = absl::UnavailableError("no children available");
|