K8S命令行可视化实验

以下为K8s命令行可视化工具的实验内容,相比于直接使用命令行,可视化工具可能更直观、更易于操作。

Lens

Lens是用于监控和调试的K8S IDE。可以在Windows、Linux以及Mac桌面上完美运行。在 Kubernetes 上:

托管地址:github/lensapp/lens开发语言:TypeScript项目热度(星):16100

IDE下载地址:https://k8slens.dev/

Lens官方文档:https://docs.k8slens.dev/

安装Lens

  1. Linux 直接snap安装即可,sudo snap install kontena-lens --classic
  2. Window

下载软件安装即可,但是需要创建账号,并且需要付费,目前是14天免费使用,创建账号后会有一个用于登录code,在登录的时候把那段代码填进去就可以登录。

本次实验是在window环境下完成的,所以直接下载桌面应用

使用Lens

添加集群

首先找到k8s集群的config文件,命令:

cat ~/.kube/config

将上述命令的输出内容复制,在lens中添加集群的时候会用到

然后将​​cat ~/.kube/config​​命令输出的内容,也就是k8s的config文件的信息填入到下方的红框,点击“add clusters”

即可添加集群成功

连接集群

双击刚才添加完成的集群,完成集群的连接。

当集群的状态是“connected”即可,表示集群连接成功,在页面就能看到已经连接的集群的相关信息。

如下是连接好的集群的状态信息:

  • 左侧是一些资源分类
  • 右侧是资源的显示面板

基本操作
新建命名空间

平时用命令行新建命名空间 ;​​len-test​​,需要执行命令:

kubectl create ns lens-test

在Lens可视化工具中只需要点击 Namespace 界面右下方的 ​​+​​,写好名字就能创建了。

新建Deployment

如果要创建 Deployment,一般是写好 yaml 文件,然后执行命令:

kubectl create -f deployment.yaml
// deployment.yaml 
apiVersion: apps/v1
kind: Deployment
metadata:name: nginx-deploymentlabels:app: nginxnamespace: lens-test
spec:replicas: 3selector:matchLabels:app: nginxtemplate:metadata:labels:app: nginxspec:containers:- name: nginximage: nginx:1.14.2ports:- containerPort: 80

而在 Lens 里只需点击 ​​Create resource​​,然后将 yaml 贴到文本框就好了:

在创建资源的时候,除了可以自己填写yaml文件,还能选择Lens提供的yaml模版,如下图所示:

选择对应的资源名称,例如Deployment,自动填充yaml文件,用户可以直接创建也能够自定义修改。

创建好的Deployment如下图:

上图中Condtions字段:在 Kubernetes 的 Deployment 控制器中,​​progressing​​​ 和 ​​available​​ 是与滚动更新相关的两个状态条件。它们用于描述 Deployment 的不同阶段和可用性。

  1. Progressing(进行中):
  1. 当 Deployment 正在进行滚动更新时,这个条件会被设置为 ​​True​​,表明正在逐步更新 Pods,但还没有达到期望的状态。例如,可能有一些 Pods 正在启动,而另一些 Pods 已经被停止,处于更新的过程中。
  1. Available(可用性):
  1. 当所有 Pods 都已成功启动并运行,并且没有出现故障时,​​Available​​​ 被设置为 ​​True​​​。如果某些 Pods 处于不可用状态,​​Available​​​ 就会被设置为 ​​False​​。
调整副本

这个 Deployment 目前只有 3 个副本,想调整下副本数该怎么操作呢?

现在选择 Deployment 并点击 ​​Scale​​ 就可以调整副本了:

进入容器

有时我们需要进到容器里去查看状况。如果用命令行的话,需要先获取到 Pod 的名字,然后再连接:

//获取 Pod 的名字
kubectl  get pod -n test
NAME                                      READY   STATUS    RESTARTS   AGE
nginx-deployment-basic-54f57cf6bf-ktw4f   1/1     Running   0          52m
nginx-deployment-basic-54f57cf6bf-tfstr   1/1     Running   0          30m//连接
kubectl exec -it nginx-deployment-basic-54f57cf6bf-ktw4f bash -n test

