java应用程序镜像制作及在kubernetes上发布

应用程序镜像制作

准备好应用程序

[[email protected]_8_24_centos testapp]# ls
Dockerfile  testapp.tar.gz

编写Dockerfile

[[email protected]_8_24_centos testapp]# cat Dockerfile
# 基础镜像
FROM core-harbor.minminmsn.com/public/jre-centos:1.8.0_212

# 维护信息
MAINTAINER minyt <[email protected]>

# 文件复制到镜像
RUN mkdir -p /data1/testapp-app && mkdir -p /data1/logs/testapp-app && mkdir -p /data1/run/testapp-app
ADD testapp.tar.gz /data1/testapp-app/

# 设置环境变量
# ENV JAVA_HOME /usr/local/jre1.8.0_212
# ENV PATH ${PATH}:${JAVA_HOME}/bin

# 容器启动时运行的命令
CMD ["/data1/testapp-app/bin/launch.sh", "start"]

# 暴漏端口
EXPOSE 10030

制作应用程序镜像

[[email protected]_8_24_centos testapp]# docker build -t core-harbor.minminmsn.com/public/testapp:2.0 .
Sending build context to Docker daemon  58.24MB
Step 1/6 : FROM core-harbor.minminmsn.com/public/jre-centos:1.8.0_212
 ---> f27d47159f1e
Step 2/6 : MAINTAINER minyt <[email protected]>
 ---> Using cache
 ---> 3d2b8caf725b
Step 3/6 : RUN mkdir -p /data1/testapp-app && mkdir -p /data1/logs/testapp-app && mkdir -p /data1/run/testapp-app
 ---> Running in 8034eb452bfa
Removing intermediate container 8034eb452bfa
 ---> eea12a3c6093
Step 4/6 : ADD testapp.tar.gz /data1/testapp-app/
 ---> 1d155c1cd571
Step 5/6 : CMD ["/data1/testapp-app/bin/launch.sh", "start"]
 ---> Running in c7dab4cffaf9
Removing intermediate container c7dab4cffaf9
 ---> 45a1da4c0742
Step 6/6 : EXPOSE 10030
 ---> Running in 2618620aa185
Removing intermediate container 2618620aa185
 ---> b1d3a82bb34d
Successfully built b1d3a82bb34d
Successfully tagged core-harbor.minminmsn.com/public/testapp:2.0

本地启动镜像测试

[[email protected]_8_24_centos testapp]# docker run -d -p 10030:10030  core-harbor.minminmsn.com/public/testapp:2.0
ce1cf6f8e29554187d8fc810f94e35b80ca0902d0e8fc7d43bc7f5fa5d9a7dc2
[[email protected]_8_24_centos testapp]# netstat -tulpn |grep 10030
tcp6       0      0 :::10030                :::*                    LISTEN      28037/docker-proxy  

浏览器访问测试

http://10.2.8.24:10030/
{"returncode":0,"message":"OK"}

上传到私有镜像库

[[email protected]_8_24_centos testapp]# docker push core-harbor.minminmsn.com/public/testapp:2.0
The push refers to repository [core-harbor.minminmsn.com/public/testapp]
04b815b81c42: Pushed
8dae5abda95b: Pushed
b9049811dc7d: Layer already exists
89169d87dbe2: Layer already exists
2.0: digest: sha256:db7f866ec3f531161c2f6a82667f03896657c34ccaf25b310d519abac175c25e size: 1160
[[email protected]_8_24_centos testapp]# 

在kubernetes上发布应用

准备testapp.yaml文件

[[email protected] testapp]# cat testapp.yaml
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  labels:
    app.kubernetes.io/name: testapp
    app.kubernetes.io/part-of: ingress-nginx

  name: testapp
  namespace: ingress-nginx
spec:
  selector:
    matchLabels:
      app.kubernetes.io/name: testapp
      app.kubernetes.io/part-of: ingress-nginx
  strategy:
    rollingUpdate:
      maxSurge: 1
      maxUnavailable: 1
    type: RollingUpdate
  template:
    metadata:
      labels:
        app.kubernetes.io/name: testapp
        app.kubernetes.io/part-of: ingress-nginx
    spec:
      containers:
        - image: core-harbor.minminmsn.com/public/testapp:2.0
          name: testapp
          ports:
            - containerPort: 10030
              protocol: TCP
      restartPolicy: Always
      volumes:
        - emptyDir: {}
          name: data

---
apiVersion: v1
kind: Service
metadata:
  name: testapp
  namespace: ingress-nginx
  labels:
    app.kubernetes.io/name: testapp
    app.kubernetes.io/part-of: ingress-nginx

spec:
  ports:
    - port: 10030
      protocol: TCP
      targetPort: 10030
  selector:
    app.kubernetes.io/name: testapp
    app.kubernetes.io/part-of: ingress-nginx
  type: NodePort

---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: testapp-ingress
  namespace: ingress-nginx
spec:
  rules:
    - host: testapp.minminmsn.com
      http:
        paths:
        - path: /
          backend:
            serviceName: testapp
            servicePort: 10030

部署应用

[[email protected] testapp]# kubectl create -f testapp.yaml
deployment.extensions/testapp created
service/testapp created
ingress.extensions/testapp-ingress created

原文地址:https://blog.51cto.com/jerrymin/2400290

