如何解决Docker容器的npm更新检查失败
我在带有以下.Dockerfile的Docker容器中运行一个React应用。
FROM node:13.12.0-alpine
WORKDIR /app
ENV PATH /app/node_modules/.bin:$PATH
COPY /mvp-client-app ./
RUN npm install --silent
CMD ["npm","start"]
启动容器时,我看到以下错误消息
> mvp-client-app@0.1.0 start /app
> react-scripts start
Attempting to bind to HOST environment variable: 0.0.0.0
If this was unintentional,check that you haven't mistakenly set it in your shell.
Learn more here:
ℹ 「wds」: Project is running at http://172.18.0.4/
ℹ 「wds」: webpack output is served from
ℹ 「wds」: Content not from webpack is served from /app/public
ℹ 「wds」: 404s will fallback to /
Starting the development server...
┌──────────────────────────────────────────────┐
│ npm update check failed │
│ Try running with sudo or get access │
│ to the local update config store via │
│ sudo chown -R $USER:$(id -gn $USER) /.config │
└──────────────────────────────────────────────┘
我无法将建议的命令添加到Dockerfile中。如何清除消息并启动容器?
我们正在使用docker-compose
version: '3.3'
services:
mvp-client:
container_name: mvp-client
build:
context: ./MVP
dockerfile: mvp-client-app/Dockerfile
ports:
- '3001:3001'
environment:
- REACT_APP_ENV=development
- COMPOSE_CONVERT_WINDOWS_PATHS=1
- HOST=0.0.0.0
- PORT=3001
user:
999:999
我尝试通过docker-compose -f docker-compose.yml build mvp-client
和docker-compose -f docker-compose.yml up mvp-client
运行容器(故意只运行一个容器,而其他容器可以正常运行)。我使用Ubuntu 18.04 LTS和Gitlab CI / CD管道。
这里是package.json
{
"name": "mvp-client-app","version": "0.1.0","private": true,"dependencies": {
"@blueprintjs/core": "^3.31.0","@blueprintjs/icons": "^3.20.1","@storybook/node-logger": "^6.0.3","@testing-library/jest-dom": "^5.11.3","@testing-library/react": "^10.4.8","@testing-library/user-event": "^12.1.1","axios": "^0.19.2","debug": "^4.1.1","echarts": "^4.7.0","echarts-for-react": "^2.0.15-beta.1","immer": "^7.0.7","lodash": "^4.17.15","node-gyp": "^7.1.0","react": "^16.13.0","react-dom": "^16.13.0","react-ga": "^3.1.2","react-google-recaptcha": "^2.1.0","react-lines-ellipsis": "^0.14.1","react-mosaic-component": "^4.1.1","react-notifications": "^1.6.0","react-redux": "^7.2.1","react-scripts": "^3.4.2","react-spinners": "^0.9.0","rebuild": "^0.1.2","redux": "^4.0.5","redux-thunk": "^2.3.0","socket.io-client": "^2.3.0","styled-components": "^5.1.1"
},"scripts": {
"start": "react-scripts start","build": "react-scripts build","test": "react-scripts test","eject": "react-scripts eject","storybook": "start-storybook -p 9009 -s public","build-storybook": "build-storybook -s public"
},"eslintConfig": {
"extends": "react-app"
},"browserslist": {
"production": [
">0.2%","not dead","not op_mini all"
],"development": [
"last 1 chrome version","last 1 firefox version","last 1 safari version"
]
},"devDependencies": {
"@storybook/addon-actions": "^6.0.3","@storybook/addon-docs": "^6.0.3","@storybook/addon-knobs": "^6.0.3","@storybook/addon-links": "^6.0.3","@storybook/addon-storysource": "^6.0.3","@storybook/addons": "^6.0.3","@storybook/preset-create-react-app": "^3.1.4","@storybook/react": "^6.0.3"
}
}
解决方法
我通过在stdin_open: true
上添加docker-compose.yml
来解决(有关更多详细信息,请参见this question)。
version: '3.3'
services:
mvp-client:
container_name: mvp-client
build:
context: ./MVP
dockerfile: mvp-client-app/Dockerfile
ports:
- '3001:3001'
environment:
- REACT_APP_ENV=development
- COMPOSE_CONVERT_WINDOWS_PATHS=1
- HOST=0.0.0.0
- PORT=3001
user:
999:999
stdin_open: true
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。