web修改
This commit is contained in:
@@ -32,7 +32,6 @@ docker/**/volumes/
|
|||||||
**/node_modules/
|
**/node_modules/
|
||||||
|
|
||||||
# 排除构建产物(保留 JAR 文件)
|
# 排除构建产物(保留 JAR 文件)
|
||||||
**/dist/
|
|
||||||
**/build/
|
**/build/
|
||||||
# 排除 target 下的非 JAR 文件
|
# 排除 target 下的非 JAR 文件
|
||||||
**/target/classes/
|
**/target/classes/
|
||||||
|
|||||||
@@ -17,14 +17,11 @@ services:
|
|||||||
environment:
|
environment:
|
||||||
TZ: Asia/Shanghai
|
TZ: Asia/Shanghai
|
||||||
volumes:
|
volumes:
|
||||||
- ${DATA_ROOT:-../volumes}/nginx/logs:/var/log/nginx
|
- ./volumes/nginx/logs:/var/log/nginx
|
||||||
- ./nginx/nginx.conf:/etc/nginx/nginx.conf:ro
|
- ./volumes/nginx.conf:/etc/nginx/nginx.conf:ro
|
||||||
- ./nginx/conf.d:/etc/nginx/conf.d:ro
|
- ./volumes/conf.d:/etc/nginx/conf.d:ro
|
||||||
# SSL 证书(可选)
|
# SSL 证书(可选)
|
||||||
# - ./nginx/ssl:/etc/nginx/ssl:ro
|
# - ./nginx/ssl:/etc/nginx/ssl:ro
|
||||||
depends_on:
|
|
||||||
- urban-lifeline-serv
|
|
||||||
- urban-lifeline-web
|
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: ["CMD", "curl", "-f", "http://localhost/health"]
|
test: ["CMD", "curl", "-f", "http://localhost/health"]
|
||||||
interval: 30s
|
interval: 30s
|
||||||
|
|||||||
131
docker/nginx/volumes/conf.d/default.conf
Normal file
131
docker/nginx/volumes/conf.d/default.conf
Normal file
@@ -0,0 +1,131 @@
|
|||||||
|
# ================================================
|
||||||
|
# Urban Lifeline - 站点配置 (All-in-One 模式)
|
||||||
|
# ================================================
|
||||||
|
|
||||||
|
# 上游服务定义 - 后端 All-in-One 容器
|
||||||
|
upstream gateway {
|
||||||
|
server urban-lifeline-serv:8080;
|
||||||
|
keepalive 32;
|
||||||
|
}
|
||||||
|
|
||||||
|
# 上游服务定义 - 前端 All-in-One 容器
|
||||||
|
upstream shared {
|
||||||
|
server urban-lifeline-web:8000;
|
||||||
|
}
|
||||||
|
|
||||||
|
upstream platform {
|
||||||
|
server urban-lifeline-web:8001;
|
||||||
|
}
|
||||||
|
|
||||||
|
upstream workcase-web {
|
||||||
|
server urban-lifeline-web:8002;
|
||||||
|
}
|
||||||
|
|
||||||
|
upstream bidding-web {
|
||||||
|
server urban-lifeline-web:8003;
|
||||||
|
}
|
||||||
|
|
||||||
|
upstream workcase-wechat {
|
||||||
|
server urban-lifeline-web:8004;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
server_name localhost;
|
||||||
|
|
||||||
|
# 健康检查端点
|
||||||
|
location /health {
|
||||||
|
access_log off;
|
||||||
|
return 200 "healthy\n";
|
||||||
|
add_header Content-Type text/plain;
|
||||||
|
}
|
||||||
|
|
||||||
|
# ====================== 前端应用代理 ======================
|
||||||
|
|
||||||
|
# Shared 公共模块 (Module Federation 远程模块)
|
||||||
|
location /shared/ {
|
||||||
|
proxy_pass http://shared/;
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
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;
|
||||||
|
|
||||||
|
# 允许跨域 (Module Federation 需要)
|
||||||
|
add_header Access-Control-Allow-Origin *;
|
||||||
|
add_header Access-Control-Allow-Methods "GET, OPTIONS";
|
||||||
|
add_header Access-Control-Allow-Headers "Origin, Content-Type, Accept";
|
||||||
|
}
|
||||||
|
|
||||||
|
# Platform 管理平台
|
||||||
|
location /platform/ {
|
||||||
|
proxy_pass http://platform/;
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
# Workcase 工单系统 PC端
|
||||||
|
location /workcase/ {
|
||||||
|
proxy_pass http://workcase-web/;
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
# Bidding 招标系统
|
||||||
|
location /bidding/ {
|
||||||
|
proxy_pass http://bidding-web/;
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
# Workcase 工单系统微信端
|
||||||
|
location /workcase-wechat/ {
|
||||||
|
proxy_pass http://workcase-wechat/;
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
# 默认首页(重定向到 platform)
|
||||||
|
location = / {
|
||||||
|
return 302 /platform/;
|
||||||
|
}
|
||||||
|
|
||||||
|
# ====================== API 代理 ======================
|
||||||
|
|
||||||
|
# 后端 API 代理
|
||||||
|
location /urban-lifeline/ {
|
||||||
|
proxy_pass http://gateway/urban-lifeline/;
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
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;
|
||||||
|
|
||||||
|
# WebSocket 支持
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection "upgrade";
|
||||||
|
|
||||||
|
# 超时设置
|
||||||
|
proxy_connect_timeout 60s;
|
||||||
|
proxy_send_timeout 60s;
|
||||||
|
proxy_read_timeout 60s;
|
||||||
|
}
|
||||||
|
|
||||||
|
# ====================== 错误页面 ======================
|
||||||
|
error_page 500 502 503 504 /50x.html;
|
||||||
|
location = /50x.html {
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
}
|
||||||
|
}
|
||||||
47
docker/nginx/volumes/nginx.conf
Normal file
47
docker/nginx/volumes/nginx.conf
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
# ================================================
|
||||||
|
# Urban Lifeline - Nginx 主配置
|
||||||
|
# ================================================
|
||||||
|
|
||||||
|
user nginx;
|
||||||
|
worker_processes auto;
|
||||||
|
error_log /var/log/nginx/error.log warn;
|
||||||
|
pid /var/run/nginx.pid;
|
||||||
|
|
||||||
|
events {
|
||||||
|
worker_connections 1024;
|
||||||
|
use epoll;
|
||||||
|
multi_accept on;
|
||||||
|
}
|
||||||
|
|
||||||
|
http {
|
||||||
|
include /etc/nginx/mime.types;
|
||||||
|
default_type application/octet-stream;
|
||||||
|
|
||||||
|
# 日志格式
|
||||||
|
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
|
||||||
|
'$status $body_bytes_sent "$http_referer" '
|
||||||
|
'"$http_user_agent" "$http_x_forwarded_for"';
|
||||||
|
|
||||||
|
access_log /var/log/nginx/access.log main;
|
||||||
|
|
||||||
|
# 性能优化
|
||||||
|
sendfile on;
|
||||||
|
tcp_nopush on;
|
||||||
|
tcp_nodelay on;
|
||||||
|
keepalive_timeout 65;
|
||||||
|
types_hash_max_size 2048;
|
||||||
|
|
||||||
|
# Gzip 压缩
|
||||||
|
gzip on;
|
||||||
|
gzip_vary on;
|
||||||
|
gzip_proxied any;
|
||||||
|
gzip_comp_level 6;
|
||||||
|
gzip_types text/plain text/css text/xml application/json application/javascript
|
||||||
|
application/xml application/xml+rss text/javascript application/x-javascript;
|
||||||
|
|
||||||
|
# 上传文件大小限制
|
||||||
|
client_max_body_size 100M;
|
||||||
|
|
||||||
|
# 引入站点配置
|
||||||
|
include /etc/nginx/conf.d/*.conf;
|
||||||
|
}
|
||||||
@@ -8,21 +8,21 @@ spring:
|
|||||||
cloud:
|
cloud:
|
||||||
nacos:
|
nacos:
|
||||||
discovery:
|
discovery:
|
||||||
server-addr: ${NACOS_SERVER_ADDR:nacos:8848}
|
server-addr: ${NACOS_SERVER_ADDR:urban-lifeline-nacos:8848}
|
||||||
namespace: ${NACOS_NAMESPACE:}
|
namespace: ${NACOS_NAMESPACE:}
|
||||||
group: ${NACOS_GROUP:DEFAULT_GROUP}
|
group: ${NACOS_GROUP:DEFAULT_GROUP}
|
||||||
|
|
||||||
# ================== DataSource ==================
|
# ================== DataSource ==================
|
||||||
datasource:
|
datasource:
|
||||||
url: ${DB_URL:jdbc:postgresql://postgres:5432/urban_lifeline}
|
url: ${DB_URL:jdbc:postgresql://urban-lifeline-pg:5432/urban_lifeline}
|
||||||
username: ${DB_USERNAME:postgres}
|
username: ${DB_USERNAME:postgres}
|
||||||
password: ${DB_PASSWORD:postgres}
|
password: ${DB_PASSWORD:postgres123456}
|
||||||
driver-class-name: org.postgresql.Driver
|
driver-class-name: org.postgresql.Driver
|
||||||
|
|
||||||
# ================== Redis ==================
|
# ================== Redis ==================
|
||||||
data:
|
data:
|
||||||
redis:
|
redis:
|
||||||
host: ${REDIS_HOST:redis}
|
host: ${REDIS_HOST:urban-lifeline-redis}
|
||||||
port: ${REDIS_PORT:6379}
|
port: ${REDIS_PORT:6379}
|
||||||
database: ${REDIS_DATABASE:0}
|
database: ${REDIS_DATABASE:0}
|
||||||
password: ${REDIS_PASSWORD:}
|
password: ${REDIS_PASSWORD:}
|
||||||
@@ -38,7 +38,7 @@ dubbo:
|
|||||||
name: dubbo
|
name: dubbo
|
||||||
port: -1
|
port: -1
|
||||||
registry:
|
registry:
|
||||||
address: nacos://${NACOS_SERVER_ADDR:nacos:8848}
|
address: nacos://${NACOS_SERVER_ADDR:urban-lifeline-nacos:8848}
|
||||||
|
|
||||||
# ================== MyBatis-Plus ==================
|
# ================== MyBatis-Plus ==================
|
||||||
mybatis-plus:
|
mybatis-plus:
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ COPY urbanLifelineWeb/packages/shared/dist/ /app/sites/shared/
|
|||||||
COPY urbanLifelineWeb/packages/platform/dist/ /app/sites/platform/
|
COPY urbanLifelineWeb/packages/platform/dist/ /app/sites/platform/
|
||||||
COPY urbanLifelineWeb/packages/workcase/dist/ /app/sites/workcase/
|
COPY urbanLifelineWeb/packages/workcase/dist/ /app/sites/workcase/
|
||||||
COPY urbanLifelineWeb/packages/bidding/dist/ /app/sites/bidding/
|
COPY urbanLifelineWeb/packages/bidding/dist/ /app/sites/bidding/
|
||||||
COPY urbanLifelineWeb/packages/workcase_wechat/dist/ /app/sites/workcase_wechat/
|
# COPY urbanLifelineWeb/packages/workcase_wechat/dist/ /app/sites/workcase_wechat/
|
||||||
|
|
||||||
# ============================================
|
# ============================================
|
||||||
# 端口配置 (可通过环境变量覆盖)
|
# 端口配置 (可通过环境变量覆盖)
|
||||||
@@ -36,8 +36,8 @@ COPY urbanLifelineWeb/packages/workcase_wechat/dist/ /app/sites/workcase_wechat/
|
|||||||
ENV SHARED_PORT=8000 \
|
ENV SHARED_PORT=8000 \
|
||||||
PLATFORM_PORT=8001 \
|
PLATFORM_PORT=8001 \
|
||||||
WORKCASE_PORT=8002 \
|
WORKCASE_PORT=8002 \
|
||||||
BIDDING_PORT=8003 \
|
BIDDING_PORT=8003
|
||||||
WORKCASE_WECHAT_PORT=8004
|
# WORKCASE_WECHAT_PORT=8004
|
||||||
|
|
||||||
# 配置和日志目录 (可外挂)
|
# 配置和日志目录 (可外挂)
|
||||||
VOLUME ["/app/config", "/app/logs"]
|
VOLUME ["/app/config", "/app/logs"]
|
||||||
|
|||||||
48
docker/urbanLifeline/web/config/app-config-shared.js
Normal file
48
docker/urbanLifeline/web/config/app-config-shared.js
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
/**
|
||||||
|
* Shared 运行时配置 (Docker 部署)
|
||||||
|
* 此文件会被挂载到容器中,覆盖构建时的默认配置
|
||||||
|
*/
|
||||||
|
window.APP_RUNTIME_CONFIG = {
|
||||||
|
env: 'production',
|
||||||
|
|
||||||
|
api: {
|
||||||
|
baseUrl: '/api',
|
||||||
|
timeout: 30000
|
||||||
|
},
|
||||||
|
|
||||||
|
baseUrl: '/',
|
||||||
|
|
||||||
|
file: {
|
||||||
|
downloadUrl: '/api/urban-lifeline/file/download/',
|
||||||
|
uploadUrl: '/api/urban-lifeline/file/upload',
|
||||||
|
maxSize: {
|
||||||
|
image: 5,
|
||||||
|
video: 100,
|
||||||
|
document: 10
|
||||||
|
},
|
||||||
|
acceptTypes: {
|
||||||
|
image: 'image/*',
|
||||||
|
video: 'video/*',
|
||||||
|
document: '.pdf,.doc,.docx,.xls,.xlsx,.ppt,.pptx'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
token: {
|
||||||
|
key: 'token',
|
||||||
|
refreshThreshold: 300000
|
||||||
|
},
|
||||||
|
|
||||||
|
publicImgPath: '/img',
|
||||||
|
publicWebPath: '/',
|
||||||
|
|
||||||
|
sso: {
|
||||||
|
platformUrl: 'https://demo-urbanlifeline.tensorgrove.com/',
|
||||||
|
workcaseUrl: 'https://demo-urbanlifeline.tensorgrove.com/workcase',
|
||||||
|
biddingUrl: 'https://demo-urbanlifeline.tensorgrove.com/bidding'
|
||||||
|
},
|
||||||
|
|
||||||
|
features: {
|
||||||
|
enableDebug: false,
|
||||||
|
enableMockData: false
|
||||||
|
}
|
||||||
|
};
|
||||||
@@ -58,11 +58,12 @@ declare -A WEBS=(
|
|||||||
["platform"]="PLATFORM_PORT:8001"
|
["platform"]="PLATFORM_PORT:8001"
|
||||||
["workcase"]="WORKCASE_PORT:8002"
|
["workcase"]="WORKCASE_PORT:8002"
|
||||||
# ["bidding"]="BIDDING_PORT:8003"
|
# ["bidding"]="BIDDING_PORT:8003"
|
||||||
["workcase_wechat"]="WORKCASE_WECHAT_PORT:8004"
|
# ["workcase_wechat"]="WORKCASE_WECHAT_PORT:8004"
|
||||||
)
|
)
|
||||||
|
|
||||||
# shared 必须最先启动 (其他模块依赖它)
|
# shared 必须最先启动 (其他模块依赖它)
|
||||||
BOOT_ORDER=(shared platform workcase bidding workcase_wechat)
|
# BOOT_ORDER=(shared platform workcase bidding workcase_wechat)
|
||||||
|
BOOT_ORDER=(shared platform workcase)
|
||||||
|
|
||||||
# 颜色
|
# 颜色
|
||||||
RED='\033[0;31m'
|
RED='\033[0;31m'
|
||||||
|
|||||||
@@ -10,9 +10,9 @@ const __filename = fileURLToPath(import.meta.url)
|
|||||||
const __dirname = dirname(__filename)
|
const __dirname = dirname(__filename)
|
||||||
|
|
||||||
// 开发环境 shared 模块地址
|
// 开发环境 shared 模块地址
|
||||||
const DEV_SHARED_URL = 'https://localhost:7000/shared/mf-manifest.json'
|
const DEV_SHARED_URL = 'https://localhost:7000/shared/remoteEntry.js'
|
||||||
// 生产环境使用相对路径,通过 Nginx 代理访问
|
// 生产环境使用相对路径,通过 Nginx 代理访问
|
||||||
const PROD_SHARED_URL = '/shared/mf-manifest.json'
|
const PROD_SHARED_URL = '/shared/remoteEntry.js'
|
||||||
|
|
||||||
export default defineConfig(({ mode }) => {
|
export default defineConfig(({ mode }) => {
|
||||||
const isDev = mode === 'development'
|
const isDev = mode === 'development'
|
||||||
|
|||||||
@@ -10,9 +10,9 @@ const __filename = fileURLToPath(import.meta.url)
|
|||||||
const __dirname = dirname(__filename)
|
const __dirname = dirname(__filename)
|
||||||
|
|
||||||
// 开发环境 shared 模块地址
|
// 开发环境 shared 模块地址
|
||||||
const DEV_SHARED_URL = 'https://localhost:7000/shared/mf-manifest.json'
|
const DEV_SHARED_URL = 'https://localhost:7000/shared/remoteEntry.js'
|
||||||
// 生产环境使用相对路径,通过 Nginx 代理访问
|
// 生产环境使用相对路径,通过 Nginx 代理访问
|
||||||
const PROD_SHARED_URL = '/shared/mf-manifest.json'
|
const PROD_SHARED_URL = '/shared/remoteEntry.js'
|
||||||
|
|
||||||
export default defineConfig(({ mode }) => {
|
export default defineConfig(({ mode }) => {
|
||||||
const isDev = mode === 'development'
|
const isDev = mode === 'development'
|
||||||
|
|||||||
@@ -10,9 +10,9 @@ const __filename = fileURLToPath(import.meta.url)
|
|||||||
const __dirname = dirname(__filename)
|
const __dirname = dirname(__filename)
|
||||||
|
|
||||||
// 开发环境 shared 模块地址
|
// 开发环境 shared 模块地址
|
||||||
const DEV_SHARED_URL = 'https://localhost:7000/shared/mf-manifest.json'
|
const DEV_SHARED_URL = 'https://localhost:7000/shared/remoteEntry.js'
|
||||||
// 生产环境使用相对路径,通过 Nginx 代理访问
|
// 生产环境使用相对路径,通过 Nginx 代理访问
|
||||||
const PROD_SHARED_URL = '/shared/mf-manifest.json'
|
const PROD_SHARED_URL = '/shared/remoteEntry.js'
|
||||||
|
|
||||||
export default defineConfig(({ mode }) => {
|
export default defineConfig(({ mode }) => {
|
||||||
const isDev = mode === 'development'
|
const isDev = mode === 'development'
|
||||||
|
|||||||
Reference in New Issue
Block a user