现在只需在 Pods 界面选择 Pod,然后点击 ​​Shell​​ 就可以连接了:

K9S

K9S提供一个来与K8S集群交互的终端UI。可以类比为针对K8S集群的Top命令。可以轻松列出、观察和管理集群中各个应用程序。

托管地址:github/derailed/k9s开发语言:Golang项目热度(星):14000

下载地址:https://github.com/derailed/k9s/releases

安装K9S

下载命令:

curl -sS https://webinstall.dev/k9s | bash

本实验环境上述命令执行失败,故在下载地址:https://github.com/derailed/k9s/releases中下载了v0.26.7/k9s_Linux_x86_64.tar.gz安装包。然后放在/usr/local/bin目录下

安装命令:

$tar -zxvf k9s_Linux_x86_64.tar.gz
LICENSE
README.md
k9s
$ mv k9s /usr/local/bin/
$ls
k9s  k9s_Linux_x86_64.tar.gz  LICENSE  README.md
$k9s
//使用该命令就会弹出当前集群资源的统计信息

然后就会弹出当前集群资源的统计信息。K8S集群中资源的变化是实时出现的。用于显示当前的这些信息非常有用。

参数解释:

  • NAMESPACE(命名空间): 显示 Pod 所属的 Kubernetes 命名空间。命名空间是 Kubernetes 中用于隔离和组织资源的一种方式。
  • NAME(名称): 显示 Pod 的名称。
  • PF(端口转发): 如果有端口转发(Port Forwarding)正在运行,将显示一个 ● 符号。
  • READY(就绪状态): 显示 Pod 中容器的就绪状态。例如,​​1/1​​ 表示有一个容器,且该容器的就绪状态为 1。
  • RESTARTS(重启次数): 显示容器的重启次数。如果容器发生故障或被重启,将增加此计数。
  • STATUS(状态): 显示 Pod 的当前状态。
  • IP(IP 地址): 显示 Pod 的 IP 地址。
  • NODE(节点): 显示 Pod 所在的 Kubernetes 节点。
  • AGE(运行时间): 显示 Pod 运行的时间。

使用K9S

K9s使用别名来定位到大多数K8s资源。这里贴出K9S官方的按键绑定。

使用方法:在输入 ​​k9s​​ 后,弹出集群资源信息页面,然后直接输入上述的快捷键命令,就能完成指定操作。

​:ctx ​​ 是用来切换集群的。

/-f filter​​ 根据提供的正则表达式进行搜索 ​​/filter​​ 相当于一个简单的文本搜索功能。

与 kubectl 相同,K9s 启动时会读取默认的 ​​kubeconfig​​。

如果有多个 config 文件,可以通过 ​​--kubeconfig​

k9s --kubecnotallow=/.kube/config
ctrl+a指令-显示所有可用资源的别名

通过这个快捷键我们可以快速查看K8s的资源别名(缩写),帮助我们轻松资源,提高工作效率。

第一列为k8s资源名称,第二列为K9s 控制台对应的资源简称(别名)。

以只读权限运行k9s

k9s为用户提供了方便的管理k8s资源的方式,同时也带来了安全上的风险,为了避免误操作对环境造成影响,我们可以在启动k9s时指定参数,以只读方式运行:

k9s --readonly
?-显示K9s提供的命令控制台的快捷键。

/-进入过滤模式

输入​​/etcd​​,对当前视图下的资源进行过滤,查找含有etcd字符串的

所有​​pod​​:

过滤的字段包括 名称、标签、运行状态。

什么也不输入的资源显示图:

输入/-f etcd 的结果图:

Esc

相当于历史回退按键,表示上一步

: -进入命令行模式

允许你输入想要查看的任何资源/资源别名。例如:​​:deploy​​​,​​:svc​​​...... 输入​​​:ns​​​,查看当前集群的所有​​namespace​​:

和k8s一样,可以查看指定命名空间的资源,命令格式​​:资源类型 namespace​​​。 输入​​​:cm default​​​,看一下​​default​​​名称空间下的​​configmap​​资源如下:

