Skip to content

Commit

Permalink
opt: 优化代码:
Browse files Browse the repository at this point in the history
- 1.域名重新分组,映射更精确;
- 2.添加GitHub工作流,定时更新hosts;
  • Loading branch information
sinspired committed Nov 16, 2024
1 parent 5b024ec commit b254c74
Show file tree
Hide file tree
Showing 7 changed files with 710 additions and 150 deletions.
53 changes: 53 additions & 0 deletions .github/workflows/update_hosts.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
name: Update hosts

on:
push:
paths:
- 'setHosts.py'
- 'requirements.txt'
schedule:
- cron: '0 */4 * * *'
workflow_dispatch: # 允许手动触发

jobs:
update-hosts:
runs-on: ubuntu-latest

# 添加并发限制,避免同时运行多个工作流
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
fetch-depth: 1 # 减少克隆深度,加快检出速度

- name: Set up Python
uses: actions/setup-python@v5 # 使用最新的 v5 版本
with:
python-version: '3.11'
cache: 'pip' # 启用 pip 缓存

- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: Run hosts update script
run: |
sudo python setHosts.py
- name: Commit and push changes
run: |
git config --global user.email "[email protected]"
git config --global user.name "action_bot"
if [[ -n $(git status -s) ]]; then
git add .
git commit -m "更新 hosts 内容"
git push
else
echo "No changes to commit"
fi
5 changes: 5 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ __pycache__
build
dist
*test*.*
*_temp*.*
*_tmp*.*
.idea/
*cache/

Expand All @@ -23,3 +25,6 @@ debhelper-build-stamp
*.substvars
*.csv
.vagrant

# 下方文件包含进仓库
!README_template.md
172 changes: 158 additions & 14 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,157 @@
> [!NOTE]
> 首次运行大约需要2分钟以获取DNS主机,请耐心等待。后续运行速度大约10秒左右
# 安装
## 一、使用方法

### 1.1 自动操作

直接下载下方文件,解压后双击运行,enjoy❤!

