diff --git a/.image/common/mall-preview.png b/.image/common/mall-preview.png
index f939214bf..e164cd2a1 100644
Binary files a/.image/common/mall-preview.png and b/.image/common/mall-preview.png differ
diff --git a/README.md b/README.md
index a08705730..7a1346fdb 100644
--- a/README.md
+++ b/README.md
@@ -233,8 +233,6 @@
![功能图](/.image/common/mall-preview.png)
-_前端基于 crmeb uniapp 经过授权重构,优化代码实现,接入芋道快速开发平台_
-
演示地址:
### 会员中心
diff --git a/yudao-framework/yudao-common/src/main/java/cn/iocoder/yudao/framework/common/util/cache/CacheUtils.java b/yudao-framework/yudao-common/src/main/java/cn/iocoder/yudao/framework/common/util/cache/CacheUtils.java
index 7f7318487..41f75405e 100644
--- a/yudao-framework/yudao-common/src/main/java/cn/iocoder/yudao/framework/common/util/cache/CacheUtils.java
+++ b/yudao-framework/yudao-common/src/main/java/cn/iocoder/yudao/framework/common/util/cache/CacheUtils.java
@@ -1,10 +1,12 @@
package cn.iocoder.yudao.framework.common.util.cache;
+import com.alibaba.ttl.threadpool.TtlExecutors;
import com.google.common.cache.CacheBuilder;
import com.google.common.cache.CacheLoader;
import com.google.common.cache.LoadingCache;
import java.time.Duration;
+import java.util.concurrent.Executor;
import java.util.concurrent.Executors;
/**
@@ -15,11 +17,13 @@ import java.util.concurrent.Executors;
public class CacheUtils {
public static LoadingCache buildAsyncReloadingCache(Duration duration, CacheLoader loader) {
+ Executor executor = Executors.newCachedThreadPool( // TODO 芋艿:可能要思考下,未来要不要做成可配置
+ TtlExecutors.getDefaultDisableInheritableThreadFactory()); // TTL 保证 ThreadLocal 可以透传
return CacheBuilder.newBuilder()
// 只阻塞当前数据加载线程,其他线程返回旧值
.refreshAfterWrite(duration)
// 通过 asyncReloading 实现全异步加载,包括 refreshAfterWrite 被阻塞的加载线程
- .build(CacheLoader.asyncReloading(loader, Executors.newCachedThreadPool())); // TODO 芋艿:可能要思考下,未来要不要做成可配置
+ .build(CacheLoader.asyncReloading(loader, executor));
}
}