从来不懂K8s的人10分钟内将应用跑在了K8s中

news2024/9/22 20:35:08

大家可能都听说过 K8s 或者 docker ,可能有容器编排的概念,知道这会提高运维效率,但是由于上手难度高迟迟没有学习它。

今天我以自己的实际经历教大家将自己的应用在10分钟内部署到k8s中,你不需要懂任何的 docker 命令和 k8s 命令就能管理应用。就是这么酷~

背景

2019年疫情的影响,大学生们纷纷开始在家上网课。
然而,他们可能会遇到老师留下的作业问题,而不知道如何解决。
同时,在进行百度搜索时,经常会遭遇许多广告的干扰。
因此,我计划开发一款专门为大学生提供搜题功能的APP。

起初所有业务都写在一个 jar 包,为了实现低耦合,我耗费大量精力,将其模块化。
模块化后可能分为多个模块,比如文档模块,搜题模块,用户模块,网关模块…
微服务模块又需要注册中心,为了应对突发流量又引入了sentinel流量控制。
越来越多的应用需要部署,而且管理愈发困难。

为了解决这个问题,这时候我使用了Jenkins 自动化构建与部署,自己手动部署了其他的依赖环境后,jar包的构建运行任务交给 Jenkins 来做。

这时候我发现还有一些不满足需求的地方,我需要寻找一款全自动,可视化的运维工具。最终发现了 Rainbond 这个应用管理平台。

这篇文章主要分享我探索全自动化运维的道路。

Jenkins 自动化及其遇到的挑战

懒惰是我进步的动力,为何不利用节约下来的时间多享受一会呢?

思考中,我萌生了自动化部署和运行的想法。
我本地提交到github,通过配置webhook,jenkins可以自动拉java代码并构建,
最后分发到我指定的服务器上并运行。

在这里插入图片描述

可以看到这是一连串的操作。确实节省很多时间,但是其中某个步骤出问题都会导致分发失败。

我在想虽然构建运行自动化了,但是如果我的应用突然宕机了,
那么我自己也不知道啊,只有用户来反馈的时候,我才能知道我网站原来进不去了。

这时候我在想:是不是有一种工具可以检测应用是否在线呢?

找到了很多可以检测应用是否在线的开源工具,应用宕机自动通知,
但是,通知我有什么用呢?
我在外旅游,我又无法去重新运行它。

这时候我意识到,事情没有我想的那么简单!

总结下可以分为以下几点:

  • 应用宕机,自己不知道,需要客户反馈?
  • 宕机后需手动重启?
  • 更新代码重新运行的时候有些应用启动时间比较长,造成服务中断,怎么样让新应用起来之后再关闭旧应用呢?
  • 查看日志的时候 不想登陆服务器执行 tail xxx。有没有支持点击查看应用日志的呢?
  • 流量太大,需要启动多个应用负载均衡?
  • 对于非java应用支持可能不友好。

于是我开启了新的探索之路。

追寻一款自动化运维工具

Kubernetes(简称 K8s)名声在外,大家是否听说过?

起初,我觉得 K8s 确实可以解决我当前的所有问题。但是,K8s的安装与学习成本非常高。

可能我自己对它的概念不够清楚,但定位上我大致知道是方便运维的。因此为了能减轻我自己运维的负担,我开始百度,疯狂寻找 K8s 可视化工具,挺多的,但是很多都不维护了,这样子出了 bug 也没人能解决啊!

Rainbond的诞生

无意间发现了 Rainbond 平台,看其介绍发现不用懂 K8s 也可以把应用部署到 K8s 中, 并且实现可视化运维管理。

而且其设计理念是:不需要懂 K8s 也能轻松管理容器化应用,平滑无缝过渡到 K8s。正好解决我的需求。

K8s 运行的应用可能需要打 docker 镜像后编写复杂 yaml 文件,过程枯燥无味,并且新手上手难度高。

而 Rainbond 为我们做了这件事,从源码到运行,全权负责,你只需要提供源码,Rainbond自动帮你运行起来。
而且运行在自己的服务器,数据安全有保证。

关键:它还是开源的!Github 地址:https://github.com/goodrain/rainbond

安装Rainbond

安装的时候,出乎意料之外的简单,只需要一句命令。而且 5 分钟就可以把平台全部运行起来,包括 K8s。这让我难以置信!!

