pyodide/docs/usage/downloading-and-deploying.md

54 lines
2.3 KiB
Markdown
Raw Normal View History

(downloading_deploying)=
# Downloading and deploying Pyodide
## Downloading Pyodide
### CDN
2022-06-22 03:15:37 +00:00
Pyodide is available from the JsDelivr CDN
| channel | indexURL | Comments | REPL |
| ------------------- | -------------------------------------------- | ---------------------------------------------------------------------------------------- | -------------------------------------------------- |
| Latest release | `{{PYODIDE_CDN_URL}}` | Recommended, cached by the browser | [link](https://pyodide.org/en/stable/console.html) |
| Dev (`main` branch) | `https://cdn.jsdelivr.net/pyodide/dev/full/` | Re-deployed for each commit on main, no browser caching, should only be used for testing | [link](https://pyodide.org/en/latest/console.html) |
2021-11-14 20:47:49 +00:00
### GitHub releases
2021-11-14 20:47:49 +00:00
You can also download Pyodide packages from [GitHub
releases](https://github.com/pyodide/pyodide/releases). The full distribution
including all vendored packages is available as `pyodide-{{VERSION}}.tar.bz2`.
The full distribution is quite large (200+ megabytes). The minimal set of files
needed to start Pyodide is included as `pyodide-core-{{VERSION}}.tar.bz2`. It is
intended for use with node which will automatically install missing packages
from the cdn -- it is the same set of files that are installed if you use `npm
install pyodide`. It may also be convenient for other purposes.
2022-06-22 03:15:37 +00:00
You will need to serve these files yourself.
(serving_pyodide_packages)=
## Serving Pyodide packages
### Serving locally
With Python 3.7.5+ you can serve Pyodide files locally with {py:mod}`http.server`:
```
python -m http.server
```
2022-06-22 03:15:37 +00:00
from the Pyodide distribution folder. Navigate to
[http://localhost:8000/console.html](http://localhost:8000/console.html) and
the Pyodide repl should load.
### Remote deployments
2022-06-22 03:15:37 +00:00
Any service that hosts static files and that correctly sets the WASM MIME type
and CORS headers will work. For instance, you can use GitHub Pages or similar
services.
2022-06-22 03:15:37 +00:00
For additional suggestions for optimizing the size and load time for Pyodide,
see the [Emscripten documentation about
deployments](https://emscripten.org/docs/compiling/Deploying-Pages.html).