Skip to content

Commit 7e5804b

Browse files
committed
新增 支持仅指定 [平均延迟上限] 条件
1 parent cee7725 commit 7e5804b

File tree

2 files changed

+73
-45
lines changed

2 files changed

+73
-45
lines changed

README.md

Lines changed: 28 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -121,7 +121,7 @@ https://github.com/XIU2/CloudflareSpeedTest
121121
-url https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png
122122
下载测速地址;用来下载测速的 Cloudflare CDN 文件地址,如地址含有空格请加上引号;
123123
-tl 200
124-
平均延迟上限;只输出低于指定平均延迟的 IP,与下载速度下限搭配使用;(默认 9999.00 ms )
124+
平均延迟上限;只输出低于指定平均延迟的 IP,可单独使用也可搭配下载速度下限;(默认 9999.00 ms)
125125
-sl 5
126126
下载速度下限;只输出高于指定下载速度的 IP,凑够指定数量 [-dn] 才会停止测速;(默认 0.00 MB/s )
127127
-p 20
@@ -184,25 +184,46 @@ CloudflareST.exe -url https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png
184184
****
185185
#### \# 自定义测速条件
186186

187-
只有**同时满足三个条件**时才会停止测速。
187+
- 仅指定 **[平均延迟上限]** 条件
188188

189189
``` bash
190-
# 平均延迟上限:9999 ms,下载速度下限:5 MB/s,数量:10 个
191-
# 即需要找到 10 个平均延迟低于 9999 ms 且下载速度高于 5 MB/s 的 IP 才会停止测速。
190+
# 平均延迟上限:200 ms,下载速度下限:0 MB/s,数量:10 个
191+
# 即找到平均延迟低于 200 ms 的 IP,然后再按延迟从低到高进行 10 次下载测速
192+
CloudflareST.exe -tl 200 -dn 10
193+
```
194+
195+
> 如果没有一个 IP **平均延迟低于 200ms**,那么不会输出任何内容。
196+
197+
- 仅指定 **[平均延迟上限]** 条件,且**只延迟测速,不下载测速**
198+
199+
``` bash
200+
# 平均延迟上限:200 ms,下载速度下限:0 MB/s,数量:无限 个
201+
# 即只输出低于 200ms 的 IP,且不再下载测速(因为不再下载测速,所以 -dn 参数就无效了)
202+
CloudflareST.exe -tl 200 -dd
203+
```
204+
205+
- 仅指定 **[下载速度下限]** 条件
206+
207+
``` bash
208+
# 平均延迟上限:9999 ms,下载速度下限:5 MB/s,数量:10 个( 可选)
209+
# 即需要找到 10 个平均延迟低于 9999 ms 且下载速度高于 5 MB/s 的 IP 才会停止测速
192210
CloudflareST.exe -sl 5 -dn 10
193211
```
194212

195213
> 没有指定平均延迟上限时,如果一直**凑不够**满足条件的 IP 数量,就会**一直测速**下去。
196214
> 所以建议**同时指定 下载速度下限 和 平均延迟上限**,这样测速到指定延迟上限还没凑够数量,就会终止测速。
197215
216+
- 同时指定 **[平均延迟上限] + [下载速度下限]** 条件
217+
198218
``` bash
199219
# 平均延迟上限、下载速度下限均支持小数(如 -sl 0.5)
200-
# 平均延迟上限:200 ms,下载速度下限:5.6 MB/s,数量:10 个
201-
# 即需要找到 10 个平均延迟低于 200 ms 且下载速度高于 5 .6MB/s 的 IP 才会停止测速
220+
# 平均延迟上限:200 ms,下载速度下限:5.6 MB/s,数量:10 个( 可选)
221+
# 即需要找到 10 个平均延迟低于 200 ms 且下载速度高于 5 .6MB/s 的 IP 才会停止测速
202222
CloudflareST.exe -tl 200 -sl 5.6 -dn 10
203223
```
204224

