| | |
| | | package org.dromara.common.oss.factory; |
| | | |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.dromara.common.core.constant.CacheNames; |
| | | import org.dromara.common.core.utils.StringUtils; |
| | | import org.dromara.common.json.utils.JsonUtils; |
| | |
| | | import org.dromara.common.oss.properties.OssProperties; |
| | | import org.dromara.common.redis.utils.CacheUtils; |
| | | import org.dromara.common.redis.utils.RedisUtils; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | |
| | | import java.util.Map; |
| | | import java.util.concurrent.ConcurrentHashMap; |
| | | import java.util.concurrent.locks.ReentrantLock; |
| | | |
| | | /** |
| | | * 文件上传Factory |
| | |
| | | /** |
| | | * 根据类型获取实例 |
| | | */ |
| | | public static synchronized OssClient instance(String configKey) { |
| | | public static OssClient instance(String configKey) { |
| | | String json = CacheUtils.get(CacheNames.SYS_OSS_CONFIG, configKey); |
| | | if (json == null) { |
| | | throw new OssException("系统异常, '" + configKey + "'配置信息不存在!"); |
| | |
| | | // 使用租户标识避免多个租户相同key实例覆盖 |
| | | String key = properties.getTenantId() + ":" + configKey; |
| | | OssClient client = CLIENT_CACHE.get(key); |
| | | if (client == null) { |
| | | CLIENT_CACHE.put(key, new OssClient(configKey, properties)); |
| | | log.info("创建OSS实例 key => {}", configKey); |
| | | return CLIENT_CACHE.get(key); |
| | | } |
| | | // 配置不相同则重新构建 |
| | | if (!client.checkPropertiesSame(properties)) { |
| | | CLIENT_CACHE.put(key, new OssClient(configKey, properties)); |
| | | log.info("重载OSS实例 key => {}", configKey); |
| | | return CLIENT_CACHE.get(key); |
| | | // 客户端不存在或配置不相同则重新构建 |
| | | if (client == null || !client.checkPropertiesSame(properties)) { |
| | | ReentrantLock lock = new ReentrantLock(); |
| | | lock.lock(); |
| | | try { |
| | | CLIENT_CACHE.put(key, new OssClient(configKey, properties)); |
| | | log.info("创建OSS实例 key => {}", configKey); |
| | | return CLIENT_CACHE.get(key); |
| | | } finally { |
| | | lock.unlock(); |
| | | } |
| | | } |
| | | return client; |
| | | } |