高性能 · 智能化 · 跨平台
一款基于现代化 UI 设计的域名 IP 智能测速与 Hosts 优化工具
SmartHostsTool 是一款专业的域名 IP 智能测速与 Hosts 文件优化工具,通过 高性能并发测速算法 自动筛选最优 IP 并写入系统 Hosts 文件,有效解决:
- ✅ GitHub 等网站访问速度慢
- ✅ DNS 解析不稳定或被污染
- ✅ 特定域名访问受限或超时
- ✅ 需要频繁切换 IP 的场景
🎨 现代化 UI 设计 - 玻璃拟态设计语言,渐变背景 + 卡片式布局
⚡ 高性能并发测速 - 基于 ThreadPoolExecutor,支持 TCP/TLS/ICMP 多种测速方式
🔄 多源智能切换 - 支持 7+ 个远程 Hosts 数据源,自动按优先级切换
🛡️ 自动权限提升 - 启动时自动请求管理员权限
🧠 智能 DNS 解析 - 批量域名并发解析,自动去重并聚合 IP
📊 高级测速指标 - 延迟、抖动、稳定性等多维度测速
🔒 TLS/SNI 验证 - HTTPS 证书验证,确保 IP 真正可用
📡 ICMP 回退机制 - TCP 测速失败时自动使用 ICMP ping
💾 自动备份 - 写入 Hosts 前自动备份,支持回滚
⏰ 定时测速 - 支持定时自动测速并写入最优 IP
🔔 系统托盘 - 最小化到托盘,后台运行不占用任务栏
界面架构:
- 顶部 App Bar:标题 + 远程源选择 + 核心操作按钮(刷新/测速/暂停/更多)
- 左侧配置区:三标签页设计(远程 Hosts / 自定义预设 / 所有解析结果)
- 右侧结果区:可交互测速结果列表 + 写入操作按钮
- 底部状态栏:进度条 + 实时状态信息
功能模块:
- 项目信息卡片:版本号 + 作者信息 + 仓库链接(可点击跳转)
- 可展开使用说明:详细操作指南,支持滚动查看
- 头像展示区:圆形裁剪头像,提升视觉亲和力
支持的数据源(按优先级):
- tinsfox:
github-hosts.tinsfox.com - GitHub520:
raw.hellogithub.com - GitHub520 原始:
raw.githubusercontent.com - GitHub520 CDN:
fastly.jsdelivr.net/cdn.jsdelivr.net - GitHub Raw 代理:
ghproxy.com - ineo6 镜像:
gitlab.com
💡 默认「自动」模式会按上述顺序依次尝试,直到成功获取数据
结果列表特性:
- ✅ 斑马纹行样式:提升数据可读性
- ✅ 状态着色:可用(绿色)/ 超时(红色)
- ✅ 多维度指标:延迟、抖动、稳定性全面展示
- ✅ 自动排序:按延迟从低到高排序
- ✅ 批量选择:点击「选择」列复选框批量勾选
- ✅ 实时更新:测速过程中动态插入新结果
- 访问 Releases 页面
- 下载对应系统的可执行文件:
- Windows:
SmartHostsTool-Windows-x64.exe
- Windows:
- 双击运行(程序会自动请求管理员权限)
⚠️ Windows Defender 提示:首次运行可能被误报,点击「更多信息」→「仍要运行」即可
Python 3.8+git clone https://github.com/KenDvD/SmartHostsTool-github.git
cd SmartHostsTool-githubpip install -r requirements.txt核心依赖:
- `ttkbootstrap>=1.10.1` - 现代化 UI 框架
- `requests>=2.25.1` - HTTP 请求库
- `Pillow>=8.0.0` - 图像处理(可选)
- `pystray>=0.19.0` - 系统托盘(可选)
# Windows(自动提权)
python main.py
# macOS/Linux(需手动提权)
sudo python main.py- 点击左侧 「🌐 远程 Hosts(仅 GitHub)」 标签页
- 在「自定义预设」中 选中
github.com - 点击顶部 「🔄 刷新远程 Hosts」 按钮
- 等待数据获取完成(通常 2-5 秒)
远程 Hosts 优势:
- ✅ 无需手动解析 DNS
- ✅ 获取 GitHub 全家桶域名(
github.com、githubusercontent.com、assets-cdn.github.com等) - ✅ 数据来源可靠(由社区维护并定期更新)
- 点击左侧 「自定义预设」 标签页
- 点击 「➕ 添加」 按钮,输入域名(如
google.com、twitter.com) - 按住
Ctrl或Shift多选要测速的域名 - 点击 「批量解析」 按钮
自定义解析说明:
- 🔍 程序会通过 DNS 查询获取域名的所有 A 记录
- ⚡ 使用 20 线程并发解析,速度极快
- 📊 解析结果会显示在「🔍 所有解析结果」标签页
- 确认左侧已有 IP 数据(远程 Hosts 或解析结果)
- 点击顶部 「▶ 开始测速」 按钮
- 观察右侧结果区域实时更新
- 如需中断,点击 「⏸ 暂停测速」
测速技术细节:
- 🚀 60 线程并发:同时测试多个 IP,速度快 10 倍
- 🎯 TCP 80 端口探测:模拟真实 HTTP 访问,精准度高
- 📏 三次取平均:每个 IP 测试 3 次取平均值,避免网络波动
- ⏱️ 超时控制:单次测试超时 2 秒自动标记为「超时」
- 🔄 节流排序:测速过程中每 300ms 刷新一次列表,避免卡顿
- 测速完成后,点击底部 「一键写入最优 IP」 按钮
- 程序会自动为每个域名选择延迟最低的可用 IP
- 确认弹窗提示,等待写入完成
- 在右侧结果列表中,点击「选择」列的复选框
- 可多选不同域名的 IP 地址
- 点击底部 「写入选中到 Hosts」 按钮
适用场景:
- 🎯 需要为不同域名指定特定 IP
- 🔀 测试不同 IP 的实际访问效果
- 🛡️ 避免某些 IP 被运营商限速
写入 Hosts 后,点击顶部 「🧰 更多」 → 「🧹 刷新 DNS」 使配置立即生效。
点击顶部 「远程源:自动(按优先级)▾」 下拉菜单,可手动指定数据源。
点击 「🧰 更多」 → 「⏰ 定时测速设置」,配置定时自动测速:
- 设置测速间隔(推荐 30-240 分钟)
- 选择要测速的域名
- 开启自动写入最优 IP
- 支持托盘通知
- 最小化到托盘:关闭窗口时最小化到系统托盘而非退出
- 快捷操作:右键托盘图标可快速测速、刷新 DNS
- 后台运行:不占用任务栏空间
点击 「🧰 更多」 → 「⚙️ 测速配置」,自定义测速参数:
- TCP 端口、超时时间、尝试次数
- TLS/SNI 验证开关
- ICMP 回退机制
- 高级指标(抖动、稳定性)
点击 「🧰 更多」 → 「📄 查看 Hosts 文件」,程序会自动用系统默认编辑器打开 Hosts 文件。
Hosts 文件路径:
- Windows:
C:\Windows\System32\drivers\etc\hosts - macOS/Linux:
/etc/hosts
写入标记:
# === SmartHostsTool Start ===
185.199.108.153 github.com
140.82.113.4 api.github.com
# ... 更多记录
# === SmartHostsTool End ===💡 程序会在标记区间内管理记录,不会影响其他手动配置
┌─────────────────────────────────────────────┐
│ SmartHostsTool 架构图 │
├─────────────────────────────────────────────┤
│ UI Layer │ ttkbootstrap (Vapor) │
│ │ Pillow (背景绘制) │
├──────────────────┼──────────────────────────┤
│ Logic Layer │ concurrent.futures │
│ │ threading / asyncio │
│ │ socket (TCP/ICMP 探测) │
│ │ ssl (TLS/SNI 验证) │
├──────────────────┼──────────────────────────┤
│ Network Layer │ requests + HTTPAdapter │
│ │ Retry 策略 │
├──────────────────┼──────────────────────────┤
│ System Layer │ ctypes (权限提升) │
│ │ subprocess (DNS 刷新) │
│ │ shutil (备份/回滚) │
└─────────────────────────────────────────────┘
SmartHostsTool-github/
├── main.py # 程序入口:GUI 模式和 writer mode(提权写入)
├── main_window.py # UI 层:主窗口界面、交互逻辑、状态更新
├── about_window.py # UI 层:关于窗口、使用说明
├── services.py # 业务逻辑层:远程 Hosts 获取、DNS 解析、测速
├── hosts_file.py # 系统层:Hosts 文件读写、备份、DNS 刷新
├── config.py # 配置层:集中管理常量、配置项
├── ui_visuals.py # UI 视觉层:玻璃拟态背景绘制
├── utils.py # 工具层:资源路径、权限管理、原子写入
├── tray_icon.py # 系统托盘:托盘图标、菜单、通知
├── icon.ico # 程序图标
├── 头像.jpg # 关于界面头像
├── presets.json # 自定义预设存储
├── requirements.txt # 依赖清单
└── README.md # 项目文档
| 模块 | 职责 | 依赖 |
|---|---|---|
| main.py | 程序入口,支持 GUI 模式和 writer mode(提权后写入 Hosts) | ttkbootstrap, hosts_file, utils |
| main_window.py | 主窗口 UI 布局、事件处理、调用 services 完成业务逻辑 | ttkbootstrap, services, hosts_file, ui_visuals |
| about_window.py | 关于窗口、使用说明展开/收起 | ttkbootstrap, ui_visuals, utils |
| services.py | 远程 Hosts 获取、DNS 解析、TCP/TLS/ICMP 测速 | requests, socket, ssl, asyncio |
| hosts_file.py | Hosts 文件读写、自动备份、回滚、DNS 刷新 | shutil, subprocess, codecs |
| config.py | 集中管理所有配置常量(远程源、超时、线程数等) | 无 |
| ui_visuals.py | 玻璃拟态背景绘制(渐变 + 光晕 + 噪点) | Pillow(可选) |
| utils.py | 资源路径兼容 PyInstaller、管理员权限管理、原子写入 | ctypes, json, tempfile |
| tray_icon.py | 系统托盘图标、菜单、通知 | pystray, Pillow(可选) |
- 分层清晰:UI 层不直接操作系统文件,通过 hosts_file.py 封装
- 模块解耦:services.py 不依赖 tkinter/ttkbootstrap,可独立测试
- 可配置性:所有配置集中在 config.py,便于后期扩展
- 兼容性:utils.py 提供资源路径兼容 PyInstaller
- 容错性:Pillow 不可用时自动降级为纯色背景
# 使用 ThreadPoolExecutor 实现 60 线程并发
self.executor = concurrent.futures.ThreadPoolExecutor(60)
for ip, domain in data:
self.executor.submit(self._test_ip_delay, ip, domain)优势:
- ⚡ 60 线程并发,测速速度提升 10-20 倍
- 🧵 自动管理线程池,避免资源泄漏
- 🛡️ 超时控制 + 异常处理,保证稳定性
技术原理:
- 📊 测速结果暂存在内存,每 300ms 批量更新一次 UI
- 🎯 减少 Tkinter 主线程负载,保持界面流畅
优化效果:
- 🖼️ 绘制速度提升 5-10 倍
- 💾 内存占用降低 80%
# Windows 平台自动请求管理员权限
if not is_admin():
ctypes.windll.shell32.ShellExecuteW(
None, "runas", sys.executable, __file__, None, 5
)
sys.exit(0)用户体验提升:
- ✅ 无需手动「右键 → 以管理员身份运行」
- ✅ UAC 提示框自动弹出
A:Hosts 文件位于系统保护目录(C:\Windows\System32\drivers\etc\),修改需要管理员权限。程序会在启动时自动请求提权。
可能原因:
- 🔥 防火墙拦截 TCP 443 端口探测
- 🌐 网络环境异常(如使用代理)
- 🚫 目标 IP 确实不可用
解决方案:
- 临时关闭防火墙/安全软件重试
- 切换不同的远程数据源
- 检查本地网络连接状态
排查步骤:
- 点击「刷新 DNS」清除缓存
- 重启浏览器(清除浏览器 DNS 缓存)
- 使用
ping命令验证解析是否生效: - 检查浏览器是否使用了代理(如 VPN)
方法一:手动编辑
- 点击「查看 Hosts 文件」
- 删除
# === SmartHostsTool Start ===到# === SmartHostsTool End ===之间的内容 - 保存并刷新 DNS
方法二:使用备份(如果启用了备份功能)
# Windows
copy C:\Windows\System32\drivers\etc\hosts.bak C:\Windows\System32\drivers\etc\hostsIPv4+IPv6双栈测速
# 1. 克隆项目
git clone https://github.com/KenDvD/SmartHostsTool-github.git
cd SmartHostsTool-github
# 2. 创建虚拟环境(推荐)
python -m venv venv
source venv/bin/activate # Windows: venv\Scripts\activate
# 3. 安装开发依赖
pip install -r requirements-dev.txt
# 4. 运行程序
python main.py- 风格:遵循 PEP 8 规范
- 注释:关键函数使用文档字符串
- 类型提示:使用
typing模块标注参数类型 - 异常处理:避免裸
except,明确捕获异常类型
使用 PyInstaller 打包:
# 安装 PyInstaller
pip install pyinstaller
# 打包为单文件可执行程序
pyinstaller --onefile --windowed --icon=icon.ico --add-data "presets.json;." --add-data "头像.jpg;." --name "SmartHostsTool" main.py参数说明:
--onefile:打包为单个 EXE 文件--windowed:隐藏控制台窗口--icon:设置程序图标--add-data:打包额外资源文件
欢迎提交 Issue 和 Pull Request!
- Fork 本仓库到你的 GitHub 账号
- 克隆到本地并创建特性分支:
git checkout -b feature/AmazingFeature - 提交更改:
git commit -m 'Add some AmazingFeature' - 推送到分支:
git push origin feature/AmazingFeature - 提交 Pull Request,描述你的改进内容
- 🐛 修复已知 Bug
- ✨ 新增实用功能(如 IPv6 支持、Hosts 备份还原)
- 📝 改进文档与注释
- 🎨 优化 UI 设计与交互
- 🌍 国际化支持(多语言界面)
本项目采用 MIT 许可证 开源。
核心条款:
- ✅ 可自由使用、修改、分发
- ✅ 可用于商业项目
⚠️ 需保留原作者版权声明⚠️ 作者不承担任何责任
感谢以下开源项目与社区的支持:
- GitHub520:提供稳定的远程 Hosts 数据源
- ttkbootstrap:现代化 Tkinter UI 框架
- Pillow:强大的 Python 图像处理库
- 所有贡献者:感谢每一位提交代码、反馈问题的开发者
- 作者:up:毕加索自画像
- GitHub:@KenDvD
- 项目仓库:SmartHostsTool-github
如果这个项目对你有帮助,欢迎点亮 Star ⭐ 支持一下!
Made with ❤️ by KenDvD