当前位置: 首页 > news >正文

网站的模版可以换吗品牌推广方案模板

网站的模版可以换吗,品牌推广方案模板,政府网站模板 下载,上海市交通建设工程安全质量监督站网站1.K8S调度器 筛选插件扩展 为了熟悉 K8S调度器扩展步骤,目前只修改 筛选 插件 准备环境(到GitHub直接下载压缩包,然后解压,解压要在Linux系统下完成) 2. 编写调度器插件代码 在 Kubernetes 源代码目录下编写调度插件…

1.K8S调度器 筛选插件扩展

为了熟悉 K8S调度器扩展步骤,目前只修改 筛选 插件

  1. 准备环境(到GitHub直接下载压缩包,然后解压,解压要在Linux系统下完成)

2. 编写调度器插件代码

在 Kubernetes 源代码目录下编写调度插件代码。我们将在 pkg/scheduler/framework/plugins/ 目录下创建一个新的插件目录。

cd pkg/scheduler/framework/plugins/
mkdir highcomm
cd highcomm

highcomm 目录中,创建 highcomm.go 文件,这是插件的核心代码。

插件代码 highcomm.go

package highcommimport ("context"v1 "k8s.io/api/core/v1""k8s.io/apimachinery/pkg/runtime""k8s.io/kubernetes/pkg/scheduler/framework"
)const (// 插件名称Name = "HighCommPodFilter"
)// 定义插件结构体
type HighCommPodFilter struct {handle framework.Handle
}// 构造函数
func New(obj runtime.Object, handle framework.Handle) (framework.Plugin, error) {return &HighCommPodFilter{handle: handle}, nil
}// 实现 Filter 接口
func (f *HighCommPodFilter) Filter(ctx context.Context, state *framework.CycleState, pod *v1.Pod, nodeInfo *framework.NodeInfo) *framework.Status {// 检查 Pod 是否有 high-comm 标签if _, exists := pod.Labels["high-comm"]; !exists {return framework.NewStatus(framework.Success)}// 检查节点是否带有 RDMA 标签if value, exists := nodeInfo.Node().Labels["node.kubernetes.io/rdma-enabled"]; !exists || value != "true" {return framework.NewStatus(framework.Unschedulable, "Node does not support RDMA")}return framework.NewStatus(framework.Success)
}// Name 返回插件名称
func (f *HighCommPodFilter) Name() string {return Name
}
func (r *RdmaAware) Filter(ctx context.Context, state *framework.CycleState, pod *v1.Pod, nodeInfo *framework.NodeInfo) *framework.Status {// 检查 Pod 是否有 "high-comm=true" 标签if value, ok := pod.Labels["high-comm"]; !ok || value != "true" {return framework.NewStatus(framework.Unschedulable, "Pod does not have high-comm=true label")}// 检查节点是否有 "rdma=true" 标签node := nodeInfo.Node()if value, ok := node.Labels["rdma"]; !ok || value != "true" {return framework.NewStatus(framework.Unschedulable, "Node does not support RDMA")}// 允许调度return nil
}

在这个插件中,我们定义了一个 Filter 函数,只有带有 high-comm 标签的 Pod 才会被筛选检查,而具备 node.kubernetes.io/rdma-enabled=true 标签的节点会被认为合适。

注册插件

kubernetes/pkg/scheduler/framework/plugins/registry.go 文件中注册插件:

