google.api_core.exceptions.ServiceUnavailable: 503 Getting metadata from plugin failed with error: 'str' object has no attribute 'before_request'

荒凉一梦 提交于 2021-02-18 12:58:07

问题


I'm trying to iterate through images in a directory and get their labels through goodle_api_vision. This is my code: def run_quickstart(): import io import os import cv2 import numpy as np from google.cloud import vision from google.cloud.vision import types

client = vision.ImageAnnotatorClient(credentials = 'service_acc_key.json')

path = 'E:\wrand\\'
for image_path in os.listdir(path):

    file_name = path + image_path
    content = cv2.imread(file_name)
    # Loads the image into memory
    #with io.open(file_name, 'rb') as image_file:
       # content = image_file.read()
    content = content.tobytes()
    print(type(content))

    image = types.Image(content=content)
    print(type(image))
    response = client.label_detection(image=image)
    labels = response.label_annotations
    print('Labels:')
    for label in labels:
        print(label.description)
        # [END vision_quickstart]

if __name__ == '__main__':
    run_quickstart()

the error that I get is at this part of code image = types.Image(content=content). The full error being

<class 'bytes'>
<class 'google.cloud.vision_v1.types.Image'>
ERROR:root:AuthMetadataPluginCallback " 
<google.auth.transport.grpc.AuthMetadataPlugin object at 
0x0000028520DCA2E8>" raised exception!
Traceback (most recent call last):
  File "C:\Users\hi_pe\AppData\Local\Programs\Python\Python36\lib\site- 
packages\grpc\_plugin_wrapping.py", line 77, in __call__
    callback_state, callback))
  File "C:\Users\hi_pe\AppData\Local\Programs\Python\Python36\lib\site- 
packages\google\auth\transport\grpc.py", line 77, in __call__
    callback(self._get_authorization_headers(context), None)
  File "C:\Users\hi_pe\AppData\Local\Programs\Python\Python36\lib\site
packages\google\auth\transport\grpc.py", line 61, in 
_get_authorization_headers
    self._credentials.before_request(
AttributeError: 'str' object has no attribute 'before_request'
Traceback (most recent call last):
  File "C:\Users\hi_pe\AppData\Local\Programs\Python\Python36\lib\site- 
packages\google\api_core\grpc_helpers.py", line 54, in error_remapped_callable
return callable_(*args, **kwargs)
File "C:\Users\hi_pe\AppData\Local\Programs\Python\Python36\lib\site-packages\grpc\_channel.py", line 487, in __call__
return _end_unary_response_blocking(state, call, False, deadline)
File "C:\Users\hi_pe\AppData\Local\Programs\Python\Python36\lib\site-packages\grpc\_channel.py", line 437, in _end_unary_response_blocking
raise _Rendezvous(state, None, None, deadline)
grpc._channel._Rendezvous: <_Rendezvous of RPC that terminated with (StatusCode.UNAVAILABLE, Getting metadata from plugin failed with error: 'str' object has no attribute 'before_request')>

The above exception was the direct cause of the following exception:

Traceback (most recent call last):
  File "Tutorial.py", line 32, in <module>
run_quickstart()
  File "Tutorial.py", line 24, in run_quickstart
response = client.label_detection(image=image)
  File "C:\Users\hi_pe\AppData\Local\Programs\Python\Python36\lib\site-packages\google\cloud\vision_helpers\decorators.py", line 117, in inner
response = self.annotate_image(request, retry=retry, timeout=timeout)
  File "C:\Users\hi_pe\AppData\Local\Programs\Python\Python36\lib\site-packages\google\cloud\vision_helpers\__init__.py", line 67, in annotate_image
r = self.batch_annotate_images([request], retry=retry, timeout=timeout)
  File "C:\Users\hi_pe\AppData\Local\Programs\Python\Python36\lib\site-packages\google\cloud\vision_v1\gapic\image_annotator_client.py", line 165, in batch_annotate_images
request, retry=retry, timeout=timeout, metadata=metadata)
  File "C:\Users\hi_pe\AppData\Local\Programs\Python\Python36\lib\site-packages\google\api_core\gapic_v1\method.py", line 139, in __call__
return wrapped_func(*args, **kwargs)
  File "C:\Users\hi_pe\AppData\Local\Programs\Python\Python36\lib\site-packages\google\api_core\grpc_helpers.py", line 56, in error_remapped_callable
six.raise_from(exceptions.from_grpc_error(exc), exc)
  File "<string>", line 3, in raise_from
google.api_core.exceptions.ServiceUnavailable: 503 Getting metadata from plugin failed with error: 'str' object has no attribute 'before_request'

I put the line content = content.tobytes() because otherwise I get this error has type <class 'numpy.ndarray'>, but expected one of: ((<class 'bytes'>,),) (always at this method call image = types.Image(content=content))


回答1:


Unfortunately you can't just pass a string directly as the credentials argument (although perhaps we should make it where you can), you should do this instead:

from google.oauth2 import service_account

credentials = service_account.Credentials.from_service_account_file('service_acc_key.json')

client = vision.ImageAnnotatorClient(credentials=credentials)



回答2:


Add the following lines before calling the client

os.environ["GOOGLE_APPLICATION_CREDENTIALS"] = path/to/service-account.json/file



来源:https://stackoverflow.com/questions/50446716/google-api-core-exceptions-serviceunavailable-503-getting-metadata-from-plugin

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!