Springboot(java)程序部署到k8s
新建rc(replication controller)
以下操作在master1做
rc是一套程序部署的配置,k8s会根据配置自动运行和管理程序,例如自动启动程序,程序挂了自动重启等等
rc配置一般都是写到配置文件(扩展名yaml),然后指定yaml文件来新建rc,k8s很多“东西”都是这种方式配置
在任意目录(最好是存放文件资料的地方),新建文件springboot-helloworld-rc.yaml,内容如下:
PS:部分项有注释
apiVersion: v1
kind: ReplicationController#对象类型,这里是rc(全称ReplicationController)
metadata:
name: helloworld#名称
labels:
name: helloworld#标注
spec:
replicas: 3#运行容器的副本数,修改这里可以快速修改分布式节点数量
selector:
name: helloworld
template:
metadata:
labels:
name: helloworld
spec:
containers:#docker容器的配置
- name: helloworld
image: 192.168.31.141:5000/springio/ewater:0.0.1#pull镜像的地址
imagePullPolicy: IfNotPresent#pull镜像时机,
ports:
- containerPort: 20801#容器对方开放端口
cd到yaml的目录,运行:kubectl create -f springboot-helloworld-rc.yaml,根据yaml的配置创建rc(创建什么类型对象是在yaml里面指定,所有类型对象创建命令都是kubectl create)
运行:kubectl get rc,可查看rc列表

运行:kubectl get pods,可查看运行的pod列表

Pod启动比较容易出错,以下详细说明:
首先pod可以理解为docker容器,例如本文rc配置了运行副本(容器)数是3,所以就创建了3个pod(容器)
Pod的状态(status)是running(运行中)是正常的,如果是其他值说明启动未成功
未成功有可能是pull镜像比较慢,这只能等
未成功也有可能是启动失败,可以用命令kubectl describe pod helloworld-7jpm5(helloworld-7jpm5代表pod名称),通过查看某个pod的启动日志来调试

例如下图就说明pull镜像时出问题

另外可以用命令kubectl logs helloworld-7jpm5(helloworld-7jpm5代表pod名称)查看pod的命令行日志,相当于在cmd运行jar包的命令行输出

rc和pod成功创建和运行,相当于java程序在k8s已运行成功,但外网还不能访问,接下来要创建service
新建service
以下操作在master1做
Service在k8s体系总负责沟通k8s内外网络配置(注意内外只是指k8s网络的内外,而不是局域网和互联网)
在任意目录(最好是存放文件资料的地方),新建文件springboot-helloworld-svc.yaml,内容如下:
apiVersion: v1
kind: Service #对象类型,这里是service
metadata:
name: helloworld #名称
labels:
name: helloworld #标注
spec:
type: NodePort
ports:
- port: 20801 #service(对内)的端口
targetPort: 20801 #pod的端口
nodePort: 32008 #service对外的端口
selector:
name: helloworld
cd到yaml文件所在目录,运行:kubectl create -f springboot-helloworld-svc.yaml,根据yaml文件创建service
可以运行kubectl get services查看到新的service
PS:20801是内部端口,32008是对外端口

此时可以在浏览器访问测试是否部署成功,注意ip是master1的,端口是service的对外端口

