This commit is contained in:
2025-10-18 01:45:48 +00:00
parent 189f20fdac
commit 9a1148e1bc
4 changed files with 3752 additions and 19 deletions

View File

@ -6,11 +6,6 @@ WORKDIR /app
# 配置npm使用淘宝镜像源解决国内网络问题 # 配置npm使用淘宝镜像源解决国内网络问题
RUN npm config set registry https://registry.npmmirror.com RUN npm config set registry https://registry.npmmirror.com
RUN npm config set disturl https://npm.taobao.org/dist
RUN npm config set electron_mirror https://npm.taobao.org/mirrors/electron/
RUN npm config set puppeteer_download_host https://npm.taobao.org/mirrors
RUN npm config set sass_binary_site https://npm.taobao.org/mirrors/node-sass/
RUN npm config set phantomjs_cdnurl https://npm.taobao.org/mirrors/phantomjs/
# 复制package.json和package-lock.json # 复制package.json和package-lock.json
COPY package*.json ./ COPY package*.json ./
@ -24,20 +19,25 @@ COPY . .
# 构建应用 # 构建应用
RUN npm run build RUN npm run build
# 生产阶段 - 使用阿里云Nginx镜像 # 生产阶段 - 使用Node镜像运行Next.js应用
FROM nginx:alpine FROM node:20-alpine
# 设置工作目录
WORKDIR /app
# 配置Alpine使用国内镜像源 # 配置Alpine使用国内镜像源
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
# 复制构建产物到nginx的html目录 # 复制构建产物
COPY --from=builder /app/out /usr/share/nginx/html COPY --from=builder /app/.next ./.next
COPY --from=builder /app/public ./public
COPY --from=builder /app/package*.json ./
# 复制自定义nginx配置如果需要 # 安装生产依赖
COPY nginx.conf /etc/nginx/conf.d/default.conf RUN npm install --production
# 暴露80端口 # 暴露Next.js默认端口
EXPOSE 80 EXPOSE 3000
# 启动nginx # 启动Next.js生产服务器
CMD ["nginx", "-g", "daemon off;"] CMD ["npm", "start"]

View File

@ -11,7 +11,7 @@ const Message: React.FC<MessageProps> = ({ message, isLast = false }) => {
const isUser = message.sender === 'user'; const isUser = message.sender === 'user';
const theme = useTheme(); const theme = useTheme();
const isMobile = useMediaQuery(theme.breakpoints.down('sm')); const isMobile = useMediaQuery(theme.breakpoints.down('sm'));
const paperRef = useRef<HTMLDivElement>(null); const paperRef = useRef(null);
// 计算气泡的borderRadius // 计算气泡的borderRadius
const borderRadius = isUser const borderRadius = isUser
@ -20,7 +20,6 @@ const Message: React.FC<MessageProps> = ({ message, isLast = false }) => {
return ( return (
<Box <Box
key={message.id}
display="flex" display="flex"
marginBottom={2} marginBottom={2}
justifyContent={isUser ? "flex-end" : "flex-start"} justifyContent={isUser ? "flex-end" : "flex-start"}

View File

@ -2,18 +2,37 @@ server {
listen 80; listen 80;
server_name localhost; server_name localhost;
# Next.js项目的根目录
root /usr/share/nginx/html; root /usr/share/nginx/html;
index index.html; index index.html;
# 支持Next.js路由 # Next.js路由配置
location / { location / {
try_files $uri $uri/ /index.html; try_files $uri $uri/ /index.html;
} }
# 处理Next.js静态资源
location /_next/ {
alias /usr/share/nginx/html/_next/;
expires 30d;
access_log off;
}
# 处理API路由
location /api/ {
proxy_pass http://localhost:3000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
# 静态文件缓存 # 静态文件缓存
location ~* \.(jpg|jpeg|png|gif|ico|css|js)$ { location ~* \.(jpg|jpeg|png|gif|ico|css|js|svg|woff|woff2|ttf|eot)$ {
expires 30d; expires 30d;
add_header Cache-Control "public, no-transform"; add_header Cache-Control "public, no-transform";
access_log off;
} }
# 错误页面 # 错误页面

3715
yarn.lock Normal file

File diff suppressed because it is too large Load Diff