teracy/create-react-appcreate-react-app Docker镜像是一个预配置的开发环境,专为使用***的create-react-app工具创建和开发React应用而设计。该镜像提供了一致的开发环境,消除了"在我机器上能运行"的问题,并简化了React项目的初始化、开发和构建流程。
bashdocker run --rm -v $(pwd):/app teracyhq/create-react-app npx create-react-app my-app
bashcd my-app docker run --rm -it -v $(pwd):/app -p 3000:3000 teracyhq/create-react-app npm start
现在可以通过访问 http://localhost:3000 在浏览器中查看应用。
bashdocker run --rm -v $(pwd):/app teracyhq/create-react-app npm run build
构建完成后,优化后的静态文件将生成在build目录中。
创建docker-compose.yml文件:
yamlversion: '3' services: react-app: image: teracyhq/create-react-app volumes: - ./:/app ports: - "3000:3000" environment: - NODE_ENV=development command: npm start
使用以下命令启动开发环境:
bashdocker-compose up
| 环境变量 | 描述 | 默认值 |
|---|---|---|
| NODE_ENV | 应用运行环境 | development |
| PORT | 开发服务器端口 | 3000 |
| REACT_APP_* | 自定义环境变量,前缀为REACT_APP_的变量会被注入到应用中 | 无 |
为了确保依赖包不会在容器重启时丢失,可以将node_modules目录单独挂载为卷:
bashdocker run --rm -it -v $(pwd):/app -v react_node_modules:/app/node_modules -p 3000:3000 teracyhq/create-react-app npm start
如需使用特定版本的Node.js,可以通过标签指定:
bashdocker run --rm -v $(pwd):/app teracyhq/create-react-app:node-16 npx create-react-app my-app
构建完成后,可以使用nginx镜像部署生成的静态文件:
dockerfile# Dockerfile FROM nginx:alpine COPY --from=builder /app/build /usr/share/nginx/html EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]
然后构建并运行生产镜像:
bash# 构建React应用 docker run --rm -v $(pwd):/app --name react-builder teracyhq/create-react-app npm run build # 构建生产镜像 docker build -t my-react-app . # 运行生产容器 docker run -d -p 80:80 my-react-app
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务