DHorse操作手册
在介绍DHorse的操作之前,我们先来看一下发布一个系统的流程是什么样的。
发布系统的流程
我们以一个Springboot系统为例,来说明一下发布流程。
1.首先从代码仓库下载代码,比如Gitlab;
2.接着是进行打包,比如使用Maven;
3.如果要使用k8s作为编排,还需要把步骤2产生的包制作成镜像,比如使用Docker;
4.上传步骤3的镜像到远程仓库,比如Harhor;
5.最后,下载镜像并编写Deployment文件部署到云集群,比如k8s;
从以上步骤可以看出,发布需要的工具和环境至少包括:代码仓库(Gitlab)、打包环境(Maven)、镜像制作(Docker)、镜像仓库(Harbor)、云集群(k8s)等;
在DHorse系统里,有些环境是对于用户来说是无需感知,因为已经做了集成,如:打包和镜像制作,可以参考文章:《DHorse系列文章之镜像制作》和《DHorse系列文章之maven打包》。其他的则需要配置,下面就一一介绍。
DHorse操作说明
代码仓库配置
如图1所示:
镜像仓库配置
如图2所示:
Maven配置
如图3所示:
在这里,可以指定打包时的Java版本信息,如果不指定,则默认使用DHorse系统所在的环境。
集群配置
进入“集群管理”菜单,可以进行添加集群操作,假如已经部署好k8s集群,则可以添加到DHorse,如图4所示:
我们可以通过如下方式生成k8s的认证令牌:
kubectl create serviceaccount "k8sadmin-dhorse" -n kube-system
kubectl create clusterrolebinding "k8sadmin-dhorse" --clusterrole=cluster-admin --serviceaccount=kube-system:k8sadmin-dhorse
secret=$(kubectl get -n kube-system serviceaccounts "k8sadmin-dhorse" -o jsonpath='{.secrets[0].name}')
kubectl get -n kube-system secrets $secret -o jsonpath='{.data.token}' | base64 -d
也可以开启日志收集功能,但是首先需要配置Dhorse安装目录下的conf/filebeat-k8s.yml文件,进行filebeat的配置。
在集群管理功能里,同时也提供了对命名空间管理的功能,如图5所示:
可以进行创建和删除命名空间。
完成以上配置以后,接下来我们就可以创建项目、创建版本、创建环境,然后进行发布了。
创建项目
在“项目管理”菜单下,可以添加项目操作,这里以添加一个Springboot项目为例进行说明,如图6、图8所示:
其中,代码仓库地址是对应代码仓库定义的项目路径或项目编号,比如GitLab项目编号如图7所示:
添加项目完成以后,就可以在“发布管理”菜单下看到分支信息,如图9所示:
可以看出,在分支列表里可以分别对每个分支进行“构建版本”操作,我们以对master分支进行构建版本为例,如图10所示:
然后进入“版本列表”菜单,可以看到产生了一条版本记录,同时也可以查看该版本的构建日志,如图11所示:
接下来,我们就可以创建一个环境,然后使用刚才构建的版本发布该环境。
发布项目
进入“环境管理”菜单,然后进行添加环境操作,如图12所示:
保存之后,“环境管理”列表里会出现一条环境记录,如果13所示:
接着,我们可以在“操作”列点击“部署”按钮,如图14所示:
选择刚才的版本,并点击“确认部署”。此时,进入到“部署历史”菜单下,可以看到产生了一条部署记录,同时可以查看该记录的日志,如图15所示:
等待部署完成以后,进入“副本管理”菜单,可以看到Pod的相关信息,如果16所示:
至此,一个完整的发布流程完成了。那么该如何访问hello项目的服务呢?
访问服务
集群内访问
假如hello项目里有一个/hello的api。
- 访问单个副本的服务
通过“副本IP:端口”进行访问,该方式在副本或Node节点都可以访问通,如图16所示的IP,访问示例:http://10.32.1.153:8080/hello
- 通过负载均衡
DHorse在部署项目以后,会默认为项目启动一个ClusterIP的service服务,可以通过“项目名称.命名空间:服务端口”来访问服务,该访问只能在副本里进行,示例如:http://hello.default:8080/hello
集群内服务之间的调用,推荐该方式。
集群外访问
两种方式:
- 通过创建NodePort或LoadBalancer,目前DHorse不支持,如果需要可以手动在集群内创建;
- 打通集群内外的网络,该方式需要运维的支持,如:通过静态路由转发等。集群内外网络互通以后,在集群外部就可以直接访问副本的IP了。
相关文章
- RHCE环境准备 | 介绍
- 登云之路|腾讯大规模云原生技术实践案例图鉴
- 我做了一款vscode主题! Dapanna Theme
- 第一周好文分享(强推这个系列!)
- canvas详细教程! ( 近1万字吐血总结)
- canvas绘制动画原理及案例讲解(绘制小恐龙动画、时钟等)
- 纯Canvas绘制绘制小恐龙向前冲游戏(Vue3版本的升级版)
- 关于css的八个结构伪类选择器 :last-child、:first-of-type、:nth-last-of-type()
- 核酸码系统拆解与设计推演
- 从零开始的内存马分析——如何骑马反杀(二)
- 从零开始的内存马分析——如何骑马反杀(三)
- 神兵利器|网络资产测绘平台聚合工具(AsamF)
- Hadoop3.0-Hdfs | Apache Hadoop介绍
- 记一次对HTB:Timelapse的渗透测试
- Ansible环境部署 | 概述
- Veinmind 在 Jenkins 的0部署成本自动化扫描方案
- 攻防|记一次攻防演练实战总结
- Java入门学习
- 168张图,万字长文,手把手教你开发vue后台管理系统!
- 这才是文件上传和下载的正确方式!