Beim Aufrufen von GoogleAdsService.search_stream
wird ein Streaming-Antwort-Iterator zurückgegeben. Dieser Iterator sollte sich im selben Bereich wie der GoogleAdsService
-Client befinden, um fehlerhafte Streams oder Segmentierungsfehler zu vermeiden. Das liegt daran, dass das gRPC-Objekt Channel
bereinigt wird, sobald das offene GoogleAdsService
-Objekt außerhalb des Gültigkeitsbereichs liegt.
Wenn das GoogleAdsService
-Objekt nicht mehr im Bereich ist, wenn die Iteration für das Ergebnis von search_stream
erfolgt, ist das Channel
-Objekt möglicherweise bereits zerstört. Dies führt zu einem undefinierten Verhalten, wenn der Iterator versucht, den nächsten Wert abzurufen.
Der folgende Code zeigt die falsche Verwendung von Streaming-Iteratoren:
def stream_response(client, customer_id, query):
return client.get_service("GoogleAdsService", version="v20").search_stream(customer_id, query=query)
def main(client, customer_id):
query = "SELECT campaign.name FROM campaign LIMIT 10"
response = stream_response(client, customer_id, query=query)
# Access the iterator in a different scope from where the service object was created.
try:
for batch in response:
# Iterate through response, expect undefined behavior.
Im obigen Code wird das GoogleAdsService
-Objekt in einem anderen Bereich erstellt als dem, in dem auf den Iterator zugegriffen wird. Daher kann das Channel
-Objekt zerstört werden, bevor der Iterator die gesamte Antwort verarbeitet hat.
Stattdessen sollte der Streaming-Iterator so lange im selben Bereich wie der GoogleAdsService
-Client verbleiben, wie er verwendet wird:
def main(client, customer_id):
ga_service = client.get_service("GoogleAdsService", version="v20")
query = "SELECT campaign.name FROM campaign LIMIT 10"
response = ga_service.search_stream(customer_id=customer_id, query=query)
# Access the iterator in the same scope as where the service object was created.
try:
for batch in response:
# Successfully iterate through response.