k8s学习笔记(1)- 简单部署springboot应用
前言:k8s全称kubernetes,k8s是为容器服务而生的一个可移植容器的编排管理工具,越来越多的公司正在拥抱k8s,并且当前k8s已经主导了云业务流程,关于更多的k8s知识,可自行学习
1、k8s环境搭建
k8s环境部署方式
minikube工具部署
参考文当:https://kubernetes.io/docs/setup/learning-environment/minikube/
适合场景:可以快速的部署一个单点的k8s,适合开发人员日常使用kubeadm工具部署
参考文档:https://kubernetes.io/docs/reference/setup-tools/kubeadm/kubeadm/
适合场景:可以通过kubeadm init和kubeadm join快速部署一个k8s集群,目前技术也比较成熟,适用于生产环境快速部署docker for windows k8s部署
参考文档:https://www.cnblogs.com/voidobject/articles/12980005.html
适合场景:可以快速的部署一个单点的k8s,适合开发人员日常使用rancher2.x k8s部署
参考文档:https://docs.rancher.cn/
http://docs.rancher.cn/docs/k3s/_index
适合场景:快速部署一个k8s集群,Rancher 是一个完整的软件堆栈,技术成熟,适用于生产环境快速部署
2、k3s介绍
K3s 是由 Rancher Labs 发布的一款开源、极轻量的Kubernetes 发行版,通过了CNCF一致性认证,适用于在资源有限的环境中运行Kubernetes。
K3s主要用于部署在资源受限的边缘计算场景中,也可以在本地运行以进行Kubernetes测试或开发。
K3s是为生产环境设计的,因此在PC或笔记本电脑上,K3s是与生产级服务器最接近的选项。
本文的操作的环境采用k3s环境
3、pod介绍
Pod是kubernetes中你可以创建和部署的最小也是最简单位。一个Pod代表着集群中运行的一个进程。
Pod中封装着应用的容器(有的情况下是好几个容器),存储、独立的网络IP,管理容器如何运行的策略选项。Pod代表着部署的一个单位:kubernetes中应用的一个实例,可能由一个或者多个容器组合在一起共享资源

创建pod的两种方式
a. kubectl命令方式
kubectl run springbootapp --image=xjk27400861/springbootapp:42 --replicas=3
备注:
--image 镜像名称及tag
--replicas指定副本数量
b. 文件方式
创建一个文件,springbootapp.yaml
执行创建命令构建pod
sudo kubectl create -f springbootapp.yaml
4、使用文件方式,构建pod
创建一个文件,springbootapp.yaml

文件内容

文件文本:
apiVersion: v1
kind: Pod
metadata:
name: springbootapp
labels:
app: springbootapp
spec:
containers:
- name: springbootapp
image: xjk27400861/springbootapp:42
ports:
- containerPort: 8080
备注:
image 指定镜像及tag
containerPort 指定容器释放端口
执行kubectl命令,构建pod
sudo kubectl create -f springbootapp.yaml

过一会,通过命令sudo kubectl get pods,可以查看到pod已创建成功
pod是运行在k8s内部,不能直接访问,我们需要再部署一个类似“反向代理”角色的Pod来帮我们访问应用。这个Pod是Service类型的
创建一个svc代理的yaml文件:springbootapp-svc.yaml,写入内容

输入命令,构建svc的pod
sudo kubectl create -f springbootapp-svc.yaml
or
sudo kubectl create -f springbootapp-svc.yaml -n springboot

我们可以通过命令,查看svc pod的状态
kubectl get svc -n springboot
-n 指定命名空间,不写默认default
在k3s任意节点,通过url可以看到app可以访问