curl -o install.sh https://get.rainbond.com && bash ./install.sh

部署自己的应用

平台运行起来后,就需要部署我自己的应用了。

我的业务主要还是 Java 开发的,之前我都是需要打出 Jar 包,再去运行。从来没了解过 docker 镜像怎么打。而使用 Rainbond 的时候,我发现它对于各种开发语言(Java、NodeJS、Go、Python、Php等)都支持的比较好,只需要提供代码仓库地址,它就能把代码打包成镜像并且运行起来。下面就以我自己的 Java-Maven 项目为例部署试试。

把大象关进冰箱需要三步,而把我的代码运行到 K8s 上也只需要三步:输入代码仓库地址->调整构建参数->构建。

1. 输入代码仓库地址

首先我通过源代码构建,输入我自己的仓库地址,点击创建。出现提示:组件构建源检测中…大概不到30秒通过了。竟然自动识别了是maven项目。
在这里插入图片描述
在这里插入图片描述

2. 调整构建参数(可选)

在识别出我的代码是 Java-Maven 以后,点击下一步,会有详细的源码构建参数让我配置,主要包含 JDK 类型、JDK 版本、Maven 版本以及启动命令等参数。这些都是默认生成的,但是也可以根据自己的需求来修改。
在这里插入图片描述
需要注意的点主要在于,在页面上配置端口时,这里的端口号需要与代码启动时的端口一致,也就是 server.port 配置的值。如果端口不对,可能会导致业务无法访问。如果不需要监听端口可直接删除,或者修改。

3. 构建

点击确认构建之后,可以查看构建日志,它会自动从 maven 仓库下载依赖,自动构建,再打包出镜像并运行到 K8s 上,大概 3 分钟左右就全部构建完成,而且成功运行了。此时点击页面右上角的访问,即可直接访问到我自己的业务了。
在这里插入图片描述
此外,Rainbond 还有完善的监控页面,可以清楚知道 CPU 和内存的使用量。
在这里插入图片描述
哦?还有应用的运行的实时日志?不错不错!看,这是熟悉的Spring日志呀!

而且还在【其他设置】中找到了我梦寐已久的应用宕机自动重启。
在这里插入图片描述

简单配置之后,检测应用是否宕机,宕机就可以重启应用,再也不用让客户来反馈网站进不去了!!!
在这里插入图片描述

至此基本功能已经完全满足了我的需求,于是好奇的我再次点了一下构建。
在这里插入图片描述

它会再次从 git 仓库拉代码,云端自动构建,构建成功之后自动运行。

另外这里 Rainbond 考虑的很周到,在构建完成应用启动时,它会先运行新应用,新应用运行起来之后才会关闭旧应用!完美解决了我之前每次更新服务,都需要停机几分钟的问题。

更多好玩的,自己去装一下试试,我就不一一介绍了,我去迁移应用去喽!

  • 更多功能请参考 Rainbond 官网:https://www.rainbond.com

对比

相比于之前传统运维任何操作都需要自己手动执行,繁琐又枯燥的问题。Jenkins 帮我解决了自动构建和自动部署的问题。而 Rainbond 则帮我解决了更新业务服务中断以及我应用过多后的管理问题。我简单做了个对比表格如下:

任务传统运维jenkinsrainbond
自动构建
自动部署
更新代码服务不中断
弹性伸缩
可视化监控
日志
集群

如果你使用了 Rainbond 来管理应用,那么可以做到以下几点:

  • 应用自动构建部署运行,支持多语言源码。
  • 如果应用宕机了,Rainbond 可以帮我们检测出来,让他自动重启或者下线这个应用。
  • 我升级的时候,Rainbond 可以先开启新应用,然后再关闭旧应用,实现服务不中断。
  • 流量大的时候,他会自动负载均衡,帮我们再启动一个服务实例来实现负载均衡。
  • 并且还可以在 Rainbond 控制台查看某个应用的实时日志。

转型成功

从此,我写完代码,提交到 git 之后,webhook 通知了 Rainbond 平台,Rainbond 自动拉取代码
根据代码语言自动构建,然后打包成 docker 镜像,最后生成 K8s 所需要的 yaml 文件运行到 K8s 中,
一键完成了应用的构建和部署。

当然不仅仅是这些,Rainbond 还可以很方便的重启,停止,启动,构建应用。当我有些业务暂时不需要时,我还可以先关闭节省资源,需要时再一键启动即可。

