From ef6ec54a0d8916617e612989b944afe16fbd693e Mon Sep 17 00:00:00 2001 From: LatentDream Date: Wed, 11 Dec 2024 08:51:40 -0500 Subject: [PATCH] [Doc] Vizro example (#298) * [Doc] Deploy `Vizro` apps * [Doc] Vizro Template * [Example] Virzo Template chore: split installation process * [Example] Start the Flask server directly | otherwise, warning in the logs * [Doc] Start the Flask server directly | otherwise, warning in the logs --- doc/_toc.yml | 1 + doc/apps/vizro.md | 106 ++++++++++++++++++ .../opengraph/opengraph-images-vizro.png | Bin 0 -> 3933 bytes examples/docker/vizro/Dockerfile | 24 ++++ examples/docker/vizro/app.py | 23 ++++ examples/docker/vizro/readme.md | 3 + examples/docker/vizro/requirements.txt | 1 + 7 files changed, 158 insertions(+) create mode 100644 doc/apps/vizro.md create mode 100755 doc/static/opengraph/opengraph-images-vizro.png create mode 100644 examples/docker/vizro/Dockerfile create mode 100644 examples/docker/vizro/app.py create mode 100644 examples/docker/vizro/readme.md create mode 100644 examples/docker/vizro/requirements.txt diff --git a/doc/_toc.yml b/doc/_toc.yml index 1c49e687..a7e23b62 100644 --- a/doc/_toc.yml +++ b/doc/_toc.yml @@ -45,6 +45,7 @@ parts: - file: apps/docker - file: apps/chainlit - file: apps/hyperdiv + - file: apps/vizro - caption: APIs chapters: diff --git a/doc/apps/vizro.md b/doc/apps/vizro.md new file mode 100644 index 00000000..0d8b31be --- /dev/null +++ b/doc/apps/vizro.md @@ -0,0 +1,106 @@ +--- +myst: + html_meta: + description: Deploy a Vizro app on Ploomber in seconds with this guide. + keywords: vizro, deployment, hosting + property=og:title: Vizro | Ploomber Docs + property=og:description: Deploy Vizro app on Ploomber in seconds with this guide. + property=og:image: https://docs.cloud.ploomber.io/en/latest/_static/opengraph-images-vizro.png + property=og:url: https://docs.cloud.ploomber.io/en/latest/apps/vizro.html +--- + +# Vizro + +To deploy a [Vizro](https://vizro.readthedocs.io/en/stable/) application you need a [Ploomber Cloud](https://platform.ploomber.io/register?utm_source=dash&utm_medium=documentation) account. + +## Project Structure + +Your deployment package must include these three essential files: + +1. `app.py` - Main application file +2. `requirements.txt` - Python dependencies +3. `Dockerfile` - Container configuration + +```{note} +You can get started quickly using our [template repository](https://github.com/ploomber/doc/tree/main/examples/docker/vizro) +``` + +## Application Setup + +1. Main Application File (`app.py`) + +Your `app.py` should initialize the Vizro application as follows: + +```python +import vizro as vm +from vizro import Vizro + +# Initialize your dashboard +dashboard = vm.Dashboard(pages=[page]) + +# Create the application instance +app = Vizro().build(dashboard) + +# Expose the Flask server to Gunicorn +server = app.dash.server + +# Development server (optional) +if __name__ == "__main__": + app.run() +``` + +2. Dependencies File (`requirements.txt`) + +List all Python packages required by your application. + +3. `Dockerfile` + +Create a `Dockerfile` with this configuration: + +```Dockerfile +FROM python:3.11-slim + +WORKDIR /app + +# Install dependencies +COPY requirements.txt . +RUN pip install --no-cache-dir -r requirements.txt gunicorn vizro + +# Copy application files +COPY . . + +# Configure the container +EXPOSE 80 +ENTRYPOINT ["gunicorn", "app:server", "run", "--bind", "0.0.0.0:80"] +``` + +## Testing locally + +Before deployment, test your application locally using Docker: + +```sh +# build the docker image +docker build . -t vizro-app + +# run it +docker run -p 5000:80 vizro-app +Now, open http://0.0.0.0:5000/ to see your app. +``` + +Once running, access your application at http://localhost:5000 + +## Deploy + +Deployment Process + +1. Zip all project files (`app.py`, `requirements.txt`, `Dockerfile`, and any additional resources) +2. Log in to Ploomber Cloud +3. Navigate to the deployment menu +4. Select the Docker deployment option +5. Upload your zip file + +![](../static/docker.png) + +```{tip} +To ensure your app doesn't break on re-deployments, pin your [dependencies.](pin-dependencies) +``` diff --git a/doc/static/opengraph/opengraph-images-vizro.png b/doc/static/opengraph/opengraph-images-vizro.png new file mode 100755 index 0000000000000000000000000000000000000000..fb7624b922391d9e4b294d9068f47f8ab958b7b2 GIT binary patch literal 3933 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 literal 0 HcmV?d00001 diff --git a/examples/docker/vizro/Dockerfile b/examples/docker/vizro/Dockerfile new file mode 100644 index 00000000..6af91596 --- /dev/null +++ b/examples/docker/vizro/Dockerfile @@ -0,0 +1,24 @@ +FROM python:3.11-slim + +# Set environment variables +ENV PYTHONUNBUFFERED=1 \ + PYTHONDONTWRITEBYTECODE=1 \ + PIP_NO_CACHE_DIR=off \ + PIP_DISABLE_PIP_VERSION_CHECK=on + +# Set work directory +WORKDIR /app + +# Install Python dependencies +RUN pip install gunicorn +COPY requirements.txt . +RUN pip install --no-cache-dir -r requirements.txt + +# Copy project files +COPY . . + +# Expose the port +EXPOSE 8000 + +# Run the application using Gunicorn +ENTRYPOINT ["gunicorn", "app:server", "run", "--bind", "0.0.0.0:80"] diff --git a/examples/docker/vizro/app.py b/examples/docker/vizro/app.py new file mode 100644 index 00000000..ba378f7f --- /dev/null +++ b/examples/docker/vizro/app.py @@ -0,0 +1,23 @@ +import vizro.plotly.express as px +from vizro import Vizro +import vizro.models as vm + +df = px.data.iris() + +page = vm.Page( + title="My first dashboard", + components=[ + vm.Graph(figure=px.scatter(df, x="sepal_length", y="petal_width", color="species")), + vm.Graph(figure=px.histogram(df, x="sepal_width", color="species")), + ], + controls=[ + vm.Filter(column="species", selector=vm.Dropdown(value=["ALL"])), + ], +) + +dashboard = vm.Dashboard(pages=[page]) +app = Vizro().build(dashboard) +server = app.dash.server + +if __name__ == "__main__": + app.run() diff --git a/examples/docker/vizro/readme.md b/examples/docker/vizro/readme.md new file mode 100644 index 00000000..aa04f955 --- /dev/null +++ b/examples/docker/vizro/readme.md @@ -0,0 +1,3 @@ +# Docker Deployment with Virzo App + +Template Dockerfile and Vizro app to deploy on Ploomber Cloud. diff --git a/examples/docker/vizro/requirements.txt b/examples/docker/vizro/requirements.txt new file mode 100644 index 00000000..6f996cb0 --- /dev/null +++ b/examples/docker/vizro/requirements.txt @@ -0,0 +1 @@ +vizro==0.1.29