2026-02-06 11:55:11 +08:00
|
|
|
|
import io
|
|
|
|
|
|
import logging
|
|
|
|
|
|
from io import BytesIO
|
|
|
|
|
|
import urllib3
|
|
|
|
|
|
from PIL import Image
|
|
|
|
|
|
from minio import Minio
|
|
|
|
|
|
|
|
|
|
|
|
from src.core.config import settings
|
|
|
|
|
|
|
|
|
|
|
|
minio_client = Minio(settings.MINIO_URL, access_key=settings.MINIO_ACCESS, secret_key=settings.MINIO_SECRET, secure=settings.MINIO_SECURE)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# 自定义 Retry 类
|
|
|
|
|
|
class CustomRetry(urllib3.Retry):
|
|
|
|
|
|
def increment(self, method=None, url=None, response=None, error=None, **kwargs):
|
|
|
|
|
|
# 调用父类的 increment 方法
|
|
|
|
|
|
new_retry = super(CustomRetry, self).increment(method, url, response, error, **kwargs)
|
|
|
|
|
|
# 打印重试信息
|
|
|
|
|
|
logger.info(f"重试连接: {method} {url},错误: {error},重试次数: {self.total - new_retry.total}")
|
|
|
|
|
|
return new_retry
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
logger = logging.getLogger()
|
|
|
|
|
|
timeout = urllib3.Timeout(connect=1, read=10.0) # 连接超时 5 秒,读取超时 10 秒
|
|
|
|
|
|
http_client = urllib3.PoolManager(
|
|
|
|
|
|
num_pools=10, # 设置连接池大小
|
|
|
|
|
|
maxsize=10,
|
|
|
|
|
|
timeout=timeout,
|
|
|
|
|
|
cert_reqs='CERT_REQUIRED', # 需要证书验证
|
|
|
|
|
|
retries=CustomRetry(
|
|
|
|
|
|
total=5,
|
|
|
|
|
|
backoff_factor=0.2,
|
|
|
|
|
|
status_forcelist=[500, 502, 503, 504],
|
|
|
|
|
|
),
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# 获取图片
|
2026-03-19 17:55:39 +08:00
|
|
|
|
def oss_get_image(oss_client, bucket, object_name):
|
2026-02-06 11:55:11 +08:00
|
|
|
|
# cv2 默认全通道读取
|
|
|
|
|
|
image_object = None
|
|
|
|
|
|
try:
|
|
|
|
|
|
image_data = oss_client.get_object(bucket_name=bucket, object_name=object_name)
|
|
|
|
|
|
data_bytes = BytesIO(image_data.read())
|
|
|
|
|
|
image_object = Image.open(data_bytes)
|
|
|
|
|
|
except Exception as e:
|
|
|
|
|
|
logger.warning(f" | 获取图片出现异常 ######: {e}")
|
|
|
|
|
|
return image_object
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def oss_upload_image(oss_client, bucket, object_name, image_bytes):
|
|
|
|
|
|
req = None
|
|
|
|
|
|
try:
|
|
|
|
|
|
req = oss_client.put_object(bucket_name=bucket, object_name=object_name, data=io.BytesIO(image_bytes), length=len(image_bytes), content_type='image/png')
|
|
|
|
|
|
except Exception as e:
|
|
|
|
|
|
logger.warning(f" | 上传图片出现异常 ######: {e}")
|
|
|
|
|
|
return req
|
|
|
|
|
|
|
|
|
|
|
|
|
2026-03-19 17:55:39 +08:00
|
|
|
|
def oss_upload_image_file(oss_client, bucket, object_name, file_path):
|
|
|
|
|
|
req = None
|
|
|
|
|
|
try:
|
|
|
|
|
|
req = oss_client.fput_object(
|
|
|
|
|
|
bucket_name=bucket,
|
|
|
|
|
|
object_name=object_name,
|
|
|
|
|
|
file_path=file_path
|
|
|
|
|
|
)
|
|
|
|
|
|
except Exception as e:
|
|
|
|
|
|
logger.warning(f" | 上传图片出现异常 ######: {e}")
|
|
|
|
|
|
return req
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_presigned_url(oss_client, bucket, object_name):
|
|
|
|
|
|
try:
|
|
|
|
|
|
presigned_url = oss_client.presigned_get_object(
|
|
|
|
|
|
bucket_name=bucket,
|
|
|
|
|
|
object_name=object_name,
|
|
|
|
|
|
expires=3600
|
|
|
|
|
|
)
|
|
|
|
|
|
return presigned_url
|
|
|
|
|
|
except Exception as e:
|
|
|
|
|
|
print(f"get_presigned_url exception :{e}")
|
|
|
|
|
|
return "object not found"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def is_minio_file_exist(minio_client: Minio, bucket_name: str, object_name: str) -> bool:
|
|
|
|
|
|
try:
|
|
|
|
|
|
# 核心判断:检查MinIO中指定bucket+object是否存在
|
|
|
|
|
|
minio_client.stat_object(bucket_name, object_name)
|
|
|
|
|
|
return True
|
|
|
|
|
|
except Exception as e:
|
|
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
|
|
|
2026-02-06 11:55:11 +08:00
|
|
|
|
if __name__ == '__main__':
|
2026-03-19 17:55:39 +08:00
|
|
|
|
url = 'fida-test/furniture/sketches/9356e3d8-d56e-4478-adde-61b29119979b.png'
|
2026-02-06 11:55:11 +08:00
|
|
|
|
read_type = "2"
|
2026-03-19 17:55:39 +08:00
|
|
|
|
img = oss_get_image(oss_client=minio_client, bucket=url.split('/')[0], object_name=url[url.find('/') + 1:])
|
2026-02-06 11:55:11 +08:00
|
|
|
|
img.show()
|
|
|
|
|
|
img.save("result.png")
|