可视化的监控,可以监控应用的 CPU 使用量和内存使用量,非常之完美!

并且还有很方便的web终端,可以直接进 linux 系统执行命令。

之前我查看应用日志还要 ssh 连接服务器,进入日志目录执行 tail xx 命令,特别繁琐,并且我压根不知道应用占用的内存和 CPU 使用情况,对自己的应用状态一无所知,Rainbond 做到了全部可视化。

节省的时间可以放心外出旅游了!
再也不怕用户返回网站进不去了!

下面是我自己的应用全部部署好以后的拓扑图。细心的小伙伴可能会发现,应用之间有连线,是有关联的,这是应用之间的依赖关系。如果 Java 应用依赖 mysql ,mysql 启动异常了,Java 应用是不会启动的,需要先启动 mysql 应用后才会启动 Java。Rainbond 启动应用时会严格按照应用的启动顺序来启动应用。

而且绿色表示应用全都处于运行中,一旦哪个服务出现问题,这里就会变成红色,一目了然。


Rainbond 官网:https://www.rainbond.com

Github 地址:https://github.com/goodrain/rainbond

钉钉群:30885018060

微信群:添加小助手微信拉你进群

wechat

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/908908.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LinkedList

LinkedList的模拟实现(底层是一个双向链表)LinkedList使用 LinkedList的模拟实现(底层是一个双向链表) 无头双向链表:有两个指针;一个指向前一个节点的地址;一个指向后一个节点的地址。 节点定…

STM32单片机实现Bootloader跳转的关键步骤

感谢关注! 本期话题 现在越来越多的嵌入式设备支持远程自动升级,不需要再借助下载器。这样对于设备的维护非常方便。 当然若使设备支持远程升级,需要编写支持升级的程序代码,可以称之为 BootLoader。 也就是说,将设…

【二叉树构建与遍历3】先序遍历+后序遍历构建一个满二叉树并输出中序遍历 C++实现

注意:根据先序遍历与后序遍历只有在满二叉树的情况下才能确定一个唯一的树。这里介绍的是根据先序遍历后序遍历构建一个满二叉树并输出中序遍历顺序。 思路: 先来一个例子: 先序遍历序列为:FDXEABG 后序遍历序列为:…

股票委托接口的部分源码分析(一)

对于一些股票委托接口的源码分析需要具体指定的交易系统可能有不同的接口实现。以下是对一个常见的股票委托接口实现的源码分析示例: import requestsdef place_order(symbol, price, quantity, side): url https://example.com/api/place_order payload {…

gRPC 客户端调用服务端需要连接池吗?

发现的问题 在微服务开发中,gRPC 的应用绝对少不了,一般情况下,内部微服务交互,通常是使用 RPC 进行通信,如果是外部通信的话,会提供 https 接口文档 对于 gRPC 的基本使用可以查看文章 gRPC介绍 对于 g…

ClickHouse(二十三):Java Spark读写ClickHouse API

进入正文前,感谢宝子们订阅专题、点赞、评论、收藏!关注IT贫道,获取高质量博客内容! 🏡个人主页:含各种IT体系技术,IT贫道_Apache Doris,大数据OLAP体系技术栈,Kerberos安全认证-CSDN博客 &…

vue开发环境搭建(WebStorm)