205-
> 如果满足条件的 IP **一个都没找到**,那么就会**和不指定条件一样**输出完整结果。
225+
> 如果没有一个 IP **平均延迟低于 200ms**,那么不会输出任何内容。
226+
> 如果没有一个 IP **下载速度高于 5.6 MB/s**,那么就会**和不指定 [下载速度下限] 条件一样**输出结果。
206227
> 所以建议先不指定条件测速一遍,看看平均延迟和下载速度大概在什么范围,避免指定条件**过低/过高**
207228
208229
> 因为 Cloudflare 公开的 IP 段是**回源 IP+任播 IP**,而**回源 IP**是无法用来指向网站的,所以下载测速是 0.00。

main.go

Lines changed: 45 additions & 38 deletions
Original file line numberDiff line numberDiff line change
@@ -41,7 +41,7 @@ https://github.com/XIU2/CloudflareSpeedTest
4141
-url https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png
4242
下载测速地址;用来下载测速的 Cloudflare CDN 文件地址,如地址含有空格请加上引号;
4343
-tl 200
44-
平均延迟上限;只输出低于指定平均延迟的 IP,与下载速度下限搭配使用;(默认 9999.00 ms)
44+
平均延迟上限;只输出低于指定平均延迟的 IP,可单独使用也可搭配下载速度下限;(默认 9999.00 ms)
4545
-sl 5
4646
下载速度下限;只输出高于指定下载速度的 IP,凑够指定数量 [-dn] 才会停止测速;(默认 0.00 MB/s)
4747
-p 20
@@ -68,7 +68,7 @@ https://github.com/XIU2/CloudflareSpeedTest
6868
flag.IntVar(&downloadTestCount, "dn", 20, "下载测速数量")
6969
flag.IntVar(&downloadSecond, "dt", 10, "下载测速时间")
7070
flag.StringVar(&url, "url", "https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png", "下载测速地址")
71-
flag.Float64Var(&timeLimit, "tl", 9999, "延迟时间上限")
71+
flag.Float64Var(&timeLimit, "tl", 9999, "平均延迟上限")
7272
flag.Float64Var(&speedLimit, "sl", 0, "下载速度下限")
7373
flag.IntVar(&printResultNum, "p", 20, "显示结果数量")
7474
flag.BoolVar(&disableDownload, "dd", false, "禁用下载测速")
@@ -136,14 +136,15 @@ func main() {
136136
var wg sync.WaitGroup
137137
var mu sync.Mutex
138138
var data = make([]CloudflareIPData, 0)
139-
var data_2 = make([]CloudflareIPData, 0)
139+
var data2 = make([]CloudflareIPData, 0)
140140
downloadTestTime = time.Duration(downloadSecond) * time.Second
141141

142+
// 开始延迟测速
142143
fmt.Println("# XIU2/CloudflareSpeedTest " + version + "\n")
143-
if ipv6Mode {
144-
fmt.Println("开始延迟测速(模式:TCP IPv6,端口:" + strconv.Itoa(tcpPort) + "):")
144+
if ipv6Mode { // IPv6 模式判断
145+
fmt.Println("开始延迟测速(模式:TCP IPv6,端口:" + strconv.Itoa(tcpPort) + ",平均延迟上限:" + fmt.Sprintf("%.2f", timeLimit) + " ms):")
145146
} else {
146-
fmt.Println("开始延迟测速(模式:TCP IPv4,端口:" + strconv.Itoa(tcpPort) + "):")
147+
fmt.Println("开始延迟测速(模式:TCP IPv4,端口:" + strconv.Itoa(tcpPort) + ",平均延迟上限:" + fmt.Sprintf("%.2f", timeLimit) + " ms):")
147148
}
148149
control := make(chan bool, pingRoutine)
149150
for _, ip := range ips {
@@ -155,54 +156,61 @@ func main() {
155156
wg.Wait()
156157
bar.Finish()
157158

158-
sort.Sort(CloudflareIPDataSet(data)) // 排序
159+
sort.Sort(CloudflareIPDataSet(data)) // 排序(按延迟,从低到高,不同丢包率会分开单独按延迟和丢包率排序)
159160

160-
// 下载测速
161+
// 延迟测速完毕后,以 [平均延迟上限] 条件过滤结果
162+
if timeLimit < 9999 && timeLimit > 0 {
163+
for i := 0; i < len(data); i++ {
164+
if float64(data[i].pingTime) <= timeLimit {
165+
data2 = append(data2, data[i]) // 延迟满足条件时,添加到新数组中
166+
} else {
167+
break
168+
}
169+
}
170+
data = data2
171+
data2 = []CloudflareIPData{}
172+
}
173+
174+
// 开始下载测速
161175
if !disableDownload { // 如果禁用下载测速就跳过
162-
if len(data) > 0 { // IP数组长度(IP数量) 大于 0 时继续
163-
if len(data) < downloadTestCount { // 如果IP数组长度(IP数量) 小于 下载测速次数,则次数改为IP数
164-
//fmt.Println("\n[信息] IP 数量小于下载测速次数(" + strconv.Itoa(downloadTestCount) + " < " + strconv.Itoa(len(data)) + "),下载测速次数改为IP数。\n")
176+
if len(data) > 0 { // IP数组长度(IP数量) 大于 0 时才会继续下载测速
177+
if len(data) < downloadTestCount { // 如果IP数组长度(IP数量) 小于下载测速数量(-dn),则次数修正为IP数
165178
downloadTestCount = len(data)
166179
}
167-
var downloadTestCount_2 int // 临时的下载测速次数
168-
if timeLimit == 9999 && speedLimit == 0 {
169-
downloadTestCount_2 = downloadTestCount // 如果没有指定条件,则临时变量为下载测速次数
170-
} else if timeLimit > 0 || speedLimit >= 0 {
171-
downloadTestCount_2 = len(data) // 如果指定了任意一个条件,则临时变量改为总数量
180+
var downloadTestCount2 int // 临时的下载测速次数,即实际的下载测速数量
181+
if speedLimit > 0 {
182+
downloadTestCount2 = len(data) // 如果指定了 [下载速度下限] 条件,则临时变量改为总数量(即一直测速下去,直到凑够下载测速数量 -dn)
183+
} else {
184+
downloadTestCount2 = downloadTestCount // 如果没有指定 [下载速度下限] 条件,则临时变量为下载测速数量(-dn)
172185
}
173-
fmt.Println("开始下载测速(延迟时间上限:" + fmt.Sprintf("%.2f", timeLimit) + " ms,下载速度下限:" + fmt.Sprintf("%.2f", speedLimit) + " MB/s):")
186+
fmt.Println("开始下载测速(下载速度下限:" + fmt.Sprintf("%.2f", speedLimit) + " MB/s,下载测速数量:" + strconv.Itoa(downloadTestCount) + ",下载测速队列:" + strconv.Itoa(downloadTestCount2) + "):")
174187
bar = pb.Simple.Start(downloadTestCount)
175-
for i := 0; i < downloadTestCount_2; i++ {
188+
for i := 0; i < downloadTestCount2; i++ {
176189
_, speed := DownloadSpeedHandler(data[i].ip)
177190
data[i].downloadSpeed = speed
178-
if float64(data[i].pingTime) <= timeLimit && float64(speed)/1024/1024 >= speedLimit {
179-
data_2 = append(data_2, data[i]) // 延迟和速度均满足条件时,添加到新数组中
191+
// 在每个 IP 下载测速后,以 [下载速度下限] 条件过滤结果
192+
if float64(speed)/1024/1024 >= speedLimit {
193+
data2 = append(data2, data[i]) // 高于下载速度下限时,添加到新数组中
180194
bar.Add(1)
181-
if len(data_2) == downloadTestCount { // 满足条件的 IP =下载测速次数,则跳出循环
195+
if len(data2) == downloadTestCount { // 凑够满足条件的 IP 时(下载测速数量 -dn),就跳出循环
182196
break
183197
}
184-
} else if float64(data[i].pingTime) > timeLimit {
185-
break
186198
}
187199
}
188200
bar.Finish()
189201
} else {
190-
fmt.Println("\n[信息] IP数量为 0,跳过下载测速。")
202+
fmt.Println("\n[信息] 延迟测速结果 IP 数量为 0,跳过下载测速。")
191203
}
192204
}
193205

194-
if len(data_2) > 0 { // 如果该数组有内容,说明进行过指定条件的下载测速
195-
sort.Sort(CloudflareIPDataSetD(data_2)) // 排序
196-
if outputFile != "" {
197-
ExportCsv(outputFile, data_2) // 输出结果到文件(指定延迟时间或下载速度的)
198-
}
199-
printResult(data_2) // 显示最快结果(指定延迟时间或下载速度的)
200-
} else {
201-
if outputFile != "" {
202-
ExportCsv(outputFile, data) // 输出结果到文件
203-
}
204-
printResult(data) // 显示最快结果
206+
if len(data2) > 0 { // 如果该数组有内容,说明指定了 [下载测速下限] 条件,且最少有 1 个满足条件的 IP
207+
data = data2
208+
}
209+
sort.Sort(CloudflareIPDataSetD(data)) // 排序(按下载速度,从高到低)
210+
if outputFile != "" {
211+
ExportCsv(outputFile, data) // 输出结果到文件
205212
}
213+
printResult(data) // 显示最快结果
206214
}
207215

208216
// 显示最快结果
@@ -212,7 +220,6 @@ func printResult(data []CloudflareIPData) {
212220
dateString := convertToString(data) // 转为多维数组 [][]String
213221
if len(dateString) > 0 { // IP数组长度(IP数量) 大于 0 时继续
214222
if len(dateString) < printResultNum { // 如果IP数组长度(IP数量) 小于 打印次数,则次数改为IP数量
215-
//fmt.Println("\n[信息] IP 数量小于显示结果数量(" + strconv.Itoa(printResultNum) + " < " + strconv.Itoa(len(dateString)) + "),显示结果数量改为IP数量。\n")
216223
printResultNum = len(dateString)
217224
}
218225
if ipv6Mode { // IPv6 太长了,所以需要调整一下间隔
@@ -231,7 +238,7 @@ func printResult(data []CloudflareIPData) {
231238
fmt.Println("\n发现新版本 [" + versionNew + "]!请前往 [https://github.com/XIU2/CloudflareSpeedTest] 更新!")
232239
}
233240

234-
if sysType == "windows" { // 如果是 Windows 系统,则需要按下 回车键 或 Ctrl+C 退出
241+
if sysType == "windows" { // 如果是 Windows 系统,则需要按下 回车键 或 Ctrl+C 退出(避免通过双击运行时,测速完毕后直接关闭)
235242
if outputFile != "" {
236243
fmt.Printf("\n完整测速结果已写入 %v 文件,请使用记事本/表格软件查看。\n按下 回车键 或 Ctrl+C 退出。", outputFile)
237244
} else {
@@ -245,7 +252,7 @@ func printResult(data []CloudflareIPData) {
245252
}
246253
}
247254
} else {
248-
fmt.Println("\n[信息] IP数量为 0,跳过输出结果。")
255+
fmt.Println("\n[信息] 完整测速结果 IP 数量为 0,跳过输出结果。")
249256
}
250257
} else {
251258
fmt.Println("\n完整测速结果已写入 " + outputFile + " 文件,请使用记事本/表格软件查看。")

0 commit comments

Comments
 (0)