注意:k9s不能够一键查看所有资源,只能依据输入的资源类型进行查看

d y l e

​d​​​ ​​y​​​ ​​l​​​ ​​e​​​:分别对应于​​describe​​​ ​​yaml​​​ ​​logs​​​ ​​edit​

通过上下按键或者鼠标选中资源,然后输入 y 就能查看它的yaml文件

注意:一般来说,K9s 支持编辑的资源对象包括 Deployment、StatefulSet、Pod、ConfigMap、Secret 等常见的 Kubernetes 资源。这些资源对象通常都是可以被编辑的,因为它们具有一些可修改的属性,比如副本数、标签、容器镜像等。

Ctrl+z-快速定位资源错误信息

筛选出错误的资源列表,再按一次​​Ctrl+z​​就会显示所有状态的资源

Ctrl+d-删除选中的K8s资源,删除前提示

Ctrl+k-直接删除资源,没有提示
使用 XRay 视图获取资源的树状关系图

通过 ​​:x <res> [ns]​​​ 可以进入 XRay 视图,从而查看和遍历资源之间的关系和关联,并检查引用的完整性。比如我们通过 ​​:x dp​​ 可以进入如下的 Deployments 资源 XRay 视图,它会以 Deployments 为基础通过树状关系图罗列其所包含的 Pods 及 Pods 所绑定的其它资源。目前 XRay 支持探查:Pods, Deployments, StatefulSets, Services, DaemonSets。

:x pod

:q Ctrl c-退出K9s
在指定命名空间运行k9s
k9s -n default

获取帮助指令
k9s help
获取全部操作指令
k9s
# 输入 ?
?

注:k9s没有创建资源的功能

Kubetree

一个应用程序可以有很多不同的资源,它们的映射总是显而易见的。 Kubetree可以用来显示K8S对象之间的所有权关系的插件:

托管地址:https://github.com/ahmetb/kubectl-tree开发语言:Shell项目热度(星):1900

安装Kubetree

kubectl krew install tree
kubectl tree --help

使用Kubetree(未成功)

说明:安装是成功的,但是不能使用,报错结果如下所示。经过查询,是Kubernetes Ingress 资源的 API 版本是​​extensions/v1beta1​​,而在 Kubernetes 版本 v1.14 之后,这个 API 版本就被弃用(deprecated),在 v1.22 版本之后将不再可用。需要更新 API 版本。

kubetail

kubetail可以非常方便的查看多个pod的日志

kubetail将来自多个pod的日志聚合到一个流中。它的效果类似于对多个pods运行kubectl logs -f。

要一次性跟踪两个“app2”pods的日志,只需执行以下操作:

$ kubetail app2

要仅跟踪来自多个pod的特定容器,请按如下方式指定容器:

$ kubetail app2 -c container1

您可以重复​​-c​​来跟踪多个特定容器:

$ kubetail app2 -c container1 -c container2

要同时跟踪多个应用程序,请用逗号分隔它们:

$ kubetail app1,app2

可以在pod中指定容器:

kubetail app2 -c container1
kubectail app2 -c container1 -c container2

托管地址:github/johanhaleby/kubetail开发语言:Golang项目热度(星):2400

安装 Kubetail

由于 Kubetail 只是一个 Shell 脚本,直接下载后便可使用。

$ wget https://raw.githubusercontent.com/johanhaleby/kubetail/master/kubetail
$ chmod +x kubetail
$ cp kubetail /usr/local/bin

因服务器无法联网,本次实验直接在kubetail代码托管地址的release地址下载脚本,下载下来的目录中有一个‘kubetail’文件,把他放在服务器的/usr/local/bin目录下,并且使用​​chmod +x kubetail​​更改它的权限,就可以使用了。

使用 Kubetail

Kubetail 的使用,基本语法如下:

kubetail <search term> [-h] [-c] [-n] [-t] [-l] [-d] [-p] [-s] [-k] [-v] [-r] [-i]

一些常用参数的解释:

-c:指定多 Pod 中的容器名称

-t:指定 Kubeconfig 文件中的 Context

