Project Name | Stars | Downloads | Repos Using This | Packages Using This | Most Recent Commit | Total Releases | Latest Release | Open Issues | License | Language |
---|---|---|---|---|---|---|---|---|---|---|
Fiber | 29,391 | 1,434 | 13 hours ago | 294 | November 14, 2023 | 76 | mit | Go | ||
⚡️ Express inspired web framework written in Go | ||||||||||
Locust | 22,612 | 35 | 75 | 9 hours ago | 303 | December 03, 2023 | 9 | mit | Python | |
Write scalable load tests in plain Python 🚗💨 | ||||||||||
Fasthttp | 20,425 | 645 | 3,507 | a day ago | 187 | November 12, 2023 | 86 | mit | Go | |
Fast HTTP package for Go. Tuned for high performance. Zero memory allocations in hot paths. Up to 10x faster than net/http | ||||||||||
Nginx Admins Handbook | 12,393 | 2 years ago | 1 | mit | Shell | |||||
How to improve NGINX performance, security, and other important things. | ||||||||||
Artillery | 7,102 | 171 | 78 | 2 days ago | 295 | December 01, 2023 | 418 | mpl-2.0 | JavaScript | |
Load testing at cloud-scale, as easy as 1-2-3. Serverless & distributed out-of-the-box. Never fail to scale! | ||||||||||
Webserver | 6,818 | 2 months ago | 104 | mit | C++ | |||||
A C++ High Performance Web Server | ||||||||||
Web Frameworks | 6,797 | 13 hours ago | 13 | April 27, 2021 | 192 | mit | PHP | |||
Which is the fastest web framework? | ||||||||||
Vibora | 5,639 | 3 years ago | 145 | mit | Python | |||||
Fast, asynchronous and elegant Python web framework. | ||||||||||
Jsdelivr | 5,173 | 11 days ago | 39 | mit | JavaScript | |||||
A free, fast, and reliable Open Source CDN for npm, GitHub, Javascript, and ESM | ||||||||||
Bombardier | 4,774 | a month ago | 10 | October 15, 2020 | 16 | mit | Go | |||
Fast cross-platform HTTP benchmarking tool written in Go |
A global super-fast and production-focused CDN, tightly integrated with NPM and GitHub
with support for on-the-fly optimizations, ES modules, detailed download stats and more
Website Repo
·
Public API
·
Blog
·
@jsDelivr
·
Discord
We are looking for contributors. Please check open issues in the above repos if you think you could help, or open a new one if you have an idea you'd like to discuss.
jsDelivr is a free CDN for open-source files. We are tightly integrated with Github and npm, allowing us to automatically provide a reliable CDN service to almost every open-source project out there.
We offer a stable CDN that can be used in production on popular websites with huge amounts of traffic. There are no bandwidth limits or premium features, and it's completely free to use.
Our public CDN is built to be used in production by even the largest websites. Everything is optimized and constantly improved to offer all users maximum speed and uptime. Performance is monitored at all times, and we are always looking into new technologies and providers that may further improve our CDN. Downtime, timeouts, or slow responses are simply unacceptable.
We do everything possible to ensure our CDN will NEVER break any websites, regardless of the use case. If a file is available via our CDN, we assume it's used in production and ensure it will continue to work no matter what.
This includes dynamic endpoints such as /npm/
, /gh/
and /combine/
. When a file is first accessed, it gets permanently stored in a reliable file system. This means that even if a npm package gets deleted or an existing file gets removed by a developer, jsDelivr will continue to serve the stored copy forever without breaking any websites or causing any issues.
On top of that, we also do version fallback. This means that if a file used in version 1.0.1 is no longer available in 1.0.2 and a user requests the non-existent file, we will fall back to the previous 1.0.1 version and serve it instead of failing with a 404 error.
Unlike the competition, jsDelivr uses multiple CDN providers, resulting in the best possible uptime and performance. We currently use CloudFlare, and Fastly.
If a CDN goes down, websites that use jsDelivr won't have any issues because all traffic will be instantly redirected to remaining operational providers.
jsDelivr uses real user performance data (also known as RUM) to make its routing decisions. These metrics are gathered from hundreds of websites and are used in our load-balancing algorithm to make accurate decisions for serving content.
All providers (CDNs and custom servers) are tested millions of times per day by real users from all over the world. Based on this information, jsDelivr knows what provider is the fastest for each user. Each user gets a unique response based on his or her location, ISP, and the providers' uptime in real-time.
This system also responds immediately to performance degradation and downtime of providers. If a CDN is under a DDoS attack, and its performance drops in some locations, in a matter of seconds, the algorithm will pick up the change and start serving a different provider to all affected users.
We have multiple layers of failover to protect our users from any downtime.
We use 2 DNS providers at the same time. For jsDelivr to go down, both of these companies would have to go down at the same time.
Both of our DNS providers monitor our load-balanced endpoint, and if they detect problems, they will automatically switch all traffic to a single CDN provider.
Our load balancer monitors the uptime of all CDN providers using both RUM and synthetic data. If any of those detect downtime or performance degradation, that CDN provider will be removed immediately without any impact on our users.
Our origin consists of multiple servers in different data centers. If a server goes down, the CDNs will automatically switch to using the remaining healthy servers.
In total, we have one of the most resilient systems out there, ready to be used in production by even the biggest companies.
jsDelivr has multiple locations close to Chinese urban centers to ensure low latency and high performance for all Chinese users.
jsDelivr provides mirrors for npm, GitHub, WordPress plugins, and custom endpoints for several other projects with special requirements. If our regular endpoints don't work for your use case, let us know and we'll figure something out!
If you are a package author, check our tips for package authors to make using your package as easy as possible.
https://cdn.jsdelivr.net
jsDelivr can instantly serve any file from any npm package in the public registry. New versions pushed to npm are instantly available via our CDN as well. No maintenance is required.
If a package, version, or file gets removed from npm, then jsDelivr will continue to serve that file from our permanent storage without breaking any websites using it.
We use a permanent S3 storage to ensure all files remain available even if npm goes down or a package is deleted by its author. Files are fetched directly from npm only the first time or when S3 goes down.
/npm/package@version/file
/npm/[email protected]/dist/jquery.min.js
/npm/jquery@3/dist/jquery.min.js
/npm/[email protected]/dist/jquery.min.js
NOTE
If you use this feature and a file you requested is not available in the newest version of the package, the link will keep working thanks to our version-fallback feature. We'll continue to serve the file from the older version of the package instead of failing with a 404 error.
/npm/jquery@beta/dist/jquery.min.js
/npm/jquery@latest/dist/jquery.min.js
/npm/jquery/dist/jquery.min.js
NOTE Requesting the latest version (as opposed to "latest major" or "latest minor") is dangerous because major versions usually come with breaking changes. Only do this if you really know what you are doing.
/npm/[email protected]/github-markdown.min.css
NOTE Minifying a large file can take several seconds. However, we store all generated files in our permanent storage, so this delay only applies to the first few requests.
/npm/[email protected]
/npm/jquery@3
/npm/jquery
/npm/[email protected]/
/npm/[email protected]/dist/
We recommend using npm for projects that support it for better UX - npm packages are searchable on our website, and package pages show additional useful information, such as descriptions and links to homepages.
We use a permanent S3 storage to ensure all files remain available even if GitHub goes down or a repository or a release is deleted by its author. Files are fetched directly from GitHub only the first time or when S3 goes down.
/gh/user/repo@version/file
/gh/jquery/[email protected]/dist/jquery.min.js
/gh/jquery/jquery@32b00373b3f42e5cdcb709df53f3b08b7184a944/dist/jquery.min.js
/gh/jquery/jquery@3/dist/jquery.min.js
/gh/jquery/[email protected]/dist/jquery.min.js
NOTE If you use this feature and a file you requested is not available in the newest release, the link will keep working thanks to our version-fallback feature. We'll continue to serve the file from older release instead of failing with a 404 error.
Falls back to the master
branch if there are no tagged releases.
/gh/jquery/jquery@latest/dist/jquery.min.js
/gh/jquery/jquery/dist/jquery.min.js
NOTE Requesting the latest version (as opposed to "latest major" or "latest minor") is dangerous because major versions usually come with breaking changes. Only do this if you really know what you are doing.
/gh/jquery/[email protected]/src/core.min.js
NOTE Minifying a large file can take several seconds. However, we store all generated files in our permanent storage, so this delay only applies to the first few requests.
/gh/jquery/[email protected]/
/gh/jquery/[email protected]/dist/
Our combine endpoint allows you to load several files from npm and GitHub endpoints in one request:
/combine/url1,url2,url3
All features that work for individual files (version ranges, minification, main modules) work here as well. All combined files come with source maps and can be easily used during development.
Examples:
/combine/gh/jquery/[email protected]/dist/jquery.min.js,gh/twbs/[email protected]/dist/js/bootstrap.min.js
/combine/npm/[email protected]/dist/css/bootstrap.min.css,npm/[email protected]/dist/css/bootstrap-theme.min.css
NOTE Combining large/many files can take several seconds. However, we store all generated files in our permanent storage, so this delay only applies to the first few requests.
All packages hosted on npm and tagged releases on GitHub are automatically available on jsDelivr. If you are a package author, here are a few tips to make using your package as easy as possible:
main
in package.json
isn't meant to be used in a browser, set a browser
or jsdelivr
field
For packages hosted on npm, we support serving "default" files with shorter URLs. The default file can be configured by setting one of the following fields in package.json
, with jsdelivr
having the highest priority:
jsdelivr
browser
main
We will first attempt to locate a minified version of the file provided here (by removing the extension and looking for the same file .min.js
). If we can't find one, we will minify ourselves.
Be advised that you must include the file extension in the values, for example:
"main": "./index" // this will NOT work
"main": "./index.js" // this is the correct way
For projects having both a JS and a CSS file, use one the above fields for JS and a style
field for the CSS file (example).
Content-Type: text/plain
for security reasons.Our WordPress endpoint works for plugins and themes hosted in the WordPress.org plugin directory and Wordpress.org theme directory, and mirrors the WordPress.org plugins SVN repo.
/wp/project/tags/version/file
/wp/wp-slimstat/tags/4.6.5/wp-slimstat.js
/wp/wp-slimstat/trunk/wp-slimstat.js
https://cdn.jsdelivr.net/wp/themes/project/version/file
https://cdn.jsdelivr.net/wp/themes/twenty-eightteen/1.7/assets/js/html5.js
https://cdn.jsdelivr.net/wp/themes/twenty-eightteen/1.7/assets/js/html5.min.js
Our caching logic and headers are optimized for production use and apply to all non-custom endpoints.
latest
versions. They are cached on our CDN for 7 days with the option to purge the cache using our API to speed up the release of your project to your users.In certain cases, purgeable files can get updated faster due to low-cache hit ratio or forced CDN purge from our side for maintenance reasons.
We use permanent S3 caching even with dynamic URLs, such as version aliasing, meaning once we download your tagged files, there is no way for you to update them. If there is a critical issue in your latest release the best course of action is to tag a new semver valid release with the fix and purge the CDN URLs using our purge API.
jsDelivr has an easy-to-use API to purge files from the cache and force the files to update. This is useful when you release a new version and want to force the update of all version-aliased users.
Please note:
To avoid abuse, access to purge is given after an email request (for now - [email protected]).
We can work together and set up a custom configuration for your project. This way, you can have full control over your files and the ability to utilize the full power of jsDelivr.
This kind of custom hosting can be suitable for:
Simply send an email to [email protected] with a request for more information.
Current OSS projects using custom configs:
jsDelivr might use information about downloaded files to build download stats per project and per file.
jsDelivr does not store any user data and does not track any users in any way.
Here are the relevant policies of our CDN providers: