Поток данных не может получить ссылку на таблицы BigQuery, когда слишком много ядер или более одного компьютера - PullRequest
0 голосов
/ 25 ноября 2018

Предполагается, что мой потоковый конвейер Dataflow считывает аналитические хиты из Pub / Sub и записывает их в BigQuery.Если я использую слишком много машин или они слишком большие, при получении ссылки на таблицы выдается ошибка ограничения скорости, точнее при выполнении _get_or_create_table.

Достигнутое ограничение скорости кажется одним из эти : 100 запросов API в секунду на пользователя, 300 одновременных запросов API на пользователя.

Он не блокирует конвейер (строки записываются после некоторой точки), но у меня такое чувствоблокирует некоторые потоки и мешает мне полностью использовать преимущества распараллеливания.Переключение с одной машины с 4 ЦП на 5 с каждыми 8 ЦП не привело к улучшению задержки (на самом деле она ухудшилась).

Как можно избежать этой ошибки, и большое количество машин записывают в BQ?

Вот журнал из интерфейса мониторинга потока данных.Он появляется регулярно, когда я запускаю конвейер:

...
File "/usr/local/lib/python2.7/dist-packages/apache_beam/io/gcp/bigquery.py", line 1087, in get_or_create_table
    found_table = self._get_table(project_id, dataset_id, table_id)
  File "/usr/local/lib/python2.7/dist-packages/apache_beam/utils/retry.py", line 184, in wrapper
    return fun(*args, **kwargs)
  File "/usr/local/lib/python2.7/dist-packages/apache_beam/io/gcp/bigquery.py", line 925, in _get_table
    response = self.client.tables.Get(request)
  File "/usr/local/lib/python2.7/dist-packages/apache_beam/io/gcp/internal/clients/bigquery/bigquery_v2_client.py", line 611, in Get
    config, request, global_params=global_params)
  File "/usr/local/lib/python2.7/dist-packages/apitools/base/py/base_api.py", line 722, in _RunMethod
    return self.ProcessHttpResponse(method_config, http_response, request)
  File "/usr/local/lib/python2.7/dist-packages/apitools/base/py/base_api.py", line 728, in ProcessHttpResponse
    self.__ProcessHttpResponse(method_config, http_response, request))
  File "/usr/local/lib/python2.7/dist-packages/apitools/base/py/base_api.py", line 599, in __ProcessHttpResponse
    http_response, method_config=method_config, request=request)

HttpForbiddenError: HttpError accessing <https://www.googleapis.com/bigquery/v2/projects/<project_id>/datasets/<dataset_id>/tables/<table_id>?alt=json>: response: <{'status': '403', 'content-length': '577', 'x-xss-protection': '1; mode=block', 'x-content-type-options': 'nosniff', 'transfer-encoding': 'chunked', 'expires': 'Sun, 25 Nov 2018 14:36:24 GMT', 'vary': 'Origin, X-Origin', 'server': 'GSE', '-content-encoding': 'gzip', 'cache-control': 'private, max-age=0', 'date': 'Sun, 25 Nov 2018 14:36:24 GMT', 'x-frame-options': 'SAMEORIGIN', 'content-type': 'application/json; charset=UTF-8'}>, content <{
 "error": {
  "errors": [
   {
    "domain": "global",
    "reason": "rateLimitExceeded",
    "message": "Exceeded rate limits: Your user_method exceeded quota for api requests per user per method. For more information, see https://cloud.google.com/bigquery/troubleshooting-errors",
    "locationType": "other",
    "location": "helix_api.method_request"
   }
  ],
  "code": 403,
  "message": "Exceeded rate limits: Your user_method exceeded quota for api requests per user per method. For more information, see https://cloud.google.com/bigquery/troubleshooting-errors"

Вот код конвейера.Я вырезал почти все, чтобы увидеть, происходит ли это по-прежнему:

p = beam.Pipeline(options=options)

msgs = p | 'Read' >> beam.io.gcp.pubsub.ReadFromPubSub(
    topic='projects/{project}/topics/{topic}'.format(
        project=args.project, topic=args.hits_topic),
    id_label='hit_id',
    timestamp_attribute='time')

lines = msgs | beam.Map(lambda x: {'content': x})

(lines
    | 'WriteToBQ' >> beam.io.gcp.bigquery.WriteToBigQuery(args.table,
                                                          dataset=args.dataset,
                                                          project=args.project))

1 Ответ

0 голосов
/ 28 мая 2019

Попробуйте обновить до последней apache_beam библиотеки (2.12.0 на момент написания).https://github.com/apache/beam/commit/932e802279a2daa0ff7797a8fc81e952a4e4f252 введено кэширование таблиц, которое в противном случае вызвало бы ограничения скорости, с которыми вы, вероятно, сталкивались в более старой версии этой библиотеки.

...