大家可能都据说过 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 则帮我解决了更新业务服务中断以及我利用过多后的治理问题。我简略做了个比照表格如下:
工作 | 传统运维 | jenkins | rainbond |
---|---|---|---|
主动构建 | ❌ | ✅ | ✅ |
主动部署 | ❌ | ✅ | ✅ |
更新代码服务不中断 | ❌ | ❌ | ✅ |
弹性伸缩 | ❌ | ❌ | ✅ |
可视化监控 | ❌ | ❌ | ✅ |
日志 | ❌ | ❌ | ✅ |
集群 | ❌ | ❌ | ✅ |
如果你应用了 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
微信群:增加小助手微信拉你进群