Skaffold Kubernetes不显示React更改

时间:2019-03-28 07:53:53

标签: reactjs kubernetes nodemon skaffold

问题:

运行skaffold并更新监视的文件时,我看到文件同步更新发生,并且nodemon重新启动了服务器,但是刷新页面没有显示更改。直到我完全停止skaffold并重新启动后,我才看到更改。

Syncing 1 files for test/dev-client:e9c0a112af09abedcb441j4asdfasfd1cf80f2a9bc80342fd4123f01f32e234cfc18
Watching for changes every 1s...
[client-deployment-656asdf881-m643v client] [nodemon] restarting due to changes...
[client-deployment-656asdf881-m643v client] [nodemon] starting `node bin/server.js`

设置:

我有一个简单的微服务应用程序。它有一个服务器端(烧瓶/ python)和一个客户端端(反应),可以快速处理开发服务器。我已经将nodewatch设置为true(对于Chokidar轮询)。在开发中,我正在通过适用于Mac的Docker使用Kubernetes。

代码:

我很高兴发布自己的代码以提供帮助。请让我知道最需要的。

这是一些入门者:

Skaffold.yaml:

apiVersion: skaffold/v1beta7
kind: Config
build:
  local:
    push: false
  artifacts:
    - image: test/dev-client
      docker:
        dockerfile: Dockerfile.dev
      context: ./client
      sync:
        '**/*.css': .
        '**/*.scss': .
        '**/*.js': .
    - image: test/dev-server
      docker:
        dockerfile: Dockerfile.dev
      context: ./server
      sync:
        '**/*.py': .
deploy:
  kubectl:
    manifests:
      - k8s-test/client-ip-service.yaml
      - k8s-test/client-deployment.yaml
      - k8s-test/ingress-service.yaml
      - k8s-test/server-cluster-ip-service.yaml
      - k8s-test/server-deployment.yaml

Package.json的相关部分:

 "start": "nodemon -L bin/server.js",

Dockerfile.dev(客户端):

# base image
FROM node:10.8.0-alpine

# setting the working directory 
# may have to run this depending on environment
# RUN mkdir -p /usr/src/app 
WORKDIR /usr/src/app

# add '/usr/src/app/node_modules/.bin' to $PATH
ENV PATH /usr/src/app/node_modules/.bin:$PATH

# install and cache app depencies
COPY package.json /usr/src/app/package.json
RUN npm install

# copy over everything else
COPY . .

# start the app.
CMD ["npm", "run", "start"]

1 个答案:

答案 0 :(得分:3)

事实证明,我在文件同步中使用了错误的模式。 ** / *。js无法正确同步目录。

更改后

sync:
        '**/*.css': .
        '**/*.scss': .
        '**/*.js': .

sync:
        '***/*.css': .
        '***/*.scss': .
        '***/*.js': .

它立即开始工作。