Springboot(java)程序部署到k8s的更多相关文章
- 从安装linux(centos7.6)系统到部署springboot java程序到k8s(大纲)
本文说明从安装linux系统开始,一直到在k8s运行springboot程序全过程 本文假设在自己电脑操作,因此linux系统使用vmware虚拟机,linux发行版使用centos 7.6.1810 ...
- 开发阶段,将SpringBoot应用快速部署到K8S
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- 基于idea做java程序的本地k8s调试-skaffold(一)
先介绍下本篇文章是基于ideas下开发微服务的场景,大家都知道微服务嘛,一个个微的服务...很多,先不谈调试,要跑起来都费力,可能的原因有: 环境变量的配置,如果多个项目穿插着来,env变量可能废了, ...
- 基于idea做java程序的本地k8s调试-skaffold(二)
上一篇讲完了java代码发到本机minikube中run,这篇来讲讲minkube中进行debug(idea下) 话说,上篇是把pigx基础infra微服务都发到了minikube中,这些微服务是ru ...
- Linux中部署JAVA程序
JAVA程序在开发完成后,需要部署到服务器,如果是WEB项目,需要部署到WEB服务器,否则部署到应用服务器. JAVA是跨平台的编程语言,服务器的操作系统可以是Windows.Linux或者其它,下面 ...
- 写个shell脚本搭载jenkins让你的程序部署飞起来
[转载请注明]: 原文出处:https://www.cnblogs.com/jstarseven/p/11399251.html 作者:jstarseven 码字挺辛苦的..... 说明 ...
- Java Project部署到Tomcat服务器上
所有的JAVA程序员,在编写WEB程序时,一般都通过工具如 MyEclipse,编写一个WEB Project,通过工具让这个WEB程序和Tomcat关联.其实在我们可以通过JAVA程序部署到Tomc ...
- Java Service Wrapper将java程序设置为服务
有时候我们希望我们java写的程序作为服务注册到系统中,Java Service Wrapper(下面简称wrapper)是目前较为流行的将Java程序部署成Windows服务的解决方案, 本文将讨论 ...
- Java Service Wrapper 发布Java程序为Windows服务
下载Windows版本:https://www.krenger.ch/blog/java-service-wrapper-3-5-37-for-windows-x64/ 转自:F:\java\bhGe ...
随机推荐
- 【leetcode】1177. Can Make Palindrome from Substring
题目如下: Given a string s, we make queries on substrings of s. For each query queries[i] = [left, right ...
- echart-如何画自定义的图形,三角形为例
- JavaScript正则表达式(四)
正则表达式方法 一.test方法 用于测试字符串参数中是否存在匹配正则表达式模式的字符串 如果存在就返回true,否则返回false 实例: 1.使用test方法不设置g标志时 2.使用test方法 ...
- 如何理解重载与重写——Overload vs Override/Overwrite
重载: 在同一个类中,拥有类似功能的同名方法之间的关系叫做重载. 重载的条件:1.具有相同方法名和类似功能: 2.参数的类型或者个数不同: 3.与返回值无关: 重写: 在子父类的继承关系中,子类继承父 ...
- Android ListView焦点事件冲突问题与解决
Android ListView对于单纯列表展示是很好用的,但是一旦牵扯到对listView进行操作就会遇到各种各样的问题.比如保存Checkbox状态与item复用的冲突.遇到可获取焦点的控件比如说 ...
- [CSP-S模拟测试]:小P的生成树(数学+Kruskal)
题目描述 小$P$是个勤于思考的好孩子,自从学习了最大生成树后,他就一直在想:能否将边权范围从实数推广到复数呢?可是马上小$P$就发现了问题,复数之间的大小关系并没有定义.于是对于任意两个复数$z_1 ...
- 为什么Redis可以方便地实现分布式锁
1.Redis为单进程单线程模式,采用队列模式将并发访问变成串行访问,且多客户端对Redis的连接并不存在竞争关系. 2.Redis的SETNX命令可以方便的实现分布式锁. setNX(SET if ...
- Microsoft windows terminal
https://github.com/microsoft/terminal 尝试在windows store中安装,结果everything搜索不到 I tried running WindowsTe ...
- 顶级域名、一级域名、二级域名与IP
转自:https://blog.csdn.net/qq_38071429/article/details/80339091 域名:可分三级,一级域名,二级域名,三级域名.是由一串字符+域名后缀组成,我 ...
- NOIP2012 洛谷P1083 借教室
传送门 题意:有一些学(xian)生(quan)要借教室.在n天内,第i天学校有ri个教室.有m份订单,每份订单有三个数值dj,sj,tj,分别表示这个订单从第sj天开始到第tj天结束(包括端点),每 ...