一、安装Node.js,搭建Vue环境 1、访问Node.js官网(https://nodejs.org/en/download/)进行安装包下载。 2、下载成功之后运行安装程序,进行安装。 如果是用安装程序进行安装,在安装过程中会自动进行Nodejs环境变量的配置…

最新两年工作经验总结

最新两年工作经验总结 前言URP的使用1:如何开启URP1、老项目升级为URP2、创建新项目时选择URP创建 2:URP阴影的设置 PolyBrush的使用(地图编辑插件)制作山峰or低谷边缘柔化雨刷上色制造场景中的物体贴图地形创建容易踩坑的点ProBu…

springboot大文件上传、分片上传、断点续传、秒传的实现

对于大文件的处理,无论是用户端还是服务端,如果一次性进行读取发送、接收都是不可取,很容易导致内存问题。所以对于大文件上传,采用切块分段上传,从上传的效率来看,利用多线程并发上传能够达到最大效率。 …

示例1:FreeRTOS移植详解_基于HAL库工程

1、开发环境 (1)Keil MDK: V5.38.0.0 (2)STM32CubeMX: V6.8.1 (3)MCU: STM32F103C8(F1系列软仿真最方便) (4)ARM编译器:V5(使用V6编译会报错) 2、移植准备工作 (1)用于移植FreeRTOS的基础工程。 时钟已配置好串口已配置好printf已经重定向到串口1 (2)FreeRT…

《YOLO小目标检测》专栏介绍 CSDN独家改进创新实战专栏目录

💡💡💡Yolo小目标检测,独家首发创新(原创),适用于Yolov5、Yolov7、Yolov8等各个Yolo系列,专栏文章提供每一步步骤和源码,带你轻松实现小目标检测涨点 💡&…

【二分查找篇】速刷牛客TOP101 高效刷题指南

文章目录 17、BM17 二分查找-I18、BM18 二维数组中的查找19、BM19 寻找峰值20、BM20 数组中的逆序对21、BM21 旋转数组的最小数字22、BM22 比较版本号23、BM23 二叉树的前序遍历 17、BM17 二分查找-I 思路步骤: step 1:从数组首尾开始,每次取…

wustojc日期格式变化

#include <stdio.h> int main() {char a[10];for(int i0;i<10;i){//用一个耍聪明的方法&#xff0c;全部用数组存储&#xff1b;面向结果编程a[0]getchar();}printf("%c%c%c%c%c%c%c%c%c%c",a[6],a[7],a[8],a[9],a[2],a[0],a[1],a[5],a[3],a[4]);return 0;}…

什么是跳跃表 ? 说一说跳跃表的查询和新增流程 ?

1.什么是跳跃表&#xff08;Skip List&#xff09; 跳跃表是 ZSet 有序列表底层的一种实现&#xff0c;也成为跳表。它通过添加多层链表的方式&#xff0c;用于在有序集合中进行高效的查找操作。 简单跳跃表的结构图&#xff1a; 从图中可以看出跳跃表有这些特征&#xff1a; …

Nginx-URLRewrite伪静态

URLRwrite是指将真实地址隐藏&#xff0c;用户访问是通过伪地址进行访问&#xff0c;这样可以隐藏URL中的传参等等 URLwrite演示&#xff0c;浏览器输入伪URL&#xff0c;回车会跳转到真实URL Rewrite匹配规则 redirect是指当请求伪装地址后&#xff0c;页面会直接跳转到真实…

基于微信小程序的上门维修评价系统_22c7h-

随着科学研究的不断深入&#xff0c;有关上门维修的各种信息量也在成倍增长。面对庞大的信息量&#xff0c;就需要有上门维修系统来提高管理工作的效率。通过这样的系统&#xff0c;我们可以做到信息的规范管理和快速查询&#xff0c;从而减少了管理方面的工作量。 建立基于微信…

聊聊 Docker

聊聊 Docker Docker 是什么&#xff1f; 定义 Docker 是一款 开源的应用容器引擎。 简单来说&#xff0c;就是 以容器虚拟化技术为基础的软件。可以把应用程序和所依赖的包一起打包到一个可移植的镜像中&#xff0c;发布到 Linux 或者 Windows 上运行。&#xff08;代码 运…

数据通信——传输层(传输层概述)

引言 终于到传输层了&#xff0c;网络层还有很多需要补充的&#xff0c;后期在慢慢填补了。 我们看哈&#xff01;在物理层我们设计出来各种硬件&#xff0c;然后使它们在物理上相互连接&#xff0c;信号以比特流的形式进行发送&#xff1b;随后&#xff0c;在数据链路层&#…

Mybatis介绍和搭建(详细搭建步骤)

目录 一、mybatis介绍 官方简介 通俗易懂 二、搭建步骤 1.创建Maven项目 2.创建数据库并建表和相关类 3.创建全局配置文件,配置数据库连接信息 4.配置sql映射文件 5.测试 一、mybatis介绍 官方简介 MyBatis 是一款优秀的持久层框架&#xff0c;它支持自定义 SQL、存…

C语言和JavaScript中的默认排序行为对比

前言 今天在js里使用sort时遇见了一个不理解的现象 即使用sort默认排序后 9 从排序前的第一位被排到了最后一位.一开始我对js sort的理解和c一样&#xff0c;然后通过查阅后发现并不是这样. 正文 排序是一项常见而重要的操作。不同的编程语言提供了不同的排序函数&#xf…