[![Release Detail](https://img.shields.io/github/v/release/sinspired/cnNetTool?sort=date&display_name=release&logo=github&label=Release)](https://github.com/sinspired/cnNetTool/releases/latest)

> 强烈建议采用本方法,如果喜欢折腾,可以继续往下看。
### 1.2 手动操作

#### 1.2.1 复制下面的内容

```bash

# cnNetTool Start in 2024-11-14 03:55:51 +08:00
140.82.112.26 alive.github.com
20.205.243.168 api.github.com
140.82.113.21 central.github.com
20.205.243.165 codeload.github.com
140.82.113.22 collector.github.com
140.82.113.3 gist.github.com
20.205.243.166 github.com
140.82.112.17 github.community
151.101.65.194 github.global.ssl.fastly.net
54.231.162.1 github-com.s3.amazonaws.com
3.5.27.154 github-production-release-asset-2e65be.s3.amazonaws.com
140.82.113.25 live.github.com
13.107.42.16 pipelines.actions.githubusercontent.com
2620:1ec:21::16 pipelines.actions.githubusercontent.com
185.199.111.154 github.githubassets.com
185.199.109.153 github.io
2606:50c0:8000::153 github.io
185.199.109.153 githubstatus.com
2606:50c0:8000::153 githubstatus.com
185.199.109.153 assets-cdn.github.com
2606:50c0:8000::153 assets-cdn.github.com
185.199.111.133 avatars.githubusercontent.com
2606:50c0:8002::154 avatars.githubusercontent.com
185.199.111.133 avatars0.githubusercontent.com
2606:50c0:8002::154 avatars0.githubusercontent.com
185.199.111.133 avatars1.githubusercontent.com
2606:50c0:8002::154 avatars1.githubusercontent.com
185.199.111.133 avatars2.githubusercontent.com
2606:50c0:8002::154 avatars2.githubusercontent.com
185.199.111.133 avatars3.githubusercontent.com
2606:50c0:8002::154 avatars3.githubusercontent.com
185.199.111.133 avatars4.githubusercontent.com
2606:50c0:8002::154 avatars4.githubusercontent.com
185.199.111.133 avatars5.githubusercontent.com
2606:50c0:8002::154 avatars5.githubusercontent.com
185.199.111.133 camo.githubusercontent.com
2606:50c0:8002::154 camo.githubusercontent.com
185.199.111.133 cloud.githubusercontent.com
2606:50c0:8002::154 cloud.githubusercontent.com
185.199.111.133 desktop.githubusercontent.com
2606:50c0:8002::154 desktop.githubusercontent.com
185.199.111.133 favicons.githubusercontent.com
2606:50c0:8002::154 favicons.githubusercontent.com
185.199.111.133 github.map.fastly.net
2606:50c0:8002::154 github.map.fastly.net
185.199.111.133 media.githubusercontent.com
2606:50c0:8002::154 media.githubusercontent.com
185.199.111.133 objects.githubusercontent.com
2606:50c0:8002::154 objects.githubusercontent.com
185.199.111.133 private-user-images.githubusercontent.com
2606:50c0:8002::154 private-user-images.githubusercontent.com
185.199.111.133 raw.githubusercontent.com
2606:50c0:8002::154 raw.githubusercontent.com
185.199.111.133 user-images.githubusercontent.com
2606:50c0:8002::154 user-images.githubusercontent.com
18.244.18.65 tmdb.org
2600:9000:21ee:ce00:5:da10:7440:93a1 tmdb.org
18.244.18.65 api.tmdb.org
2600:9000:21ee:ce00:5:da10:7440:93a1 api.tmdb.org
18.244.18.65 files.tmdb.org
2600:9000:21ee:ce00:5:da10:7440:93a1 files.tmdb.org
3.160.150.29 themoviedb.org
2600:9000:275b:b800:16:e4a1:eb00:93a1 themoviedb.org
3.160.150.29 api.themoviedb.org
2600:9000:275b:b800:16:e4a1:eb00:93a1 api.themoviedb.org
3.160.150.29 www.themoviedb.org
2600:9000:275b:b800:16:e4a1:eb00:93a1 www.themoviedb.org
3.160.150.29 auth.themoviedb.org
2600:9000:275b:b800:16:e4a1:eb00:93a1 auth.themoviedb.org
143.244.50.213 image.tmdb.org
2400:52e0:1a01::987:1 image.tmdb.org
143.244.50.213 images.tmdb.org
2400:52e0:1a01::987:1 images.tmdb.org
52.94.225.248 imdb.com
13.226.254.49 www.imdb.com
52.94.228.167 secure.imdb.com
13.226.254.49 s.media-imdb.com
52.94.228.167 us.dd.imdb.com
13.226.254.49 www.imdb.to
52.94.237.74 imdb-webservice.amazon.com
98.82.155.134 origin-www.imdb.com
151.101.1.16 m.media-amazon.com
2600:1417:8400:4::173c:6094 m.media-amazon.com
61.213.189.194 Images-na.ssl-images-amazon.com
2600:1417:8400:4::173c:6094 Images-na.ssl-images-amazon.com
61.213.189.194 images-fe.ssl-images-amazon.com
2600:1417:8400:4::173c:6095 images-fe.ssl-images-amazon.com
61.213.189.194 images-eu.ssl-images-amazon.com
2600:1417:8400:4::173c:6094 images-eu.ssl-images-amazon.com
61.213.189.194 ia.media-imdb.com
2600:1417:8400:4::173c:6095 ia.media-imdb.com
151.101.89.16 f.media-amazon.com
2a04:4e42:15::272 f.media-amazon.com
3.168.147.92 imdb-video.media-imdb.com
18.173.117.77 dqpnq362acqdi.cloudfront.net
2600:9000:25f2:3800:5:ce70:a180:21 dqpnq362acqdi.cloudfront.net
209.85.232.195 translate.google.com
2a00:1450:4001:829::201a translate.google.com
209.85.232.195 translate.googleapis.com
2a00:1450:4001:829::201a translate.googleapis.com
209.85.232.195 translate-pa.googleapis.com
2a00:1450:4001:829::201a translate-pa.googleapis.com
18.65.168.9 plugins.jetbrains.com
2600:9000:24bb:5e00:12:7c44:15c0:93a1 plugins.jetbrains.com
18.65.168.9 download.jetbrains.com
2600:9000:24bb:5e00:12:7c44:15c0:93a1 download.jetbrains.com
18.65.168.9 cache-redirector.jetbrains.com
2600:9000:24bb:5e00:12:7c44:15c0:93a1 cache-redirector.jetbrains.com

# Update time: 2024-11-14 03:55:51 +08:00
# GitHub仓库: https://github.com/sinspired/cnNetTool
# cnNetTool End

```

该内容会自动定时更新, 数据更新时间:2024-11-14 03:55:51 +08:00

#### 1.2.2 修改 hosts 文件

hosts 文件在每个系统的位置不一,详情如下:
- Windows 系统:`C:\Windows\System32\drivers\etc\hosts`
- Linux 系统:`/etc/hosts`
- Mac(苹果电脑)系统:`/etc/hosts`
- Android(安卓)系统:`/system/etc/hosts`
- iPhone(iOS)系统:`/etc/hosts`

修改方法,把第一步的内容复制到文本末尾:

1. Windows 使用记事本。
2. Linux、Mac 使用 Root 权限:`sudo vi /etc/hosts`
3. iPhone、iPad 须越狱、Android 必须要 root。


## 二、安装

首先安装 python,然后在终端中运行以下命令:

Expand All @@ -25,7 +175,7 @@ pip install -r requirements.txt
```
这将安装所有依赖项

# 参数说明
## 参数说明

**cnNetTool** 可以接受以下参数:

Expand All @@ -39,34 +189,28 @@ pip install -r requirements.txt

### Hosts文件工具 `SetHosts.py`

* --log-level 设置日志输出等级,'DEBUG', 'INFO', 'WARNING', 'ERROR'
* --num-fastest 限定Hosts主机 ip 数量
* --max-latency 设置允许的最大延迟(毫秒)
* -log 设置日志输出等级,'DEBUG', 'INFO', 'WARNING', 'ERROR'
* -num --num-fastest 限定Hosts主机 ip 数量
* -max --max-latency 设置允许的最大延迟(毫秒)
* -v --verbose 打印运行信息

命令行键入 `-h` `help` 获取帮助

`py SetDNS.py -h`

`py SetHosts.py -h`

# 运行
## 三、运行

请使用管理员权限,在项目目录运行,分别设置解析最快的DNS服务器,更新hosts文件。 **接受传递参数,大部分时候直接运行即可**

```bash
py SetDNS.py
py SetHosts.py
```

# 最新发行版下载

Windows下载可执行文件双击运行即可,注意使用管理员权限。linux系统使用sudo。

或在命令行设置参数运行:

可执行文件也可带参数运行
```pwsh
./SetDNS.exe --best-dns-num 10
./SetHosts.exe --num-fastest 3 --max-latency 500
```

[![Release Detail](https://img.shields.io/github/v/release/sinspired/cnNetTool?sort=date&display_name=release&logo=github&label=Release)](https://github.com/sinspired/cnNetTool/releases/latest)
102 changes: 102 additions & 0 deletions README_template.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
# cnNetTool

[![Release Version](https://img.shields.io/github/v/release/sinspired/cnNetTool?display_name=tag&logo=github&label=Release)](https://github.com/sinspired/cnNetTool/releases/latest)
[![GitHub repo size](https://img.shields.io/github/repo-size/sinspired/cnNetTool?logo=github)
](https://github.com/sinspired/cnNetTool)
[![GitHub last commit](https://img.shields.io/github/last-commit/sinspired/cnNetTool?logo=github&label=最后提交:)](ttps://github.com/sinspired/cnNetTool)

全面解锁Github,解决加载慢、无法访问等问题!解锁Google翻译,支持chrome网页翻译及插件,解锁划词翻译,以及依赖Google翻译API的各种平台插件。解锁tinyMediaManager影视刮削。

自动设置最佳DNS服务器。

> 适合部分地区饱受dns污染困扰,访问 GitHub 卡顿、抽风、图裂,无法使用Chrome浏览器 自带翻译功能,无法刮削影视封面等问题。分别使用 `setDNS` 自动查找最快服务器并设置,使用 `setHosts` 自动查找DNS映射主机并设置。支持Windows、Linux、MacOS。Enjoy!❤
> [!NOTE]
> 首次运行大约需要2分钟以获取DNS主机,请耐心等待。后续运行速度大约10秒左右
## 一、使用方法

### 1.1 自动操作

直接下载下方文件,解压后双击运行,enjoy❤!

[![Release Detail](https://img.shields.io/github/v/release/sinspired/cnNetTool?sort=date&display_name=release&logo=github&label=Release)](https://github.com/sinspired/cnNetTool/releases/latest)

> 强烈建议采用本方法,如果喜欢折腾,可以继续往下看。
### 1.2 手动操作

#### 1.2.1 复制下面的内容

```bash
{hosts_str}
```

该内容会自动定时更新, 数据更新时间:{update_time}

#### 1.2.2 修改 hosts 文件

hosts 文件在每个系统的位置不一,详情如下:
- Windows 系统:`C:\Windows\System32\drivers\etc\hosts`
- Linux 系统:`/etc/hosts`
- Mac(苹果电脑)系统:`/etc/hosts`
- Android(安卓)系统:`/system/etc/hosts`
- iPhone(iOS)系统:`/etc/hosts`

修改方法,把第一步的内容复制到文本末尾:

1. Windows 使用记事本。
2. Linux、Mac 使用 Root 权限:`sudo vi /etc/hosts`
3. iPhone、iPad 须越狱、Android 必须要 root。


## 二、安装

首先安装 python,然后在终端中运行以下命令:

```bash
git clone https://github.com/sinspired/cnNetTool.git
cd cnNetTool
pip install -r requirements.txt
```
这将安装所有依赖项

## 参数说明

**cnNetTool** 可以接受以下参数:

### DNS 服务器工具 `SetDNS.py`

* --debug 启用调试日志
* --show-availbale-list, --list 显示可用dns列表,通过 --num 控制显示数量
* --best-dns-num BEST_DNS_NUM, --num 显示最佳DNS服务器的数量
* --algorithm --mode {region,overall} 默认 `region` 平衡IPv4和ipv6 DNS
* --show-resolutions, --show 显示域名解析结果

### Hosts文件工具 `SetHosts.py`

* -log 设置日志输出等级,'DEBUG', 'INFO', 'WARNING', 'ERROR'
* -num --num-fastest 限定Hosts主机 ip 数量
* -max --max-latency 设置允许的最大延迟(毫秒)
* -v --verbose 打印运行信息

命令行键入 `-h` `help` 获取帮助

`py SetDNS.py -h`

`py SetHosts.py -h`

## 三、运行

请使用管理员权限,在项目目录运行,分别设置解析最快的DNS服务器,更新hosts文件。 **接受传递参数,大部分时候直接运行即可**

```bash
py SetDNS.py
py SetHosts.py
```
可执行文件也可带参数运行
```pwsh
./SetDNS.exe --best-dns-num 10
./SetHosts.exe --num-fastest 3 --max-latency 500
```

Loading

0 comments on commit b254c74

Please sign in to comment.