node.js - 如何在 kubernetes 上部署带有 redis 的 node.js?

标签 node.js redis kubernetes minikube

我有一个非常简单的 node.js 应用程序(HTTP 服务),它与 Redis 进行“对话”。我想创建一个部署并使用 minikube 运行它。

据我了解,我的应用程序需要一个基于 docker 镜像的 kubernetes Pod。这是我的 Dockerfile:

FROM node:8.9.1
WORKDIR /usr/src/app
COPY package*.json ./
RUN npm install
COPY . .
EXPOSE 8080
CMD ["npm", "start"]

我使用 docker build -t my-app 构建 docker 镜像。

接下来,我为我的应用的 Pod 创建了一个 Pod 定义:

apiVersion: v1
kind: Pod
metadata:
  name: my-app
spec:
  containers:
  - name: my-app
    image: my-app:latest
    imagePullPolicy: Never
    ports:
    - containerPort: 8080

到目前为止,还不错。但是从现在开始,我不清楚如何进行redis:

  1. redis 应该是另一个 Pod,还是一个服务(就 Kubernetes 种类而言)?

  2. 如何从我的应用程序内部引用 redis?根据redis是否会被定义为Pod/Service,如何获取连接URL和端口?我读到了有关 Kubernetes 创建的环境变量的信息,但我不确定这些是否适用于 Pod 或服务。

  3. 如何在单一配置下聚合两者(我的应用程序和 redis)?如何确保首先启动 redis,然后启动我的应用程序(这需要运行 redis 实例),以及如何将我的 HTTP 端点公开给“外部世界”?我阅读了有关部署的信息,但不确定如何将这些部分连接在一起。

理想情况下,我希望所有配置都包含在 YAML 文件中,这样在一天结束时,整个基础设施都可以通过一个命令启动。

最佳答案

我想我找到了解决方案(使用部署和服务)。

对于我的部署,我在一个 Pod 中使用了两个容器(webapp + redis),因为 webapp 在没有事件的 redis 实例的情况下运行是没有意义的,而且它在应用程序启动时连接到 redis。我在这个推理中可能是错误的,所以如果您有其他想法,请随时纠正我。

这是我的部署:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-app-deployment
spec:
  selector:
    matchLabels:
      app: my-app-deployment
  template:
    metadata:
      labels:
        app: my-app-deployment
    spec:
      containers:
      - name: redis
        image: redis:latest
        ports:
        - containerPort: 6379
        volumeMounts:
        - mountPath: /srv/www
          name: redis-storage
      - name: my-app
        image: my-app:latest
        imagePullPolicy: Never
        ports:
        - containerPort: 8080
      volumes:
      - name: redis-storage
        emptyDir: {}

这是服务定义:

apiVersion: v1
kind: Service
metadata:
  name: my-app-service
spec:
  ports:
  - port: 8080
    protocol: TCP
  type: NodePort
  selector:
    app: my-app-deployment

我使用以下方法创建部署: kubectl create -f deployment.yaml 然后,我使用 kubectl create -f service.yaml 创建服务 我使用 minikube ip 读取 IP,并从 kubectl describe service my-app-service 的输出中提取端口。

关于node.js - 如何在 kubernetes 上部署带有 redis 的 node.js?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53031852/

相关文章:

php - Predis 与 PhpiredisStreamConnection 持久化

php - Redis哨兵实现

Redis如何表示一个二维世界(MMO?)

kubernetes - 如何在 Kubernetes pod 中设置 pid 限制?

node.js - 重构后,Sequelize 不会读取新的模型名称(删除最终模型名称中的 s)

c# - Express (NodeJS) 无法处理来自 Xamarin Android 应用程序的 Post

jquery - 使用 Chart.js 时 $(...).getContext ("2d") 不是函数

node.js - 在 Node.JS 和 Express 中拦截 HTTPS 服务器上的 HTTP 响应

kubernetes - 在没有负载均衡器的情况下在Digital Ocean的托管Kubernetes上暴露端口80

azure - 使用托管标识将 Azure Key Vault 与 Azure Kubernetes 服务集成