Skip to content

Latest commit

 

History

History

genai-stack

GenAI Stack

This project is based in https://github.com/docker/genai-stack

Configure

MacOS and Linux users can use any LLM that's available via Ollama.

Check the "tags" section under the model page you want to use on https://ollama.ai/library and write the tag for the value of the environment variable LLM= in the .env file.

All platforms can use GPT-3.5-turbo and GPT-4 (bring your own API keys for OpenAIs models).

MacOS Install Ollama on MacOS and start it before running docker compose up.

Linux No need to install Ollama manually, it will run in a container as part of the stack when running with the Linux profile: run docker compose --profile linux up. Make sure to set the OLLAMA_BASE_URL=http://llm:11434 in the .env file when using Ollama docker container.

Windows Not supported by Ollama, so Windows users need to generate a OpenAI API key and configure the stack to use gpt-3.5 or gpt-4 in the .env file.

Summary properties

Modify environment variables in .env file to specify your preferences.

SUMMARY_LANGUAGE=Brazilian # Any language name supported by LLM
SUMMARY_SIZE=120 # Number of words for the summary
TAGS_NUMBER=3 # Number of tags to be identified for classification

Develop

Warning

There is a performance issue that impacts python applications in the latest release of Docker Desktop. Until a fix is available, please use version 4.23.0 or earlier.

To start everything

docker compose up

If changes to build scripts has been made, rebuild.

docker compose up --build

Shutdown If health check fails or containers don't start up as expected, shutdown completely to start up again.

docker compose down

Applications

The database can be explored at http://localhost:7474.

App - Summarizer API

Endpoints:

Example cURL command:

curl --location 'http://localhost:8506/summary' \
--form 'file=@"/tmp/document.pdf"'

Exposes the functionality to get a summary as text and a list of tags from a PDF file.

Example cURL command:

curl --location 'http://localhost:8506/prompt?prompt=Question' \
--form 'file=@"/tmp/document.pdf"'

Exposes the functionality to get an answer to a question from a PDF file.