-l:标签过滤器,使用 -l 参数之后,会忽略 Pod 名称

-n:指定命名空间

-s:指定返回一个相对时间之后的日志,例如 5s,2m 或者 3h,缺省是 10s

-k:指定输出内容的具体着色部分,pod:只给 pod 名称上色,line:整行上色(缺省),false:不上色

一些使用实例:

上图是实验截图,下面的是网图。

​kubectl log​​ 更适合查看单个pod的日志,而 ​​kubetail​​ 更适合查看 多个Pod 的日志。

不同的pod用不同的颜色标识

Kube-shell(未成功)

失败原因:Kube-shell是基于​​python​​-prompt-toolkit实现的,旨在提供Kubectl的易用性并提高生产力。,需要先部署python环境,需要安装依赖项,用到apt install ,该命令在服务器中执行不了(估测是服务器网络问题)所以没成功。

在使用kubectl命令时候很多繁琐的选项不好记忆,容易记错,如果在输入命令时候能自动提示和补全则会非常有效。kube-shell是Kubernetes CLI的集成shell。它提供了易于使用的kubectl以提高生产力:

托管地址:github/cloudnativelabs/kube-shell开发语言:Python项目热度(星):2000

Kubectx-Kubens

使用kubectl操作kubernetes集群的过程中,可能会遇到需要操作不同集群的问题

对于管理多个K8S集群的伙伴, kubectx可以帮助在集群之间无缝切换:

kubectx获取集群相关信息时,常常需要在kubectl命令中指定命名空间。而kubens则允许我们可以省略该参数。

托管地址:https://github.com/ahmetb/kubectx 开发语言:Golang项目热 度(星):11600

安装Kubectx

安装命令:

curl https://github.com/ahmetb/kubectx/releases/download/v0.9.5/kubectx -o usr/local/bin/kubectx
chmod +x usr/local/bin/kubectx

本次实验环境的安装:打开https://github.com/ahmetb/kubectx/releases/download/v0.9.5/kubectx下载文件,然后放到服务器上,移动文件位置到 /usr/local/bin 命令是:mv kubectx /usr/local/bin,再更改文件的权限 chmod +x usr/local/bin/kubectx,最后就可以使用命令了。

使用Kubectx

常用命令:

kubectx                     : 列出目前所有的context
kubectx <NAME>              : 切换到<NAME>对应的context
kubectx -                   : 切换到上一次的context
kubectx <NEW NAME>=<NAME>   : 给<NAME>context命名一个新名字
kubectx <NAME>=.            : 给当前context命名一个新名字

集群切换

安装Kubens

linux环境:

curl -L https://github.com/ahmetb/kubectx/releases/download/v0.9.1/kubens -o usr/local/bin/kubens
chmod +x /bin/kubens

k8s每次查看指定命名空间的资源都需要加 -n 命名空间 来指定命名空间,我们可以通过开源项目​​kubens​​来切换当前命名空间,切换命名空间后,就无需每次都使用 -n 命令来指定命名空间了。

使用Kubens

列出所有的ns
[root@master-1 ~]# kubens  ##列出当前命名空间
default # 当前 ns 会有突出颜色显示
etcd-backup
kube-node-lease
kube-public
kube-system
kubesphere-controls-system
kubesphere-devops-system
kubesphere-monitoring-federated
kubesphere-monitoring-system
kubesphere-system
lens-test
切换ns
[root@master-1 ~]# kubens kube-system ##切换命名空间为kube-system
Context "kubernetes-admin@kubernetes" modified.
Active namespace is "kube-system".[root@master-1 ~]# kubectl get pods ##切换命名空间后,无需指定命名空间,即可查看切换后的命名空间资源
NAME                                       READY   STATUS    RESTARTS   AGE
calico-kube-controllers-578894d4cd-k4ccx   1/1     Running   0          39h
calico-node-4svc2                          1/1     Running   0          39h
calico-node-r8xlx                          1/1     Running   0          7h42m
calico-node-vvksl                          1/1     Running   0          7h47m
coredns-7ff77c879f-sz87s                   1/1     Running   0          2d1h
coredns-7ff77c879f-v8vg8                   1/1     Running   0          2d1h
etcd-master-11                             1/1     Running   0          2d1h
kube-apiserver-master-11                   1/1     Running   0          2d1h
kube-controller-manager-master-11          1/1     Running   16         2d1h
kube-proxy-4q2fg                           1/1     Running   0          2d1h
kube-proxy-fpn7d                           1/1     Running   0          7h42m
kube-proxy-mvwf7                           1/1     Running   0          7h47m
kube-scheduler-master-11                   1/1     Running   17         2d1h
metrics-server-57bc7f4584-zkbqz            1/1     Running   0          6h48m

