ECS
Fusion Monster Evaluation Project - GO Version
(No additional shell file dependencies unless necessary to install the environment using the shell, the environment is installed just to measure more accurately, in extreme cases no environment dependencies can also be fully measured project)
Please report any issues via issues.
Go version: https://github.com/oneclickvirt/ecs
Shell version: https://github.com/spiritLHLS/ecs/blob/main/README_EN.md
Language
Supported Systems and Architectures
Compilation and Testing Support
Supported for Compilation | Tested on | Supported OS for Compilation | Tested OS |
---|---|---|---|
amd64 | amd64 | Linux | Linux |
arm64 | arm64 | Windows | Windows |
arm | MacOS(Darwin) | MacOS | |
386 | FreeBSD | ||
mips,mipsle | Android | ||
mips64,mips64le | |||
ppc64,ppc64le | |||
s390x | s390x | ||
riscv64 |
For more information about the architecture and system, please test or compile it yourself, and open issues if you have any questions.
Systems Pending Support
OS | Notes |
---|---|
Android(arm64) | Permission issues that are not fixed, no problems with ARM architecture for non-Android systems |
OpenBSD/NetBSD | Some of Goalng's official libraries do not support this system (especially net-related items) |
Windows(Virtual Machines) | Inaccurate mbw test performance without Admin rights (memory tests) |
Windows(Physical Machines)(not under Admin) | Inaccurate mbw test performance without Admin rights (memory tests) |
Features
- System basic information query and concurrent IP basic information query: Self-developed basics, gostun
- CPU test: Self-developed cputest supporting sysbench(lua/golang version), geekbench, winsat
- Memory test: Self-developed memorytest supporting sysbench, dd
- Disk test: Self-developed disktest supporting dd, fio, winsat
- Streaming media unlock information concurrent query: Modified from netflix-verify and more to CommonMediaTests
- Common streaming media tests concurrent query: Self-developed to UnlockTests, logic modified from RegionRestrictionCheck and others
- IP quality/security information concurrent query: Self-developed, binary files compiled in securityCheck
- Email port test: Self-developed portchecker
- Three-network return path test: Modified from zhanghanyun/backtrace to oneclickvirt/backtrace
- Three-network route test: Modified from NTrace-core to nt3
- Speed test: Based on data from speedtest.net and speedtest.cn, developed to oneclickvirt/speedtest
- Three-network Ping test: Modified from ecsspeed to pingtest
- Support root or admin environment testing, support non-root or non-admin environment testing, support offline environment for testing, not support no DNS environment for testing
For first-time users of this project, it is recommended to check the instructions: Jump to
Instructions for Use
Linux/FreeBSD/MacOS
One-click command
One-Click Command will Install Dependencies by Default, Update Package Manager by Default, Default Non-Interactive Mode*
-
International users without acceleration:
export noninteractive=true && curl -L https://raw.githubusercontent.com/oneclickvirt/ecs/master/goecs.sh -o goecs.sh && chmod +x goecs.sh && ./goecs.sh env && ./goecs.sh install && goecs
-
International/domestic users with CDN acceleration:
export noninteractive=true && curl -L https://cdn.spiritlhl.net/https://raw.githubusercontent.com/oneclickvirt/ecs/master/goecs.sh -o goecs.sh && chmod +x goecs.sh && ./goecs.sh env && ./goecs.sh install && goecs
-
Domestic users with CNB acceleration:
export noninteractive=true && curl -L https://cnb.cool/oneclickvirt/ecs/-/git/raw/main/goecs.sh -o goecs.sh && chmod +x goecs.sh && ./goecs.sh env && ./goecs.sh install && goecs
-
Short Link:
export noninteractive=true && curl -L https://bash.spiritlhl.net/goecs -o goecs.sh && chmod +x goecs.sh && bash goecs.sh env && bash goecs.sh install && goecs ``
Detailed instructions
Detailed description of the commands in *Command Controls whether to install dependencies, Whether to update the package manager, Default interaction mode can be selected
Expand to view detailed instructions
-
Download the script
International users without acceleration:
curl -L https://raw.githubusercontent.com/oneclickvirt/ecs/master/goecs.sh -o goecs.sh && chmod +x goecs.sh
International/domestic users with CDN acceleration:
curl -L https://cdn.spiritlhl.net/https://raw.githubusercontent.com/oneclickvirt/ecs/master/goecs.sh -o goecs.sh && chmod +x goecs.sh
Domestic users with CNB acceleration:
curl -L https://cnb.cool/oneclickvirt/ecs/-/git/raw/main/goecs.sh -o goecs.sh && chmod +x goecs.sh
-
Update package manager (optional) and install environment
./goecs.sh env
Non-interactive mode:
export noninteractive=true && ./goecs.sh env
-
Install
goecs
./goecs.sh install
-
Upgrade
goecs
./goecs.sh upgrade
-
Uninstall
goecs
./goecs.sh uninstall
-
help command
./goecs.sh -h
-
Invoke the menu
goecs -l en
Command parameterization
Expand to view parameter descriptions
Usage: goecs [options]
-backtrace
Enable/Disable backtrace test (in 'en' language or on windows it always false) (default true)
-basic
Enable/Disable basic test (default true)
-comm
Enable/Disable common media test (default true)
-cpu
Enable/Disable CPU test (default true)
-cpum string
Set CPU test method (supported: sysbench, geekbench, winsat) (default "sysbench")
-cput string
Set CPU test thread mode (supported: single, multi) (default "multi")
-disk
Enable/Disable disk test (default true)
-diskm string
Set disk test method (supported: fio, dd, winsat) (default "fio")
-diskmc
Enable/Disable multiple disk checks, e.g., -diskmc=false
-diskp string
Set disk test path, e.g., -diskp /root
-email
Enable/Disable email port test (default true)
-h Show help information
-l string
Set language (supported: en, zh) (default "zh")
-log
Enable/Disable logging in the current path
-memory
Enable/Disable memory test (default true)
-memorym string
Set memory test method (supported: sysbench, dd, winsat) (default "sysbench")
-menu
Enable/Disable menu mode, disable example: -menu=false (default true)
-nt3
Enable/Disable NT3 test (in 'en' language or on windows it always false) (default true)
-nt3loc string
Specify NT3 test location (supported: GZ, SH, BJ, CD for Guangzhou, Shanghai, Beijing, Chengdu) (default "GZ")
-nt3t string
Set NT3 test type (supported: both, ipv4, ipv6) (default "ipv4")
-security
Enable/Disable security test (default true)
-speed
Enable/Disable speed test (default true)
-spnum int
Set the number of servers per operator for speed test (default 2)
-upload
Enable/Disable upload the result (default true)
-ut
Enable/Disable unlock media test (default true)
-v Display version information
Windows
- Download the compressed file with the .exe file: Releases
- After unzipping, right-click and run as administrator.
Docker
Expand to view how to use it
International image: https://hub.docker.com/r/spiritlhl/goecs
Please ensure Docker is installed on your machine before executing the following commands
Privileged mode + host network
docker run --rm --privileged --network host spiritlhl/goecs:latest -menu=false -l en
Unprivileged mode + non-host network
docker run --rm spiritlhl/goecs:latest -menu=false -l en
Using Docker to execute tests will result in some hardware testing bias and virtualization architecture detection failure. Direct testing is recommended over Docker testing.
Mirror image: https://cnb.cool/oneclickvirt/ecs/-/packages/docker/ecs
Please ensure Docker is installed on your machine before executing the following commands
Privileged mode + host network
docker run --rm --privileged --network host docker.cnb.cool/oneclickvirt/ecs:latest -menu=false -l en
Unprivileged mode + non-host network
docker run --rm docker.cnb.cool/oneclickvirt/ecs:latest -menu=false -l en
Compiling from source code
Expand to view compilation instructions
- Clone the public branch of the repository (without private dependencies)
git clone -b public https://github.com/oneclickvirt/ecs.git
cd ecs
- Install Go environment (skip if already installed)
Select go 1.24.5 version to install
curl -L https://cdn.spiritlhl.net/https://raw.githubusercontent.com/spiritLHLS/one-click-installation-script/main/install_scripts/go.sh -o go.sh && chmod +x go.sh && bash go.sh
- Compile
go build -o goecs
- Run test
./goecs -menu=false -l en
Supported compilation parameters:
- GOOS: supports linux, windows, darwin, freebsd, openbsd
- GOARCH: supports amd64, arm, arm64, 386, mips, mipsle, s390x, riscv64
Cross-platform compilation examples:
# Compile Windows version
GOOS=windows GOARCH=amd64 go build -o goecs.exe
# Compile MacOS version
GOOS=darwin GOARCH=amd64 go build -o goecs_darwin
QA
Q: Why is sysbench used by default instead of geekbench?
A: Comparing the characteristics of both:
Comparison | sysbench | geekbench |
---|---|---|
Application scope | Lightweight, runs on almost any server | Heavyweight, won't run on small machines |
Test requirements | No network needed, no special hardware requirements | Requires internet, IPv4 environment, minimum 1GB memory |
Open source status | Based on LUA, open source, can compile for various architectures | Official binaries are closed source, cannot compile your own version |
Test stability | Core test components unchanged for 10+ years | Each major version updates test items, making scores hard to compare between versions (each version benchmarks against current best CPUs) |
Test content | Only tests computing performance | Covers multiple performance aspects with weighted scores, though some tests aren't commonly used |
Suitable scenarios | Good for quick tests, focuses on computing performance | Good for comprehensive testing |
Ranking | sysbench.spiritlhl.net | browser.geekbench.com |
Note that goecs
allows you to specify CPU test method via parameters. The default is chosen for faster testing across more systems.
Q: Why use Golang instead of Rust for refactoring?
A: Because network-related projects currently trend toward Golang, with many components maintained by open source communities. Many Rust components would require building from scratch, I'm too lazy I don't have that technical capability.
Q: Why not continue developing the Shell version instead of refactoring?
A: Because there were too many varied environment issues. Pre-compiled binary files are easier for solving environment problems (better generalization).
Q: Are there explanations for each test item?
A: Each test project has its own maintenance repository. Click through to view the repository description.
Q: How do I manually terminate a test halfway through?
A: Press Ctrl+C to terminate the program. After termination, a goecs.txt file and share link will still be generated in the current directory containing information tested so far.
Q: How do I test in a non-Root environment?
A: Execute the installation command manually. If you can't install it, simply download the appropriate architecture package from releases, extract it, and run the file if you have execution permissions. Alternatively, use Docker if you can.
Thanks
Thank he.net bgp.tools ipinfo.io maxmind.com cloudflare.com ip.sb scamalytics.com abuseipdb.com ip2location.com ip-api.com ipregistry.co ipdata.co ipgeolocation.io ipwhois.io ipapi.com ipapi.is ipqualityscore.com bigdatacloud.com dkly.net virustotal.com and others for providing APIs for testing, and thanks to various websites on the Internet for providing query resources.
Thank
provided free hosting support for this open source project's shared test results storage
Thanks also to the following platforms for editorial and testing support

