|
@@ -18,6 +18,8 @@ var tcpPort int
|
|
|
var ipFile string
|
|
|
var outputFile string
|
|
|
var printResultNum int
|
|
|
+var timeLimit int
|
|
|
+var speedLimit int
|
|
|
|
|
|
func init() {
|
|
|
var downloadSecond int64
|
|
@@ -40,6 +42,10 @@ https://github.com/XIU2/CloudflareSpeedTest
|
|
|
下载测速时间;单个 IP 测速最长时间,单位:秒;(默认 5)
|
|
|
-url https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png
|
|
|
下载测速地址;用来 Cloudflare CDN 测速的文件地址,如含有空格请加上引号;
|
|
|
+ -tl 200
|
|
|
+ 延迟时间上限;只输出指定延迟时间以下的结果,数量为 -dn 参数的值,单位:ms;
|
|
|
+ -sl 5
|
|
|
+ 下载速度下限;只输出指定下载速度以上的结果,数量为 -dn 参数的值,单位:MB/s;
|
|
|
-p 20
|
|
|
显示结果数量;测速后直接显示指定数量的结果,值为 0 时不显示结果直接退出;(默认 20)
|
|
|
-f ip.txt
|
|
@@ -59,6 +65,8 @@ https://github.com/XIU2/CloudflareSpeedTest
|
|
|
flag.IntVar(&downloadTestCount, "dn", 20, "下载测速数量")
|
|
|
flag.Int64Var(&downloadSecond, "dt", 5, "下载测速时间")
|
|
|
flag.StringVar(&url, "url", "https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png", "下载测速地址")
|
|
|
+ flag.IntVar(&timeLimit, "tl", 0, "延迟时间上限")
|
|
|
+ flag.IntVar(&speedLimit, "sl", 0, "下载速度下限")
|
|
|
flag.IntVar(&printResultNum, "p", 20, "显示结果数量")
|
|
|
flag.BoolVar(&disableDownload, "dd", false, "禁用下载测速")
|
|
|
flag.StringVar(&ipFile, "f", "ip.txt", "IP 数据文件")
|
|
@@ -91,6 +99,12 @@ https://github.com/XIU2/CloudflareSpeedTest
|
|
|
if url == "" {
|
|
|
url = "https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png"
|
|
|
}
|
|
|
+ if timeLimit <= 0 {
|
|
|
+ timeLimit = 9999
|
|
|
+ }
|
|
|
+ if speedLimit < 0 {
|
|
|
+ speedLimit = 0
|
|
|
+ }
|
|
|
if printResultNum < 0 {
|
|
|
printResultNum = 20
|
|
|
}
|
|
@@ -111,6 +125,7 @@ func main() {
|
|
|
var wg sync.WaitGroup
|
|
|
var mu sync.Mutex
|
|
|
var data = make([]CloudflareIPData, 0)
|
|
|
+ var data_2 = make([]CloudflareIPData, 0)
|
|
|
|
|
|
fmt.Println("# XIU2/CloudflareSpeedTest " + version + "\n")
|
|
|
fmt.Println("开始延迟测速(模式:TCP,端口:" + strconv.Itoa(tcpPort) + "):")
|
|
@@ -130,15 +145,31 @@ func main() {
|
|
|
if !disableDownload { // 如果禁用下载测速就跳过
|
|
|
if len(data) > 0 { // IP数组长度(IP数量) 大于 0 时继续
|
|
|
if len(data) < downloadTestCount { // 如果IP数组长度(IP数量) 小于 下载测速次数,则次数改为IP数
|
|
|
+ //fmt.Println("\n[信息] IP 数量小于下载测速次数(" + strconv.Itoa(downloadTestCount) + " < " + strconv.Itoa(len(data)) + "),下载测速次数改为IP数。\n")
|
|
|
downloadTestCount = len(data)
|
|
|
- fmt.Println("\n[信息] IP数量小于下载测速次数,下载测速次数改为IP数。\n")
|
|
|
+
|
|
|
+ }
|
|
|
+ var downloadTestCount_2 int // 临时的下载测速次数
|
|
|
+ if timeLimit == 9999 && speedLimit == 0 {
|
|
|
+ downloadTestCount_2 = downloadTestCount // 如果没有指定条件,则临时的下载次数变量为下载测速次数
|
|
|
+ fmt.Println("开始下载测速:")
|
|
|
+ } else if timeLimit > 0 || speedLimit >= 0 {
|
|
|
+ downloadTestCount_2 = len(data) // 如果指定了任意一个条件,则临时的下载次数变量改为总数量
|
|
|
+ fmt.Println("开始下载测速(延迟时间上限:" + strconv.Itoa(timeLimit) + " ms,下载速度下限:" + strconv.Itoa(speedLimit) + " MB/s):")
|
|
|
}
|
|
|
- bar = pb.Simple.Start(downloadTestCount)
|
|
|
- fmt.Println("开始下载测速:")
|
|
|
- for i := 0; i < downloadTestCount; i++ {
|
|
|
+ bar = pb.Simple.Start(downloadTestCount_2)
|
|
|
+ for i := 0; i < downloadTestCount_2; i++ {
|
|
|
_, speed := DownloadSpeedHandler(data[i].ip)
|
|
|
data[i].downloadSpeed = speed
|
|
|
bar.Add(1)
|
|
|
+ if int(data[i].pingTime) <= timeLimit && int(float64(speed)/1024/1024) >= speedLimit {
|
|
|
+ data_2 = append(data_2, data[i]) // 延迟和速度均满足条件时,添加到新数组中
|
|
|
+ if len(data_2) == downloadTestCount { // 满足条件的 IP =下载测速次数,则跳出循环
|
|
|
+ break
|
|
|
+ }
|
|
|
+ } else if int(data[i].pingTime) > timeLimit {
|
|
|
+ break
|
|
|
+ }
|
|
|
}
|
|
|
bar.Finish()
|
|
|
} else {
|
|
@@ -146,11 +177,17 @@ func main() {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- if outputFile != "" {
|
|
|
- ExportCsv(outputFile, data) // 输出结果到文件
|
|
|
+ if len(data_2) > 0 { // 如果该数字有内容,说明进行过指定条件的下载测速
|
|
|
+ if outputFile != "" {
|
|
|
+ ExportCsv(outputFile, data_2) // 输出结果到文件(指定延迟时间或下载速度的)
|
|
|
+ }
|
|
|
+ printResult(data_2) // 显示最快结果(指定延迟时间或下载速度的)
|
|
|
+ } else {
|
|
|
+ if outputFile != "" {
|
|
|
+ ExportCsv(outputFile, data) // 输出结果到文件
|
|
|
+ }
|
|
|
+ printResult(data) // 显示最快结果
|
|
|
}
|
|
|
-
|
|
|
- printResult(data) // 显示最快结果
|
|
|
}
|
|
|
|
|
|
// 显示最快结果
|
|
@@ -159,15 +196,15 @@ func printResult(data []CloudflareIPData) {
|
|
|
dateString := convertToString(data) // 转为多维数组 [][]String
|
|
|
if len(dateString) > 0 { // IP数组长度(IP数量) 大于 0 时继续
|
|
|
if len(dateString) < printResultNum { // 如果IP数组长度(IP数量) 小于 打印次数,则次数改为IP数量
|
|
|
+ //fmt.Println("\n[信息] IP 数量小于显示结果数量(" + strconv.Itoa(printResultNum) + " < " + strconv.Itoa(len(dateString)) + "),显示结果数量改为IP数量。\n")
|
|
|
printResultNum = len(dateString)
|
|
|
- fmt.Println("\n[信息] IP数量小于显示结果数量,显示结果数量改为IP数量。\n")
|
|
|
}
|
|
|
fmt.Printf("%-16s%-5s%-5s%-5s%-6s%-11s\n", "IP 地址", "已发送", "已接收", "丢包率", "平均延迟", "下载速度 (MB/s)")
|
|
|
for i := 0; i < printResultNum; i++ {
|
|
|
fmt.Printf("%-18s%-8s%-8s%-8s%-10s%-15s\n", ipPadding(dateString[i][0]), dateString[i][1], dateString[i][2], dateString[i][3], dateString[i][4], dateString[i][5])
|
|
|
}
|
|
|
if outputFile != "" {
|
|
|
- fmt.Printf("\n完整测速结果已写入 %v 文件,请使用记事本/表格软件查看。按下 回车键 或 Ctrl+C 退出。", outputFile)
|
|
|
+ fmt.Printf("\n完整测速结果已写入 %v 文件,请使用记事本/表格软件查看。\n按下 回车键 或 Ctrl+C 退出。", outputFile)
|
|
|
} else {
|
|
|
fmt.Printf("\n请按 回车键 或 Ctrl+C 退出。")
|
|
|
}
|