Kube-Capacity

kube-capacity是一个简单的CLI,提供了Kubernetes集群中资源请求、限制和使用的概况。帮助我们快速查看概览整个集群和​​pod​​的资源配置情况。

检查集群节点:

加--pods查看Pods信息:

托管地址:github/ robscott/kube-capacity开发语言:golang项目热度(星):767

安装Kube-Capacity

kubectl krew install resource-capacity

本实验的安装方法是在https://github.com/robscott/kube-capacity/releases下载​​kube-capacity_v0.7.4_linux_x86_64.tar.gz​​,然后将下载下来的文件解压,将其中的kube-capacity二进制文件放到/usr/local/bin目录下,就可以使用kube-capacity命令了

使用Kube-Capacity

默认情况下,​​kube-capacity​​​ 将输出一个节点列表,其中包含 ​​CPU​​​ 和内存资源请求的总数以及在它们上运行的所有 ​​pod​​ 的限制。对于具有多个节点的集群,第一行还将包括集群范围的总数。该输出将如下所示:

--pods

对于更详细的输出,​​kube-capacity​​​ 可以在输出中包含 ​​pod​​​。当​​-p​​​或​​--pods​​​被传递给 ​​kube-capacity​​​ 时,它将包含如下所示的特定于 ​​pod ​​的输出

显示 Pod 计数

要显示每个节点和整个集群的 ​​pod ​​​数量,可以通过​​--pod-count​​参数:

按标签过滤
kube-capacity --pod-labels app=nginx
//这个命令将显示具有标签 app=nginx 的所有 Pod 的资源容量信息。
kube-capacity --namespace kube-system
//这个命令将显示命名空间为 kube-system 的所有 Pod 的资源容量信息。
kube-capacity --namespace-labels team=api
//这个命令将显示具有命名空间标签 team=api 的所有 Pod 的资源容量信息。
kube-capacity --node-labels kubernetes.io/role=node
//这个命令将显示具有节点标签 kubernetes.io/role=node 的所有节点的资源容量信息。

JSON和YAML输出

默认情况下,​​kube-capacity​​​ 将以表格格式提供输出。要以 ​​JSON ​​​或 ​​YAML​​ 格式查看此数据,可以使用输出标志。以下是一些示例命令:

kube-capacity --pods --output json
kube-capacity --pods --containers --util --output yaml

结论

  1. 使用K9S、Kube-Capacity、Kubectx-Kubens、kubetail命令行来提高运维能力,部署入版本
  2. k8s命令行可视化工具可帮助kubernetes管理员、开发人员更好的监控和维护k8s集群

参考资料:

  1. ​​mp.weixin.qq.com​​
  2. ​​https://zhuanlan.zhihu.com/p/335000575(lens的使用参考)​​
  3. ​​https://www.hi-linux.com/posts/43085.html(kubetail的安装)​​
  4. ​​https://zhuanlan.zhihu.com/p/642469576(kubetail的使用)​​
  5. ​​https://www.cnblogs.com/xunweidezui/p/15607080.html(kube-shell的安装使用)​​
  6. ​​https://blog.csdn.net/engchina/article/details/122664763(正常k9s的安装)​​
  7. ​​https://www.jianshu.com/p/42f7e1e53410(k9s的使用)​​
  8. ​​https://juejin.cn/post/6847902224983539720(k9s的配置文件参考、自定义别名、自定义快捷键)​​
  9. ​​https://blog.csdn.net/weixin_40449300/article/details/117093982(kubetree的安装)​​
  10. ​​https://blog.csdn.net/qq_41337034/article/details/108576266(kubens的安装)​​
  11. ​​https://zhuanlan.zhihu.com/p/539180125(kube-capacity使用参考)​​

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

