Snext is a Next.js application that lets you create API routes in Python.
Snext, because it sounds like "snake"?. You know, like a Python.
/! /! /! This is an early experiment
Hey, if you end up there, you are probably a JavaScript developer and Python is only your second language.
Here is how to setup an efficient Python environment.
I suggest using Pyenv to install Python. Consider it as an equivalent to Node Version Manager or Volta but for Python.
This is equivalent to using Volta or NVM in the Node ecosystem.
Python doesn't have a node_modules
folder. That's maybe for the best, however it makes it quite hard to
handle dependencies when you have a lot of projects on your machine.
A virtual environment is a bit similar: it will tell Python to install packages locally to your current project, and not globally.
The difference with Node is that you must enable them systematically.
Setup a Virtual environment and install the Python packages:
python3 -m venv ./venv
source ./venv/bin/activate
pip install -r requirements.txt
You need to activate the virtual env when you start working:
source ./venv/bin/activate
This command doesn't work in NPM scripts, sadly. You have to type it everytime.
vercel
CLI can solve our issues (see https://vercel.com/docs/cli#commands/dev) => done, it does!Use Vercel CLI instead of next dev
.
Vercel CLI command vercel dev
is able to simulate a serverless environment locally, so you can test your API routes.
If you put all API routes in ./api/
, and use vercel dev
, you can have both Python and Node.js API routes (and of course the Next.js frontend still works fine).
Read vercel/vercel#6197
When running Next, you'll want everything to run on localhost:3000
, but you'll have 2 servers: one for Node, one for Python. This require some rewriting logic to work.
Also, we may have multiple API routes, that will act as serverless functions when deployed. But locally, we must make them one server.
The recommended pattern to get static data from you API routes in Next, is to reuse the core logic of the route directly in getStaticProps
. But this is only possible because both are using JS. With Python, we would need to build the API routes first, run them, and then only build the frontend.
Needs to be tested with Vercel CLI.
We have this error https://github.com/vercel/community/discussions/103
in the latest version, the Python runtime seems too big.
See vercel/community#103 (comment)
See vercel/vercel#2830
See https://github.com/vercel/vercel/blob/main/errors/now-dev-as-dev-script.md
The script must be named smth else for instance dev:vercel
otherwise it creates an infinite loop.
No -
in folder names in Python, or you're gonna have a bad time importing files... Use underscore _
.
This may lead to messy URLs because the folder name is tied to the route name in Next.
(From my limited experience with Python) I'd tend to compare Flask or Falcon to Express: used a lot, minimal enough. But the blocking behaviour of Python can be very confusing to the JavaScript developer. So I'll go for Sanic, because it relies on async/await like Node.js and might be the least confusing.
Anyway, all knowledge gathered for one framework should be reusable for any other framework.
For simplification, we'll suppose a hosting on Vercel.
We may need a vercel.json
to tell Vercel which runtime to use:
https://vercel.com/docs/runtimes#advanced-usage/community-runtimes
Since Vercel dev works, we should expect Vercel deployment to work out of the box. To be tested.
In Python, you need a Virtual Environment to isolate your packages between apps, while in JS node_modules
plays this role. The problem is that the virtual environment must be activated when you start working, so that's an additional step for the developer.
To make it worse, the source
command that activate the environment cannot be (last time I've checked) put in package.json
, so you have to remember the right command everytime.
This is a Next.js project bootstrapped with create-next-app
.
First, run the development server:
npm run dev
# or
yarn dev
Open http://localhost:3000 with your browser to see the result.
You can start editing the page by modifying pages/index.js
. The page auto-updates as you edit the file.
API routes can be accessed on http://localhost:3000/api/hello. This endpoint can be edited in pages/api/hello.js
.
The pages/api
directory is mapped to /api/*
. Files in this directory are treated as API routes instead of React pages.
To learn more about Next.js, take a look at the following resources:
You can check out the Next.js GitHub repository - your feedback and contributions are welcome!
The easiest way to deploy your Next.js app is to use the Vercel Platform from the creators of Next.js.
Check out our Next.js deployment documentation for more details.