From 8848ad3ff48ae3f0e7c2026877537d1f7c6d4172 Mon Sep 17 00:00:00 2001 From: FirstClear <32212332+FirstClear@users.noreply.github.com> Date: Tue, 5 Aug 2025 19:53:13 +0800 Subject: [PATCH] feat(ci): Frontend supports Docker build. (#580) --- docker/docker-compose.yml | 25 ++++++++++-- docker/nginx/conf.d/default.conf | 65 ++++++++++++++++++++++++++++++++ docker/nginx/nginx.conf | 14 +++++++ docker/nginx/ssl/.gitkeep | 0 frontend/.dockerignore | 24 ++++++++++++ frontend/Dockerfile | 54 ++++++++++++++++++++++++++ 6 files changed, 179 insertions(+), 3 deletions(-) create mode 100644 docker/nginx/conf.d/default.conf create mode 100644 docker/nginx/nginx.conf create mode 100644 docker/nginx/ssl/.gitkeep create mode 100644 frontend/.dockerignore create mode 100644 frontend/Dockerfile diff --git a/docker/docker-compose.yml b/docker/docker-compose.yml index 18dee843..a99332b5 100755 --- a/docker/docker-compose.yml +++ b/docker/docker-compose.yml @@ -349,12 +349,12 @@ services: restart: always container_name: coze-server env_file: *env_file - environment: - LISTEN_ADDR: 0.0.0.0:8888 + # environment: + # LISTEN_ADDR: 0.0.0.0:8888 networks: - coze-network ports: - - '8888:8888' + # - '8888:8888' - '8889:8889' volumes: - .env:/app/.env @@ -371,6 +371,25 @@ services: condition: service_healthy milvus: condition: service_healthy + command: ['/app/opencoze'] + + coze-frontend: + build: + context: .. + dockerfile: frontend/Dockerfile + container_name: coze-frontend + restart: always + ports: + - "8888:80" + # - "443:443" # SSL port (uncomment if using SSL) + volumes: + - ./nginx/nginx.conf:/etc/nginx/nginx.conf:ro # Main nginx config + - ./nginx/conf.d/default.conf:/etc/nginx/conf.d/default.conf:ro # Proxy config + # - ./nginx/ssl:/etc/nginx/ssl:ro # SSL certificates (uncomment if using SSL) + depends_on: + - coze-server + networks: + - coze-network networks: coze-network: diff --git a/docker/nginx/conf.d/default.conf b/docker/nginx/conf.d/default.conf new file mode 100644 index 00000000..fca53b99 --- /dev/null +++ b/docker/nginx/conf.d/default.conf @@ -0,0 +1,65 @@ +server { + listen 80; + server_name _; + + # Static resources + location / { + root /usr/share/nginx/html; + try_files $uri $uri/ /index.html; + index index.html index.htm; + autoindex on; + autoindex_exact_size off; + autoindex_localtime on; + } + + # API proxy + location /api/ { + proxy_pass http://coze-server:8888; + + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + + # SSL/TLS settings + proxy_ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3; + proxy_ssl_verify off; + } +} + +# if you want to use https, you can uncomment the following code +# server { +# listen 443 ssl; +# server_name _; + +# ssl_certificate /etc/nginx/ssl/pem; +# ssl_certificate_key /etc/nginx/ssl/key; +# ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3; +# ssl_prefer_server_ciphers on; +# ssl_session_cache shared:SSL:10m; +# ssl_session_timeout 10m; + +# # Static resources +# location / { +# root /usr/share/nginx/html; +# try_files $uri $uri/ /index.html; +# index index.html index.htm; +# autoindex on; +# autoindex_exact_size off; +# autoindex_localtime on; +# } + +# # API proxy +# location /api/ { +# proxy_pass https://coze-server:8888; + +# proxy_set_header Host $host; +# proxy_set_header X-Real-IP $remote_addr; +# proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; +# proxy_set_header X-Forwarded-Proto $scheme; + +# # SSL/TLS settings +# proxy_ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3; +# proxy_ssl_verify off; +# } +# } \ No newline at end of file diff --git a/docker/nginx/nginx.conf b/docker/nginx/nginx.conf new file mode 100644 index 00000000..41e04c4b --- /dev/null +++ b/docker/nginx/nginx.conf @@ -0,0 +1,14 @@ +worker_processes 1; +events { worker_connections 1024; } + +http { + include mime.types; + default_type application/octet-stream; + sendfile on; + keepalive_timeout 65; + + # setting client request body size limit - 0 means no limit + client_max_body_size 0; + + include /etc/nginx/conf.d/*.conf; +} \ No newline at end of file diff --git a/docker/nginx/ssl/.gitkeep b/docker/nginx/ssl/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/frontend/.dockerignore b/frontend/.dockerignore new file mode 100644 index 00000000..31eb66c2 --- /dev/null +++ b/frontend/.dockerignore @@ -0,0 +1,24 @@ +.env +.env.* + +# Logs +logs +*.log* + +# node +node_modules +.husky +.next + +# vscode +.vscode + +# webstorm +.idea +*.iml +*.iws +*.ipr + + +# Jetbrains +.idea diff --git a/frontend/Dockerfile b/frontend/Dockerfile new file mode 100644 index 00000000..72e075db --- /dev/null +++ b/frontend/Dockerfile @@ -0,0 +1,54 @@ +# Build stage +FROM node:22-alpine AS builder + +WORKDIR /app + +# if you located in China, you can use aliyun mirror to speed up +RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories + +# Install bash git dos2unix for TypeScript compiler +RUN apk add --no-cache bash git dos2unix + +# if you located in China, you can use aliyun mirror to speed up +RUN npm config set registry https://registry.npmmirror.com + +# Copy rush.json from root directory first +COPY rush.json ./ + +# Install rush with retry logic +RUN npm install -g @microsoft/rush + +# Copy the frontend source code (excluding node_modules and build artifacts) +COPY frontend/ ./frontend/ + +# Copy common directory for Rush +COPY common/ ./common/ + +# Copy scripts directory for Rush hooks +COPY scripts/ ./scripts/ + +# Convert line endings for shell scripts in scripts directory to Unix format +RUN find . -name "*.sh" -type f -exec dos2unix {} \; + +# Install all dependencies +RUN rush install + +# Use rush build to build the specific project +RUN rush build --to @coze-studio/app + +# Production image stage +FROM nginx:1.25-alpine + + +# if you located in China, you can use aliyun mirror to speed up +RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories +# Install necessary tools for SSL configuration +RUN apk add --no-cache bash + +# Copy build artifacts to nginx static directory +COPY --from=builder /app/frontend/apps/coze-studio/dist /usr/share/nginx/html + +EXPOSE 8888 + +# Start nginx +CMD ["nginx", "-g", "daemon off;"]