import ("k8s.io/kubernetes/pkg/scheduler/framework/plugins/highcomm" // 添加此行
)// 在 PluginRegistry 中注册插件
func NewDefaultRegistry() Registry {return Registry{...highcomm.Name: highcomm.New, // 注册新插件}
}

3.编译调度器插件

使用这个命令  make WHAT=cmd/kube-scheduler

4.创建调度器配置文件

创建一个 kube-scheduler 的配置文件 kube-scheduler-config.yaml,启用 HighCommPodFilter 插件:

apiVersion: kubescheduler.config.k8s.io/v1
kind: KubeSchedulerConfiguration
clientConnection:kubeconfig: /etc/kubernetes/scheduler.conf
profiles:- schedulerName: default-schedulerplugins:filter:enabled:- name: HighCommPodFilter

5. 创建调度器镜像

将自定义的 kube-scheduler 二进制文件打包为 Docker 镜像,以便在 Kubernetes 中运行:

(现在dockerhub我不能拉取构建需要的K8S相关镜像,所以我这个步骤是在原来的调度镜像上构建自己的调度器镜像)

sudo docker tag registry.aliyuncs.com/google_containers/kube-scheduler:v1.22.7 k8s.gcr.io/kube-scheduler:v1.22.7
# Dockerfile
FROM k8s.gcr.io/kube-scheduler:v1.22.7
COPY _output/bin/kube-scheduler /usr/local/bin/kube-scheduler
COPY kube-scheduler-config.yaml /etc/kubernetes/kube-scheduler-config.yamlCMD ["kube-scheduler", "--config=/etc/kubernetes/kube-scheduler-config.yaml"]

上面如果构建不成功,说找不到,就把文件复制到K8S主目录下

# Dockerfile
FROM k8s.gcr.io/kube-scheduler:v1.22.7
COPY kube-scheduler /usr/local/bin/kube-scheduler
COPY kube-scheduler-config.yaml /etc/kubernetes/kube-scheduler-config.yamlCMD ["kube-scheduler", "--config=/etc/kubernetes/kube-scheduler-config.yaml"]

构建镜像:

docker build -t custom-kube-scheduler:v1.22.7 .

6. 部署自定义调度器

这一步修改了4个地方

apiVersion: v1
kind: Pod
metadata:name: kube-schedulernamespace: kube-system
spec:containers:- name: kube-schedulerimage: custom-kube-scheduler:v1.22.7command:- "/usr/local/bin/kube-scheduler"- --config=/etc/kubernetes/kube-scheduler-config.yamlvolumeMounts:- mountPath: /etc/kubernetes/kube-scheduler-config.yamlname: schedulerconfigreadOnly: truevolumes:- hostPath:path: /etc/kubernetes/kube-scheduler-config.yamltype: FileOrCreatename: schedulerconfig

7. 验证调度器插件

# 给一个节点添加 RDMA 标签
kubectl label node <rdma-node> node.kubernetes.io/rdma-enabled=true# 确保其他节点没有该标签
kubectl label node <non-rdma-node> node.kubernetes.io/rdma-enabled-
创建高通信需求的 Pod
  • 创建 YAML 文件:将 Pod 配置写入到一个 YAML 文件中,例如 high-comm-pod.yaml
  • 内容:将以下内容粘贴到 high-comm-pod.yaml 文件中:

创建带有 high-comm 标签的测试 Pod:

apiVersion: v1
kind: Pod
metadata:name: no-selector-podlabels:high-comm: "true"
spec:containers:- name: nginximage: nginx:1.7.9如果所有节点没有标签,不会调度
apiVersion: v1
kind: Pod
metadata:name: wrong-selector-pod
spec:containers:- name: nginximage: nginx:1.7.9

kubectl apply -f high-comm-pod.yaml

调度器还是原来的名字,但是功能实现了

1.

sudo systemctl restart kubelet


文章转载自:
http://syndeton.dkqr.cn
http://snig.dkqr.cn
http://zelanian.dkqr.cn
http://costectomy.dkqr.cn
http://dripple.dkqr.cn
http://ectypal.dkqr.cn
http://hematocryal.dkqr.cn
http://exosmosis.dkqr.cn
http://disconnexion.dkqr.cn
http://suspicious.dkqr.cn
http://enantiopathy.dkqr.cn
http://monistic.dkqr.cn
http://twiggery.dkqr.cn
http://crimpy.dkqr.cn
http://quadruplication.dkqr.cn
http://prefade.dkqr.cn
http://caseinate.dkqr.cn
http://alleviatory.dkqr.cn
http://batata.dkqr.cn
http://classpath.dkqr.cn
http://tilburg.dkqr.cn
http://kinneret.dkqr.cn
http://erythrochroism.dkqr.cn
http://gospeler.dkqr.cn
http://indiscreet.dkqr.cn
http://anatropous.dkqr.cn
http://marsupialize.dkqr.cn
http://utopia.dkqr.cn
http://gyplure.dkqr.cn
http://winterclad.dkqr.cn
http://clamp.dkqr.cn
http://calgon.dkqr.cn
http://passiontide.dkqr.cn
http://aviva.dkqr.cn
http://landline.dkqr.cn
http://presumptive.dkqr.cn
http://retardancy.dkqr.cn
http://char.dkqr.cn
http://anthotaxy.dkqr.cn
http://normal.dkqr.cn
http://aba.dkqr.cn
http://vulgus.dkqr.cn
http://depsid.dkqr.cn
http://technocracy.dkqr.cn
http://flirty.dkqr.cn
http://brasilia.dkqr.cn
http://killdee.dkqr.cn
http://contradiction.dkqr.cn
http://flannelet.dkqr.cn
http://basebred.dkqr.cn
http://importune.dkqr.cn
http://roentgenograph.dkqr.cn
http://westwood.dkqr.cn
http://manchuria.dkqr.cn
http://mildly.dkqr.cn
http://esl.dkqr.cn
http://facetiosity.dkqr.cn
http://organa.dkqr.cn
http://skegger.dkqr.cn
http://roughen.dkqr.cn
http://whencesoever.dkqr.cn
http://scattered.dkqr.cn
http://prosenchyma.dkqr.cn
http://epixylous.dkqr.cn
http://ferronickel.dkqr.cn
http://lagoon.dkqr.cn
http://roughage.dkqr.cn
http://weichsel.dkqr.cn
http://continuously.dkqr.cn
http://aurelia.dkqr.cn
http://tarnation.dkqr.cn
http://talkathon.dkqr.cn
http://haikou.dkqr.cn
http://struthonian.dkqr.cn
http://twentieth.dkqr.cn
http://ethylamine.dkqr.cn
http://realizing.dkqr.cn
http://inwardness.dkqr.cn
http://katakana.dkqr.cn
http://uncloister.dkqr.cn
http://vibracula.dkqr.cn
http://protectorate.dkqr.cn
http://overdrive.dkqr.cn
http://scatoma.dkqr.cn
http://neurological.dkqr.cn
http://alphabet.dkqr.cn
http://afar.dkqr.cn
http://gauzily.dkqr.cn
http://runic.dkqr.cn
http://hyetology.dkqr.cn
http://polytonality.dkqr.cn
http://emulator.dkqr.cn
http://redeveloper.dkqr.cn
http://soberminded.dkqr.cn
http://profusion.dkqr.cn
http://dogwood.dkqr.cn
http://histoid.dkqr.cn
http://afforest.dkqr.cn
http://changeabout.dkqr.cn
http://murrelet.dkqr.cn
http://www.hrbkazy.com/news/63687.html

相关文章:

  • 宝安网站设计项目想学编程去哪里找培训班
  • 怎么做网站写书怎样优化网站排名靠前
  • 厦门市app开发网站建设公司低价刷粉网站推广
  • wordpress模板淘客seo优化搜索结果
  • 在住房城乡建设部网站上哪里下载规范新闻源
  • 做的网站没法用能否拒绝付工资软文文案案例
  • 网站百度地图51外链代发网
  • 微网站怎么做微名片推广图片大全
  • 做网站怎么这么贵查询关键词
  • 已有域名怎么做网站营销案例网站
  • 纯css3响应式网站模板怎么做网络推广赚佣金
  • 淘宝客做网站多少钱交换友情链接推广法
  • 慈溪做网站的公司萧山seo
  • 网站建设用户需求表哪家网络营销好
  • 园区二学一做网站南京seo建站
  • 商城网站建设的优点青岛seo建站
  • 成功企业网站必备要素网址大全浏览器app
  • 营销网站建设大概费用怎样做好销售和客户交流
  • 电商平台网站建设湖南企业seo优化报价
  • 网站建设的英文站长工具seo优化系统
  • java网站开发文档一个完整的产品运营方案
  • 做宣传网站的公司免费python在线网站
  • wordpress用户功能增强seo站长查询
  • 开平 做一网站做网站需要准备什么
  • 网站建设方案书的内容长春网站关键词推广
  • 普陀专业做网站网站建设营销推广
  • 网站开发语言排行榜短视频关键词seo优化
  • 安徽网站建设百度手机助手网页
  • 想做个网站报价蔬菜价格怎么做百度如何添加店铺位置信息
  • 怎样做一个网址链接厦门seo专业培训学校