【发布时间】:2020-04-09 00:38:50
【问题描述】:
我是 docker 和 kubernetes 的新手。我创建了一个 jar 文件,我需要启动 jar kube 创建 pod 时的文件。我想从 kube pod.yml 传递 args 来调用 java 类 在docker镜像中打包的jar文件中-
Dockerfile
==========
FROM openjdk:8
ARG JAR_FILE=target/app.jar
# cd /usr/local/runme
WORKDIR /usr/local/runme/
COPY ${JAR_FILE} app-jar-with-dependencies.jar
以下是我的pod文件-
apiVersion: v1
kind: Pod
metadata:
name: app
labels:
zone: dev
version: v1
spec:
containers:
- name: app-ctr
image: "docker-image-created-from-above-dockerfile"
ports:
- containerPort: 8080
env:
- name: NO_OF_CONSUMERS
value: "1"
args: [ "-n", "$(NO_OF_CONSUMERS)"]
在我的 pom.xml 中,我有以下 mainClass -
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<archive>
<manifest>
<mainClass>com.app.KafkaConsumer</mainClass>
</manifest>
</archive>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
</configuration>
<executions>
<execution>
<id>make-assembly</id> <!-- this is used for inheritance merges -->
<phase>package</phase> <!-- bind to the packaging phase -->
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
我不知道该怎么做。我是否需要使用 ENTRYPOINT 或 CMD 或其他任何东西。
【问题讨论】:
标签: java docker kubernetes-pod