|
|
@@ -435,10 +435,10 @@ public class RecommendService {
|
|
|
boolean isNoneUserRisk = isNoneUserRisk(request, param);
|
|
|
boolean hitRiskScene = riskScenes.contains(request.getHotSceneType());
|
|
|
boolean hitRiskUidCache = riskUserCache.getUnchecked(RedisKeyConstants.Recommend.riskUserUid).contains(param.getUid());
|
|
|
- // V563 实验补丁: 命中 V563 时, 把 String "null" uid 的命中改回 false,
|
|
|
+ // V563/V566 实验补丁: 命中其一时, 把 String "null" uid 的命中改回 false,
|
|
|
// 修 RickUserCacheJob 将 BIGINT NULL 转 String.valueOf(null)="null" 写入
|
|
|
// Redis Set, 导致 client 传 "null" 字符串 uid 的 guest user 全部错杀的 bug.
|
|
|
- if (hitRiskUidCache && "null".equals(param.getUid()) && isHitV563Exp(request, param)) {
|
|
|
+ if (hitRiskUidCache && "null".equals(param.getUid()) && isHitNullUidFixExp(request, param)) {
|
|
|
hitRiskUidCache = false;
|
|
|
}
|
|
|
boolean hitRiskMidCache = riskUserCache.getUnchecked(RedisKeyConstants.Recommend.riskUserMid).contains(param.getMid());
|
|
|
@@ -496,17 +496,24 @@ public class RecommendService {
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
- * 是否命中 V563 实验 (走 judgeHitAlgoExp, 同时覆盖 abExpCodes 通道和 rootSessionId
|
|
|
- * 尾号通道). 当前只用于 risk uid 命中里 String "null" 错杀的精准修复.
|
|
|
+ * null uid 风控错杀修复的实验集 (V563/V566/...). 命中其中任一实验时走精准修复路径;
|
|
|
+ * 多实验共享同一修复, 加新实验只需扩这个 Set。
|
|
|
+ *
|
|
|
+ * 走 judgeHitAlgoExp, 同时覆盖 abExpCodes 通道和 rootSessionId 尾号通道.
|
|
|
*/
|
|
|
- private static final String V563_EXP_CODE = "563";
|
|
|
-
|
|
|
- private boolean isHitV563Exp(RecommendRequest request, RecommendParam param) {
|
|
|
- return experimentService.judgeHitAlgoExp(
|
|
|
- param.getAppType(),
|
|
|
- request.getRootSessionId(),
|
|
|
- param.getAbExpCodes(),
|
|
|
- V563_EXP_CODE);
|
|
|
+ private static final Set<String> NULL_UID_FIX_EXP_CODES = new HashSet<>(Arrays.asList("563", "566"));
|
|
|
+
|
|
|
+ private boolean isHitNullUidFixExp(RecommendRequest request, RecommendParam param) {
|
|
|
+ for (String code : NULL_UID_FIX_EXP_CODES) {
|
|
|
+ if (experimentService.judgeHitAlgoExp(
|
|
|
+ param.getAppType(),
|
|
|
+ request.getRootSessionId(),
|
|
|
+ param.getAbExpCodes(),
|
|
|
+ code)) {
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return false;
|
|
|
}
|
|
|
|
|
|
private boolean isNoneUserRisk(RecommendRequest request, RecommendParam param) {
|