物联网学习1、什么是 MQTT?

MQTT&#xff08;Message Queuing Telemetry Transport&#xff09;是一种轻量级、基于发布-订阅模式的消息传输协议&#xff0c;适用于资源受限的设备和低带宽、高延迟或不稳定的网络环境。它在物联网应用中广受欢迎&#xff0c;能够实现传感器、执行器和其它设备之间的高效通…

3D数据格式导出工具HOOPS Publish如何生成高质量3D PDF?

在当今数字化时代&#xff0c;从建筑设计到制造业&#xff0c;从医学领域到电子游戏开发&#xff0c;3D技术已经成为了不可或缺的一部分。在这个进程中&#xff0c;将3D模型导出为3D PDF格式具有重要的意义。同时&#xff0c;HOOPS Publish作为一个领先的解决方案&#xff0c;为…

【搜索引擎2】实现API方式调用ElasticSearch8接口

1、理解ElasticSearch各名词含义 ElasticSearch对比Mysql Mysql数据库Elastic SearchDatabase7.X版本前有Type&#xff0c;对比数据库中的表&#xff0c;新版取消了TableIndexRowDocumentColumnmapping Elasticsearch是使用Java开发的&#xff0c;8.1版本的ES需要JDK17及以上…

从0开始搭建基于VUE的前端项目(一) 项目创建和配置