时间: 2024-10-21 18:42:41

java应用程序镜像制作及在kubernetes上发布的相关文章

如何制作可以在 MaxCompute 上使用的 crcmod

之前我们介绍过在 PyODPS DataFrame 中使用三方包.对于二进制包而言,MaxCompute 要求使用包名包含 cp27-cp27m 的 Wheel 包.但对于部分长时间未更新的包,例如 oss2 依赖的 crcmod,PyPI 并未提供 Wheel 包,因而需要自行打包.本文介绍了如何使用 quay.io/pypa/manylinux1_x86_64 镜像制作可在 MaxCompute 上使用的 Wheel 包. 本文参考 https://github.com/pypa/manyl

阿里云部署Java网站和微信开发调试心得技巧(上)

阿里云部署Java网站和微信开发调试心得技巧(上)本篇手记旨在帮助大家从0开始: 申请阿里云服务器 搭建出程序的执行环境 在服务器上发布并运行自己的web project 域名解析 微信测试号的申请与连接以获取微信用户信息全篇文章主要以如何去完成目标为主,因此会以流程的形式来展现,细节方面需要大家多多思考.其中文章的上集实现了1-4,文章的下集实现了5一.申请阿里云服务器(1)PC访问阿里云https://www.aliyun.com/,申请阿里云帐号(可以用您的支付宝帐号登录,因为支付宝帐号已

【ASP.NET Core分布式项目实战】(五)Docker制作dotnet core控制台程序镜像

Docker制作dotnet core控制台程序镜像 基于dotnet SDK 新建控制台程序 mkdir /home/console cd /home/console dotnet new console dotnet restore 创建 Dockerfile 文件,参考https://github.com/dotnet/dotnet-docker/blob/master/samples/aspnetapp/Dockerfile vim /home/console/Dockerfile #

Docker之三----java业务镜像制作

一.制作tomcat镜像: 基本架构图: 1.制作JDK镜像 基于官方提供的centos7.2.1511基础镜像构建JDK和tomcat镜像,先构建JDK镜像,然后再基于JDK镜像构建tomcat镜像. JDK下载路径:https://www.oracle.com/technetwork/java/javase/downloads/index.html 选择架构版本: (1)先下载基础centos镜像 [[email protected] ~]# docker pull centos (2)搭建

Java应用程序项目的打包与发行

这里主要是讲解一下怎样将 Java程序打包成独立运行的exe程序包,以下这种方法应该是最佳的解决方案了.NetDuke的EXE 程序包了是使用这种方案制作的.在操作步骤上还是比较简单的,而且通用性强. 1.程序打包 首先将程序打成Jar包,打包命令:jar cf 包文件名.jar *.class.接下来编译包中的清单文件MANIFEST.MF . Manifest-Version - 指定清单文件的版本号 Main-Class - 指定程序运行的入口类.注意:类名后不要加class扩展名 2.让

openstack虚拟化技术和镜像制作

一.虚拟化技术简介 应用程序 函数库 操作系统 硬件 计算机系统层次结构 现在计算机系统是一个庞大的整体, 整个系统非常复杂,因此计算机系统被自下而上分为多个层次,每一个层次都像上一个层次呈现一个抽象,并且每一层只需要知道下层抽象的接口,而并不需要了解其内部机制.虚拟化技术就是下层的软件模块,根据上层软件模块的需求,抽象出一个虚拟的软件或者硬件接口,使上一层软件可以运行在与自己所期待的运行环境完全一致的虚拟环境上. 虚拟化可以发生在上表的各个层次,但对于openstack这样的云计算服务而言,更

Harbor用户机制、镜像同步和与Kubernetes的集成实践

Habor是由VMWare公司开源的容器镜像仓库.事实上,Habor是在Docker Registry上进行了相应的企业级扩展,从而获得了更加广泛的应用,这些新的企业级特性包括:管理用户界面,基于角色的访问控制 ,AD/LDAP集成以及审计日志等. 容器的核心在于镜象的概念,由于可以将应用打包成镜像,并快速的启动和停止,因此容器成为新的炙手可热的基础设施CAAS,并为敏捷和持续交付包括DevOps提供底层的支持. 而Habor和Docker Registry所提供的容器镜像仓库,就是容器镜像的存

kickstart及光盘引导镜像制作

一.kickstart简介使用kickstart可以完成系统的自动化安装,原理是把安装过程内装写到配置文件中,这个配置文件可以放在光盘和文件服务器上,下面只介绍光盘引导镜像的制作.二.光盘引导镜像制作过程  (1) 准备工作目录,例如这里使用/tmp/cdrom:   #mkdir /tmp/cdrom  (2) 挂载系统发行光盘,复制光盘所有内容至/tmp/cdrom:  #mount -r -t iso9660 /dev/cdrom /media/cdrom  #cp -r /media/c

docker镜像制作---jdk7+tomcat7基础镜像

1. 安装docker rpm -Uvh http://download.fedoraproject.org/pub/epel/6/i386/epel-release-6-8.noarch.rpm yum -y install docker-io? 可使用以下命令,查看 Docker 是否安装成功:docker version 输出了 Docker 的版本号,则说明安装成功了,可通过以下命令启动 Docker 服务: service docker start 一旦 Docker 服务启动完毕,我