Проблемы доступа к хранилищу BLOB-объектов Azure через частную конечную точку в конвейере Azure DevOps

У меня возникли проблемы с доступом к хранилищу BLOB-объектов Azure через частную конечную точку с использованием токена SAS в конвейере Azure DevOps. Несмотря на правильную настройку частной конечной точки, токена SAS и конвейера, я сталкиваюсь с ошибками AuthorizationFailure, когда конвейер пытается выполнить операции с большими двоичными объектами, такие как чтение и запись. Сообщение об ошибке:

azure.core.exceptions.HttpResponseError: This request is not authorized to perform this operation.
RequestId:70336d7b-201e-005c-179d-938271000000
Time:2024-04-21T03:36:35.5944080Z
ErrorCode:AuthorizationFailure
Content: <?xml version = "1.0" encoding = "utf-8"?><Error><Code>AuthorizationFailure</Code><Message>This request is not authorized to perform this operation. RequestId:70336d7b-201e-005c-179d-938271000000 Time:2024-04-21T03:36:35.5944080Z</Message></Error>

Код:

from azure.storage.blob import BlobServiceClient, generate_account_sas, ResourceTypes, AccountSasPermissions
from datetime import datetime, timedelta
import pandas as pd
from io import BytesIO

ACCOUNT_NAME = "****"
CONTAINER_NAME = "****"
account_url = f"https://{ACCOUNT_NAME}.blob.core.windows.net"
account_key = '****'

sas_token = generate_account_sas(
    account_name=ACCOUNT_NAME,
    account_key=account_key,
    resource_types=ResourceTypes(container=True, object=True),
    permission=AccountSasPermissions(read=True, write=True, list=True),
    expiry=datetime.utcnow() + timedelta(hours=1)
)

Я думаю, проблема в том, что мой Blob является «частным», а брандмауэр заблокирован для всех. У меня есть частная конечная точка, но как использовать ее в конвейере Azure, возможно ли это?

Какой тип агента Azure Pipelines вы используете? если вы используете агенты, размещенные Microsoft, то по умолчанию у них не будет возможности подключения к частной конечной точке, поскольку это частный IP-адрес. Попробуйте настроить самостоятельный агент Learn.microsoft.com/en-us/azure/devops/pipelines/agents/…

skjcyber 21.04.2024 10:02
Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
0
1
393
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Если вы хотите использовать частную конечную точку из своего конвейера Azure, вам придется создать автономный агент, подключенный к той же виртуальной сети (или одноранговой виртуальной сети), что и частная конечная точка BLOB-объекта. Агенты, размещенные Microsoft, просто не могут получить доступ к частным конечным точкам.

Я бы только добавил, что по моему опыту внедрение автономных агентов в масштабируемом наборе виртуальных машин оказалось гораздо менее сложной задачей, чем я думал. Это действительно требует затрат на вычисления, но если вашей организации требуется частная конечная точка и она не может принять освобождение, которое потребуется для Azure Pipelines (а оно немалое), тогда вам просто придется покрыть затраты на вычисления.

KonTheCat 21.04.2024 13:00

У организации уже есть собственный компьютер. Могу ли я использовать его для подключения к моей частной конечной точке?

LUCAS XX 21.04.2024 16:19

Я не вижу, где находится эта конфигурация, могу ли я что-то добавить или мне нужно настроить ее с нуля?

LUCAS XX 21.04.2024 16:20

@LUCASXX Если в вашей организации уже есть автономный агент, и этот агент размещен в той же виртуальной сети (или в одноранговой виртуальной сети), что и ваша частная конечная точка, вам следует использовать его, если только политика компании не предполагает этого :) Перейдите на автономный размещенный агент, просто переключив атрибут «пул» в файле yaml и убедитесь, что у вас есть необходимые разрешения на его использование.

Eric Qvarnström 21.04.2024 17:52

Другие вопросы по теме