2018-10-02 10:40:08 +00:00
|
|
|
|
2018-10-02 10:47:49 +00:00
|
|
|
Starlette includes a `BackgroundTask` class for in-process background tasks.
|
|
|
|
|
|
|
|
A background task should be attached to a response, and will run only once
|
|
|
|
the response has been sent.
|
2018-10-02 10:40:08 +00:00
|
|
|
|
|
|
|
### Background Task
|
|
|
|
|
2018-12-14 14:56:31 +00:00
|
|
|
Used to add a single background task to a response.
|
|
|
|
|
2018-10-05 15:38:02 +00:00
|
|
|
Signature: `BackgroundTask(func, *args, **kwargs)`
|
2018-10-02 10:40:08 +00:00
|
|
|
|
|
|
|
```python
|
|
|
|
from starlette.applications import Starlette
|
|
|
|
from starlette.responses import JSONResponse
|
2019-11-13 12:25:18 +00:00
|
|
|
from starlette.routing import Route
|
2018-10-02 10:40:08 +00:00
|
|
|
from starlette.background import BackgroundTask
|
|
|
|
|
|
|
|
|
2019-11-13 12:25:18 +00:00
|
|
|
...
|
|
|
|
|
2018-10-02 10:47:49 +00:00
|
|
|
async def signup(request):
|
|
|
|
data = await request.json()
|
|
|
|
username = data['username']
|
|
|
|
email = data['email']
|
|
|
|
task = BackgroundTask(send_welcome_email, to_address=email)
|
|
|
|
message = {'status': 'Signup successful'}
|
|
|
|
return JSONResponse(message, background=task)
|
|
|
|
|
|
|
|
async def send_welcome_email(to_address):
|
|
|
|
...
|
2019-11-13 12:25:18 +00:00
|
|
|
|
|
|
|
|
|
|
|
routes = [
|
|
|
|
...
|
|
|
|
Route('/user/signup', endpoint=signup, methods=['POST'])
|
|
|
|
]
|
|
|
|
|
|
|
|
app = Starlette(routes=routes)
|
2018-10-02 10:47:49 +00:00
|
|
|
```
|
2018-12-14 14:56:31 +00:00
|
|
|
|
|
|
|
### BackgroundTasks
|
|
|
|
|
|
|
|
Used to add multiple background tasks to a response.
|
|
|
|
|
|
|
|
Signature: `BackgroundTasks(tasks=[])`
|
|
|
|
|
|
|
|
```python
|
|
|
|
from starlette.applications import Starlette
|
|
|
|
from starlette.responses import JSONResponse
|
|
|
|
from starlette.background import BackgroundTasks
|
|
|
|
|
|
|
|
async def signup(request):
|
|
|
|
data = await request.json()
|
|
|
|
username = data['username']
|
|
|
|
email = data['email']
|
|
|
|
tasks = BackgroundTasks()
|
|
|
|
tasks.add_task(send_welcome_email, to_address=email)
|
|
|
|
tasks.add_task(send_admin_notification, username=username)
|
|
|
|
message = {'status': 'Signup successful'}
|
|
|
|
return JSONResponse(message, background=tasks)
|
|
|
|
|
|
|
|
async def send_welcome_email(to_address):
|
|
|
|
...
|
|
|
|
|
|
|
|
async def send_admin_notification(username):
|
|
|
|
...
|
|
|
|
|
2019-11-13 12:25:18 +00:00
|
|
|
routes = [
|
|
|
|
Route('/user/signup', endpoint=signup, methods=['POST'])
|
|
|
|
]
|
|
|
|
|
|
|
|
app = Starlette(routes=routes)
|
2018-12-14 14:56:31 +00:00
|
|
|
```
|
2022-04-24 06:17:07 +00:00
|
|
|
|
|
|
|
!!! important
|
|
|
|
The tasks are executed in order. In case one of the tasks raises
|
|
|
|
an exception, the following tasks will not get the opportunity to be executed.
|