进入pod命令,与docker命令类似:
sudo kubectl exec -it springbootapp bash
至此,我们完成了一个简单应用的部署,这是一个单体应用
参考资料url:
https://www.cnblogs.com/demingblog/p/12905569.html
https://blog.51cto.com/loong576/2420421
k8s学习笔记(1)- 简单部署springboot应用的更多相关文章
- K8S学习笔记之二进制部署Kubernetes v1.13.4 高可用集群
0x00 概述 本次采用二进制文件方式部署,本文过程写成了更详细更多可选方案的ansible部署方案 https://github.com/zhangguanzhang/Kubernetes-ansi ...
- K8S学习笔记之Kubernetes 部署策略详解
0x00 概述 在Kubernetes中有几种不同的方式发布应用,所以为了让应用在升级期间依然平稳提供服务,选择一个正确的发布策略就非常重要了. 选择正确的部署策略是要依赖于我们的业务需求的,下面我们 ...
- 【K8s学习笔记】K8s是如何部署应用的?
本文内容 本文致力于介绍K8s一些基础概念与串联部署应用的主体流程,使用Minikube实操 基础架构概念回顾 温故而知新,上一节[K8S学习笔记]初识K8S 及架构组件 我们学习了K8s的发展历史. ...
- OGG学习笔记04-OGG复制部署快速参考
OGG学习笔记04-OGG复制部署快速参考 源端:Oracle 10.2.0.5 RAC + ASM 节点1 Public IP地址:192.168.1.27 目标端:Oracle 10.2.0.5 ...
- JSP学习笔记(三):简单的Tomcat Web服务器
注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...
- ActionBarSherlock学习笔记 第一篇——部署
ActionBarSherlock学习笔记 第一篇--部署 ActionBarSherlock是JakeWharton编写的一个开源框架,使用这个框架,可以实现在所有的Android ...
- JAVA WEB学习笔记(三):简单的基于Tomcat的Web页面
注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...
- Spark学习笔记0——简单了解和技术架构
目录 Spark学习笔记0--简单了解和技术架构 什么是Spark 技术架构和软件栈 Spark Core Spark SQL Spark Streaming MLlib GraphX 集群管理器 受 ...
- Html学习笔记(二) 简单标签
标签的重点 标签的用途 标签在浏览器中的默认样式 <body>标签: 在网页上显示的内容 <p>标签: 添加段落 <hx>标签: 添加标题 标签一共有6个,h1.h ...
- k8s学习笔记(2)- Rancher2.x部署springboot应用及高可用、扩容
前言:上一篇介绍基于k3s环境,使用kubectl部署springboot简单项目应用,本篇介绍基于rancher2.x部署应用程序 1.上篇已部署一个springboot应用,我们可以通过ranch ...
随机推荐
- MySQL案例:一次单核CPU占用过高问题的处理
客户现场反馈,top的检查结果中,一个CPU的占用一直是100%.实际上现场有4个CPU,而且这个服务器是mysql专属服务器. 我的第一反应是io_thread一类的参数设置有问题,检查以后发现re ...
- HashSet的add()方法源码解析(jdk1.8)
HashSet 实现了Set接口 实际上是HashMap 可以存null,但只能有一个 不保证元素是有序的,取决于hash后,在确定索引结果 add源码 //核心操作putVal final V pu ...
- BUUCTF-[极客大挑战 2019]BuyFlag
BUUCTF-[极客大挑战 2019]BuyFlag 进去一看,哦原来是某安全团队的招募启示. 但没看到什么有用的信息,看到了Q群号,我还以为是一道社工题(=_=) 来到pay.php 看一下源码,发 ...
- Java的Class类及static块的执行时机
要理解RTTI在Java中的工作原理,首先必须知道类型信息在运行时是如何表示的,这项工程由Class对象完成,它包含了与类有关的信息.Java使用Class对象来执行其RTTI,即使你执行的是类似转型 ...
- Shell中常用的语句
exit 完全中断脚本的执行 break 中断脚本的循环,但是会执行循环外的语句 continue 跳出本次循环,进行下一次循环 进一步了解三者的区别,有如下实验: 执行该脚本: 脚本正常运行情况: ...
- Excel vba call Python script on Mac
How can I launch an external python process from Excel 365 VBA on OSX? It took me a while, but I fig ...
- vue 双向绑定(v-model 双向绑定、.sync 双向绑定、.sync 传对象)
1. v-model实现自定义组件双向绑定 v-model其实是个语法糖,如果没按照相应的规范定义组件,直接写v-model是不会生效的.再说一遍,类似于v-on:click可以简写成@click,v ...
- 20210720 noip21
又是原题,写下题解吧 Median 首先时限有 2s(学校评测机太烂,加到 4s 了),可以放心地筛 \(1e7\) 个质数并算出 \(s_2\),然后问题变为类似滑动求中位数.发现 \(s_2\) ...
- Mysql - You can't specify target table '表名' for update in FROM clause 错误解决办法
背景 在MySQL中,写SQL语句的时候 ,可能会遇到 You can't specify target table '表名' for update in FROM clause 这样的错误 错误含义 ...
- MongoDB 常见问题 - 解决找不到 mongo、mongod 命令的问题
问题背景 成功安装 MongoDB 后执行 Mongo.MongoD 显示找不到命令 解决方案 echo 'export PATH="/usr/local/opt/mongodb-commu ...