-
Notifications
You must be signed in to change notification settings - Fork 92
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
Implement propagation of x-goog-spanner-request-id gRPC header on every call #1261
Labels
api: spanner
Issues related to the googleapis/python-spanner API.
Comments
product-auto-label
bot
added
the
api: spanner
Issues related to the googleapis/python-spanner API.
label
Dec 9, 2024
odeke-em
added a commit
to odeke-em/python-spanner
that referenced
this issue
Dec 12, 2024
…propagation Generates a request_id that is then injected inside metadata that's sent over to the Cloud Spanner backend. Fixes googleapis#1261
odeke-em
added a commit
to odeke-em/python-spanner
that referenced
this issue
Dec 14, 2024
…propagation Generates a request_id that is then injected inside metadata that's sent over to the Cloud Spanner backend. Fixes googleapis#1261
odeke-em
added a commit
to odeke-em/python-spanner
that referenced
this issue
Dec 16, 2024
…propagation Generates a request_id that is then injected inside metadata that's sent over to the Cloud Spanner backend. Fixes googleapis#1261
odeke-em
added a commit
to odeke-em/python-spanner
that referenced
this issue
Dec 18, 2024
This change introduces AtomicCounter, a concurrency/thread-safe counter do deal with the multi-threaded nature of variables. It permits operations: * atomic_counter += 1 * value = atomic_counter + 1 * atomic_counter.value that'll be paramount to bringing in the logic for x-goog-spanner-request-id in much reduced changelists. Updates googleapis#1261 Carved out from PR googleapis#1264
odeke-em
added a commit
to odeke-em/python-spanner
that referenced
this issue
Dec 18, 2024
…propagation Generates a request_id that is then injected inside metadata that's sent over to the Cloud Spanner backend. Fixes googleapis#1261
olavloite
added a commit
that referenced
this issue
Dec 19, 2024
* feat(x-goog-spanner-request-id): introduce AtomicCounter This change introduces AtomicCounter, a concurrency/thread-safe counter do deal with the multi-threaded nature of variables. It permits operations: * atomic_counter += 1 * value = atomic_counter + 1 * atomic_counter.value that'll be paramount to bringing in the logic for x-goog-spanner-request-id in much reduced changelists. Updates #1261 Carved out from PR #1264 * Tests for with_request_id * chore: remove sleep * chore: remove unused import --------- Co-authored-by: Knut Olav Løite <koloite@gmail.com>
odeke-em
added a commit
to odeke-em/python-spanner
that referenced
this issue
Dec 20, 2024
…propagation Generates a request_id that is then injected inside metadata that's sent over to the Cloud Spanner backend. Officially inject the first set of x-goog-spanner-request-id values into header metadata Add request-id interceptor to use in asserting tests Wrap Snapshot methods with x-goog-request-id metadata injector Setup scaffolding for XGoogRequestIdHeader checks Wire up XGoogSpannerRequestIdInterceptor for TestDatabase checks Inject header in more Session using spots plus more tests Base for tests with retries on abort More plumbing for Transaction and Database Update unit tests for Transaction Wrap more in Transaction + update tests Update tests Plumb in more tests Update TestDatabase Fixes googleapis#1261
odeke-em
added a commit
to odeke-em/python-spanner
that referenced
this issue
Dec 24, 2024
…propagation Generates a request_id that is then injected inside metadata that's sent over to the Cloud Spanner backend. Officially inject the first set of x-goog-spanner-request-id values into header metadata Add request-id interceptor to use in asserting tests Wrap Snapshot methods with x-goog-request-id metadata injector Setup scaffolding for XGoogRequestIdHeader checks Wire up XGoogSpannerRequestIdInterceptor for TestDatabase checks Inject header in more Session using spots plus more tests Base for tests with retries on abort More plumbing for Transaction and Database Update unit tests for Transaction Wrap more in Transaction + update tests Update tests Plumb in more tests Update TestDatabase Fixes googleapis#1261
aakashanandg
pushed a commit
to aakashanandg/python-spanner
that referenced
this issue
Jan 2, 2025
…1275) * feat(x-goog-spanner-request-id): introduce AtomicCounter This change introduces AtomicCounter, a concurrency/thread-safe counter do deal with the multi-threaded nature of variables. It permits operations: * atomic_counter += 1 * value = atomic_counter + 1 * atomic_counter.value that'll be paramount to bringing in the logic for x-goog-spanner-request-id in much reduced changelists. Updates googleapis#1261 Carved out from PR googleapis#1264 * Tests for with_request_id * chore: remove sleep * chore: remove unused import --------- Co-authored-by: Knut Olav Løite <koloite@gmail.com>
odeke-em
added a commit
to odeke-em/python-spanner
that referenced
this issue
Jan 4, 2025
…propagation Generates a request_id that is then injected inside metadata that's sent over to the Cloud Spanner backend. Officially inject the first set of x-goog-spanner-request-id values into header metadata Add request-id interceptor to use in asserting tests Wrap Snapshot methods with x-goog-request-id metadata injector Setup scaffolding for XGoogRequestIdHeader checks Wire up XGoogSpannerRequestIdInterceptor for TestDatabase checks Inject header in more Session using spots plus more tests Base for tests with retries on abort More plumbing for Transaction and Database Update unit tests for Transaction Wrap more in Transaction + update tests Update tests Plumb in more tests Update TestDatabase Fixes googleapis#1261
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
This is a feature request to implement propagation of x-goog-spanner-request-id gRPC header on every call.
Reasoning
x-goog-spanner-request-id allows propagation of an ID that'll be correlated between client and server calls. We can't rely on trace headers because they are sampled, convoluted through a bunch of infrastructure so Google Engineering asked that we craft up a better mechanism. The value will allow tracking the operations of an RPC even through retries
Requirements
Each x-goog-spanner-request-id requires the following fields
Specification
Please reference https://orijtech.notion.site/x-goog-spanner-request-id-always-on-gRPC-header-to-aid-in-quick-debugging-of-errors-14aba6bc91348091a58fca7a505c9827?pvs=4
Reference implementation
I built a Go reference implementation at googleapis/google-cloud-go#11048
/cc @tharoldD
The text was updated successfully, but these errors were encountered: