K8s部署docker化Java应用

docker下载链接

Docker

下面以SpringBoot工程为例

  • 首先建立一个SpringBoot工程,工程目录结构如下:
> mt-myservice
    > .idea
    > .mvn
    > src
        > main
            > docker
                  Dockerfile         // Dockerfile(名字是固定的)为工程docker的配置
        > java
            > com.my
                > controller         // web应用入口,controller控制器
                > service            // 业务逻辑类             
                  MyserviceApplication   // springBoot应用启动类
    > resources
          application.properties     // springBoot配置类,tomcat默认端口号可在这里修改
  • 上述添加docker配置文件Dockerfile,目录结构设置为src/main/docker,内容如下
#基础镜像环境
FROM java:8  
VOLUME /tmp  
#把工程生成的jar包添加到容器并改名为app.jar
ADD myservice-0.0.1-SNAPSHOT.jar app.jar 
#命令入口,其中-Djava.security.egd=file:/dev/./urando是生成随机数,urandom节约构建熵池时间
#设置应用最大内存为1000M
ENTRYPOINT ["java","-Xmx1000m","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
  • pom中配置maven插件,配置如下
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId
### 使用 Kubernetes 和 Docker 部署 Java 项目的教程 #### 准备工作 在开始之前,需要确保已经安装了必要的工具和环境。这包括 JDK、Maven 或 Gradle 构建工具、Docker 客户端以及 kubectl 命令行工具[^1]。 #### 创建 Java 项目 假设我们有一个简单的 Spring Boot 应用程序作为目标项目。可以通过以下命令创建一个新的 Spring Boot 项目: ```bash spring init --dependencies=web my-java-app cd my-java-app ``` 此操作将生成一个基础的 Web 项目结构,并包含 `pom.xml` 文件用于 Maven 构建管理。 #### 添加 Docker 支持 为了使应用程序能够被封装为 Docker 映像,在构建过程中需引入插件支持。编辑 `pom.xml` 并加入如下配置片段来启用 Docker 插件功能: ```xml <build> <plugins> <plugin> <groupId>com.spotify</groupId> <artifactId>dockerfile-maven-plugin</artifactId> <version>1.4.13</version> <executions> <execution> <id>default</id> <goals> <goal>build</goal> <goal>push</goal> </goals> </execution> </executions> <configuration> <repository>${project.artifactId}</repository> <tag>${project.version}</tag> <buildArgs> <JAR_FILE>target/${project.build.finalName}.jar</JAR_FILE> </buildArgs> </configuration> </plugin> </plugins> </build> ``` 上述 XML 片段定义了一个名为 `dockerfile-maven-plugin` 的插件实例过程及其参数设置,它会在执行特定生命周期阶段时自动完成映像制作与推送动作。 #### 编写 Dockerfile 在同一目录下新建文件名叫做 `Dockerfile` 的纯文本文档,其内容大致如下所示: ```dockerfile FROM openjdk:17-jdk-alpine ARG JAR_FILE=target/*.jar COPY ${JAR_FILE} app.jar ENTRYPOINT ["java","-jar","/app.jar"] ``` 这段脚本描述了一种基于官方 OpenJDK 镜像的基础层之上叠加当前应用二进制产物的方式形成最终可分发版本的方法论。 #### 测试本地镜像构建流程 通过运行下面这条指令验证整个自动链条是否正常运作: ```bash mvn clean package dockerfile:build ``` 如果一切顺利的话,则应该能看到类似于这样的日志输出表明成功建立了新的容器镜像资源: ``` [INFO] Building image my-java-app:0.0.1-SNAPSHOT ... Successfully built abcdefghijklmnopqrstuvwxyz ``` #### 推送至远程仓库 继续利用 maven 生命周期进一步把刚造好的成果物提交给指定位置存储起来以便稍后引用加载之用: ```bash mvn dockerfile:push ``` 此时依据实际网络状况等待片刻之后即可确认上传完毕状态消息显示出来. #### 设定 K8S 资源清单 最后一步就是编写适合集群调度使用的 YAML 格式的资源配置说明书样例形式可能看起来像是这样子的样子: ```yaml apiVersion: apps/v1 kind: Deployment metadata: name: my-java-deployment spec: replicas: 2 selector: matchLabels: app: my-java-app template: metadata: labels: app: my-java-app spec: containers: - name: my-java-container image: your-dockerhub-account/my-java-app:latest ports: - containerPort: 8080 --- apiVersion: v1 kind: Service metadata: name: my-java-service spec: type: LoadBalancer selector: app: my-java-app ports: - protocol: TCP port: 80 targetPort: 8080 ``` 这里分别声明了一个副本数设定为两个节点规模的应用部署计划还有对外暴露服务地址端口转换关系等内容细节部分[^2]. #### 提交到云端平台 登录腾讯云控制台界面找到对应区域下的 K8S 实例选项卡页面点击导入现有 manifest 文档按钮上传刚才准备妥当后的 yaml 文件即刻生效启动全部环节运转机制直至完全就绪为止. ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值