create-react-app Docker镜像是一个预配置的开发环境,专为使用***的create-react-app工具创建和开发React应用而设计。该镜像提供了一致的开发环境,消除了"在我机器上能运行"的问题,并简化了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
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务