(improvement)(chat) It supports successful startup using Docker, local, and other methods. If the Chroma store creation fails, it will be replaced with in-memory (#1301)

This commit is contained in:
lexluo09
2024-06-30 20:15:46 +08:00
committed by GitHub
parent b56abd7348
commit c8b6af4887
8 changed files with 14391 additions and 16488 deletions

View File

@@ -7,7 +7,7 @@ WORKDIR /usr/src/app
# Argument to pass in the supersonic version at build time
ARG SUPERSONIC_VERSION
# Install the Vim editor.
# Install the vim editor.
RUN apt-get update && \
apt-get install -y vim && \
rm -rf /var/lib/apt/lists/*

View File

@@ -1,4 +1,29 @@
#!/usr/bin/env bash
# Please execute the "supersonic-build.sh" command first
# to generate the corresponding zip package in the "assembly/build/" directory.
docker build --no-cache --build-arg SUPERSONIC_VERSION=$1 -t supersonic:$1 -f docker/Dockerfile .
# Function to execute the build script
execute_build_script() {
echo "Executing build script: assembly/bin/supersonic-build.sh"
assembly/bin/supersonic-build.sh
}
# Function to build the Docker image
build_docker_image() {
local version=$1
echo "Building Docker image: supersonic:$version"
docker build --no-cache --build-arg SUPERSONIC_VERSION=$version -t supersonic:$version -f docker/Dockerfile .
if [ $? -ne 0 ]; then
echo "Docker build failed. Exiting."
exit 1
fi
echo "Docker image supersonic:$version built successfully."
}
# Main script execution
VERSION=$1
if [ -z "$VERSION" ]; then
echo "Usage: $0 <version>"
exit 1
fi
execute_build_script
build_docker_image $VERSION

View File

@@ -1,15 +1,13 @@
version: '3.8'
services:
mysql:
image: mysql:8.0
container_name: supersonic_mysql
environment:
MYSQL_ROOT_PASSWORD: root_password
MYSQL_DB_HOST: ${DB_HOST}
MYSQL_DATABASE: ${DB_NAME}
MYSQL_USER: ${DB_USERNAME}
MYSQL_PASSWORD: ${DB_PASSWORD}
MYSQL_DATABASE: supersonic_db
MYSQL_USER: supersonic_user
MYSQL_PASSWORD: supersonic_password
ports:
- "3306:3306"
volumes:
@@ -30,9 +28,9 @@ services:
command: >
sh -c "
sleep 30 &&
if ! mysql -h supersonic_mysql -uroot -proot_password -e 'use supersonic_db; show tables;' | grep -q 's2_database'; then
mysql -h supersonic_mysql -uroot -proot_password supersonic_db < /usr/src/app/supersonic-standalone-0.9.2-SNAPSHOT/conf/db/schema-mysql.sql &&
mysql -h supersonic_mysql -uroot -proot_password supersonic_db < /usr/src/app/supersonic-standalone-0.9.2-SNAPSHOT/conf/db/data-mysql.sql
if ! mysql -h supersonic_mysql -usupersonic_user -psupersonic_password -e 'use supersonic_db; show tables;' | grep -q 's2_database'; then
mysql -h supersonic_mysql -usupersonic_user -psupersonic_password supersonic_db < /usr/src/app/supersonic-standalone-0.9.2-SNAPSHOT/conf/db/schema-mysql.sql &&
mysql -h supersonic_mysql -usupersonic_user -psupersonic_password supersonic_db < /usr/src/app/supersonic-standalone-0.9.2-SNAPSHOT/conf/db/data-mysql.sql
else
echo 'Database already initialized.'
fi