Sub-Store项目中的节点去重技术方案解析
2025-06-02 21:04:34作者:柯茵沙
在代理订阅管理工具Sub-Store的实际应用中,用户经常会遇到节点列表中存在重复服务器的问题。本文将深入探讨基于IP和端口的节点去重技术实现方案,帮助用户优化订阅列表。
问题背景
当用户从多个来源获取代理节点时,经常会出现不同域名指向相同服务器IP的情况。这会导致:
- 订阅列表冗余膨胀
- 连接测试时重复操作
- 影响用户体验和操作效率
核心解决方案
Sub-Store提供了脚本处理功能,可以通过JavaScript脚本实现高级节点管理。针对节点去重需求,开发者提出了两种等效的技术方案:
方案一:使用Map数据结构
function operator(proxies) {
const uniqueProxies = new Map();
proxies.forEach((proxy) => {
const key = `${proxy.server}:${proxy.port}`;
uniqueProxies.set(key, proxy);
});
return Array.from(uniqueProxies.values());
}
方案二:使用Set数据结构
function operator(proxies = []) {
const seen = new Set();
const filteredProxies = [];
proxies.forEach((p = {}) => {
const key = `${p.server}:${p.port}`;
if (!seen.has(key)) {
seen.add(key);
filteredProxies.push(p);
}
});
return filteredProxies;
}
技术要点解析
- 唯一性判断标准:以服务器地址(server)和端口号(port)的组合作为唯一标识
- 数据结构选择:
- Map对象:直接存储键值对,最后转换回数组
- Set对象:配合数组使用,检查存在性
- 保留策略:默认保留首次出现的节点,后续重复项被过滤
高级应用场景
对于使用域名而非IP的节点,可扩展方案:
- 域名解析预处理:先将域名解析为IP再进行去重
- 域名还原处理:去重后恢复原始域名
if ($server._domain) $server.server = $server._domain
实际应用建议
- 在Sub-Store的脚本处理界面选择"添加脚本操作"
- 粘贴上述任一代码片段
- 注意选择正确的代码格式(JavaScript)
- 建议先备份原始订阅,再应用去重处理
性能考量
两种方案在时间复杂度上均为O(n),适合处理大规模节点列表:
- Map方案更简洁,适合现代JavaScript环境
- Set方案更直观,便于理解去重逻辑
通过合理应用这些技术方案,用户可以显著优化Sub-Store中的代理节点管理效率,获得更简洁、高效的订阅列表。
登录后查看全文
热门项目推荐
暂无数据
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
539
3.76 K
Ascend Extension for PyTorch
Python
349
414
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
889
609
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
338
185
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
986
252
openGauss kernel ~ openGauss is an open source relational database management system
C++
169
233
暂无简介
Dart
778
193
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
114
140
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.35 K
758