测速站点

Stefan Stidl ab86aab10f http fetch timeout fix 3 zile în urmă
.github 21d3fb0260 ci: use npm ci and track package-lock for reproducible e2e 3 zile în urmă
.logo 8be8aba5ed Fixed typo in results/index.php 5 ani în urmă
backend f1f48ae53e fix: return client IPv6 address via cloudflared (#757) 1 lună în urmă
docker 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
examples a3ed06699f Add alt attribute to speed test results image for accessibility (#731) 4 luni în urmă
frontend 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
results 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
tests ab86aab10f http fetch timeout fix 3 zile în urmă
.eslintrc.json 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
.gitignore 21d3fb0260 ci: use npm ci and track package-lock for reproducible e2e 3 zile în urmă
.prettierignore cb265a2d91 add eslinter, update github actions (stale issues, dependabot), optimize docker image (#728) 4 luni în urmă
.prettierrc.json 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
DESIGN_SWITCH.md c4ce1d2731 doc: design-switch 3 zile în urmă
DEVELOPMENT.md cb265a2d91 add eslinter, update github actions (stale issues, dependabot), optimize docker image (#728) 4 luni în urmă
Dockerfile 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
Dockerfile.alpine 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
LICENSE 8be8aba5ed Fixed typo in results/index.php 5 ani în urmă
README.md c4ce1d2731 doc: design-switch 3 zile în urmă
config.json 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
design-switch.js 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
doc.md 1a45664d81 version strings sync 3 zile în urmă
doc_docker.md 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
favicon.ico 8be8aba5ed Fixed typo in results/index.php 5 ani în urmă
index-classic.html 6693c7ee2c Cherry-pick: revert "Use server-list.json in classic frontend by default" (#776) 3 zile în urmă
index-modern.html 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
index.html 3a7dc31ff2 Implement the new design from #649 (#694) 4 zile în urmă
package-lock.json 21d3fb0260 ci: use npm ci and track package-lock for reproducible e2e 3 zile în urmă
package.json 49f54a5c3c add e2e testing (#777) 3 zile în urmă
playwright.config.js 49f54a5c3c add e2e testing (#777) 3 zile în urmă
speedtest.js 6693c7ee2c Cherry-pick: revert "Use server-list.json in classic frontend by default" (#776) 3 zile în urmă
speedtest_worker.js 2b53bbae54 Changed var to the let/const because it's completely supported by IE11 and all other browsers since 2015. (#656) 1 an în urmă

README.md

LibreSpeed Logo

LibreSpeed

No Flash, No Java, No Websocket, No Bullshit.

This is a very lightweight speed test implemented in Javascript, using XMLHttpRequest and Web Workers.

Try it

Take a speed test

Compatibility

All modern browsers are supported: IE11, latest Edge, latest Chrome, latest Firefox, latest Safari. Works with mobile versions too.

Features

  • Download
  • Upload
  • Ping
  • Jitter
  • IP Address, ISP, distance from server (optional)
  • Telemetry (optional)
  • Results sharing (optional)
  • Multiple Points of Test (optional)

Screenrecording of a running Speedtest

Server requirements

  • A reasonably fast web server with Apache 2 (nginx, IIS also supported)
  • PHP 5.4 or newer (other backends also available)
  • MariaDB or MySQL database to store test results (optional, Microsoft SQL Server, PostgreSQL and SQLite also supported)
  • A fast! internet connection

Installation

Assuming you have PHP and a web server installed, the installation steps are quite simple.

  1. Download the source code and extract it
  2. Copy the following files to your web server's shared folder (ie. /var/www/html/speedtest for Apache): index.html, speedtest.js, speedtest_worker.js, favicon.ico and the backend folder
  3. Optionally, copy the results folder too, and set up the database using the config file in it.
  4. Be sure your permissions allow execute (755).
  5. Visit YOURSITE/speedtest/index.html and voila!

Installation Video

This video shows the installation process of a standalone LibreSpeed server: Quick start installation guide for Debian 12

More videos will be added later.

Android app

A template to build an Android client for your LibreSpeed installation is available here.

CLI client

A command line client is available here.

.NET client

A .NET client library is available in the LibreSpeed.NET repo (NuGet), maintained by MemphiZ.

Development

If you want to contribute or develop with LibreSpeed, see DEVELOPMENT.md for information about using npm for development tasks, linting, and formatting.

Design switch

LibreSpeed supports both the classic and modern UI. The root index.html acts as a lightweight switcher and redirects to index-classic.html or index-modern.html based on config.json (useNewDesign) or URL overrides (?design=new / ?design=old). For architecture and deployment details (including Docker behavior), see DESIGN_SWITCH.md.

Docker

A docker image is available on GitHub, check our docker documentation for more info about it. The image is built every week to include an updated version of the ipinfo-DB used for ISP detection. Also this ensures, that the latest security patches in PHP are installed. Therefore we recommend to use the latest image.

Go backend

A Go implementation is available in the speedtest-go repo, maintained by Maddie Zhan.

Rust backend

A Rust implementation is available in the speedtest-rust repo, maintained by Sudo Dios.

Node.js backend

A partial Node.js implementation is available in the node branch, developed by dunklesToast. It's not recommended to use at the moment.

Donate

Donate with Liberapay Donate with PayPal

License

Copyright (C) 2016-2024 Federico Dossena

This program is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU Lesser General Public License along with this program. If not, see https://www.gnu.org/licenses/lgpl.