准备与版本 安装nodejs(v20.11.1)安装vue脚手架(@vue/cli 5.0.8) ,参考(https://cli.vuejs.org/zh/)vue版本(2.7.16),vue2的最后一个版本vue.config.js的配置详解(https://cli.vuejs.org/zh/config/)element-ui(2.15.14)(https://element.eleme.io/)vuex(3.6.2) (https://…

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之八 简单水彩画效果

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之八 简单水彩画效果 目录 Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之八 简单水彩画效果 一、简单介绍 二、简单图像浮雕效果实现原理 三、简单水彩画效果案例实现简单步骤 四、注意事项…

Spring IoCDI(3)

DI详解 接下来学习一下依赖注入DI的细节. 依赖注入是一个过程, 是指IoC容器在创建Bean时, 去提供运行时所依赖的资源, 而资源指的就是对象. 在之前的案例中, 使用了Autowired这个注解, 完成了依赖注入这个操作. 简单来说, 就是把对象取出来放到某个类的属性中. 在一些文章中…

Matlab将日尺度数据转化为月尺度数据

日尺度转化为月尺度 clcclear all% load datadata xlread(data.xlsx) % 例如该数据为1961-01-01至2022-12-31&#xff0c;共计22645天data data(:,1:3) % 该数据有22645行&#xff0c;数据分别为降水&#xff0c;气温&#xff0c;湿度等三列dt datetime(1961-01-01):datatim…

从MVC 到DDD 架构

目录 一、前言 二、MVC架构 三、DDD架构 四、我为什么会使用DDD&#xff1f; 五、DDD架构分层 一、前言 最近在做一个项目&#xff0c;使用的是DDD架构思&#xff0c;觉得很不错&#xff0c;在此记录下。 二、MVC架构 MVC是一种经典的软件架构模式&#xff0c;主要用于…

关于未来自我的发展和一些学习方法(嵌入式方向)

我是一名大二的学生&#xff0c;考研还是就业&#xff0c;到底是重视专业课还是重视数学英语&#xff0c;这些问题一直困扰了我很久&#xff0c;但如今已经有了一些浅显的认识&#xff0c;所以才会想写这样一篇文章来记录一下自己的状态和未来的规划 下面的看法都是个人的看法&…

开源一款剪贴板跨设备共享工具

shigen坚持更新文章的博客写手&#xff0c;擅长Java、python、vue、shell等编程语言和各种应用程序、脚本的开发。记录成长&#xff0c;分享认知&#xff0c;留住感动。 个人IP&#xff1a;shigen 昨天遇到了一个很棘手的问题&#xff1a;我的手机剪贴板需要同步到另外的两台设…

基于Arduino IDE 野火ESP8266模块 一键配网 的开发

一、配网介绍 ESP8266 一键配网&#xff08;也称为 SmartConfig 或 FastConfig&#xff09;是一种允许用户通过智能手机上的应用程序快速配置 ESP8266 Wi-Fi 模块的方法&#xff0c;而无需手动输入 SSID 和密码。为了实现这一功能&#xff0c;则需要一个支持 SmartConfig 的智能…

基于java实现学科竞赛管理系统【Springboot+mybatis+layui】

基于java实现学科竞赛管理系统【Springbootmybatislayui】 博主介绍&#xff1a;多年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 央顺技术团队 Java毕设项目精品实战案例《1000套》 欢迎点赞 收藏 ⭐留言 文…

Ribbon简介

目录 一 、概念介绍 1、Ribbon是什么 2、认识负载均衡 2.1 服务器端的负载均衡 2.2 客户端的负载均衡 3、Ribbon工作原理 4、Ribbon的主要组件 IClientConfig ServerList ServerListFilter IRule Iping ILoadBalancer ServerListUpdater 5、Ribbon支持…

AndroidStudio出现类似 Could not create task ‘:app:ToolOperatorDemo.main()‘. 错误

先看我们的报错 翻译过来大概意思是:无法创建任务:app:ToolOperatorDemo.main()。 没有找到名称为“main”的源集。 解决方法&#xff1a; 在.idea文件夹下的gradle.xml文件中 <GradleProjectSettings>标签下添加<option name"delegatedBuild" value"f…

华为OD机试 - 芯片资源限制(Java 2024 C卷 100分)

华为OD机试 2024C卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;A卷B卷C卷&#xff09;》。 刷的越多&#xff0c;抽中的概率越大&#xff0c;每一题都有详细的答题思路、详细的代码注释、样例测试…

车载以太网AVB交换机 gptp透明时钟 5口 全千兆 SW1500

全千兆车载以太网交换机 一、产品简要分析 5端口千兆车载以太网交换机&#xff0c;包含4个通道的1000BASE-T1接口使用罗森博格H-MTD和泰科MATEnet双接口&#xff0c;1个通道1000BASE-T标准以太网(RJ45接口)&#xff0c;可以实现车载以太网多通道交换&#xff0c;千兆和百兆车载…

XR虚拟直播间,引领创新风潮,打破直播局限!

随着互联网技术日新月异的发展&#xff0c;直播行业也迎来了蓬勃发展的春天。然而&#xff0c;大多数直播间在吸引观众眼球和延长用户观看时长方面&#xff0c;仍然面临着巨大的挑战。正是在这样的背景下&#xff0c;XR虚拟直播系统应运而生&#xff0c;以其多维度的直播场景、…

ComfyUI SDWebUI升级pytorch随记

目前使用的版本是去年10月的1.6版本&#xff0c;有点老。希望支持新的特性&#xff0c;于是乎开始作死。从升级torch开始。先看看已有的版本&#xff1a; (venv) rootubuntu-sd-server:~# pip show torch Name: torch Version: 2.0.1 Summary: Tensors and Dynamic neural net…

矩阵置零 - LeetCode 热题 18

大家好&#xff01;我是曾续缘&#x1f929; 今天是《LeetCode 热题 100》系列 发车第 18 天 矩阵第 1 题 ❤️点赞 &#x1f44d; 收藏 ⭐再看&#xff0c;养成习惯 矩阵置零 给定一个 m x n 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为…

动态规划——回文串问题

目录 练习1&#xff1a;回文子串 练习2&#xff1a;最长回文子串 练习3&#xff1a;回文串分割IV 练习4&#xff1a;分割回文串 练习5&#xff1a;最长回文子序列 练习6&#xff1a;让字符串成为回文串的最小插入次数 本篇文章主要学习使用动态规划来解决回文串相关问题&…