k8s 开源_jdk源码剖析手册

k8s 开源_jdk源码剖析手册createfunc main() { #随机数 rand.Seed(time.Now().UnixNano()) #创建一个新的命令行对象 command := cmd.NewDefaultKubectlCommand() #日志 logs.InitLogs() defer logs.FlushLogs() #真正执行的命令行 if err := command.Execute(); err != nil { os.Exit(1) }}# NewDefaultKubectl

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

create

func main() { 
   
	#随机数
	rand.Seed(time.Now().UnixNano())
	#创建一个新的命令行对象
	command := cmd.NewDefaultKubectlCommand()
	#日志
	logs.InitLogs()
	defer logs.FlushLogs()
	#真正执行的命令行
	if err := command.Execute(); err != nil { 
   
		os.Exit(1)
	}
}
# NewDefaultKubectlCommand函数
# in io.Reader, out, errout io.Writer 标准输入 标准输出 标准错误输出
func NewDefaultKubectlCommandWithArgs(pluginHandler PluginHandler, args []string, in io.Reader, out, errout io.Writer) *cobra.Command { 
   
	#创建一个新的命令行
	cmd := NewKubectlCommand(in, out, errout)
	if len(args) > 1 { 
   
	
	#第一个参数 即create -f nginx_pod.yml部分
		cmdPathPieces := args[1:]
		#调用cmd的find函数去匹配参数
		if _, _, err := cmd.Find(cmdPathPieces); err != nil { 
   
			if err := HandlePluginCommand(pluginHandler, cmdPathPieces); err != nil { 
   
				fmt.Fprintf(errout, "Error: %v\n", err)
				os.Exit(1)
			}
		}
	}

	return cmd
}
func NewKubectlCommand(in io.Reader, out, err io.Writer) *cobra.Command { 
   
	#打印help出现的信息
	cmds := &cobra.Command{ 
   
		Use:   "kubectl",
		Short: i18n.T("kubectl controls the Kubernetes cluster manager"),
		Long: templates.LongDesc(` kubectl controls the Kubernetes cluster manager. Find more information at: https://kubernetes.io/docs/reference/kubectl/overview/`),
		Run: runHelp,

		#运行函数之前的钩子
		PersistentPreRunE: func(*cobra.Command, []string) error { 
   
			rest.SetDefaultWarningHandler(warningHandler)
			#运行前初始化性能评估的工作
			return initProfiling()
		},
		#运行函数之后的钩子
		PersistentPostRunE: func(*cobra.Command, []string) error { 
   
			#运行后的保存性能检测的工作
			if err := flushProfiling(); err != nil { 
   
				return err
			}
			#打印警报
			if warningsAsErrors { 
   
				,,,
			}
			return nil
		},
	}
	groups := templates.CommandGroups{ 
   
		{ 
   
			#命令的信息 初级命令
			Message: "Basic Commands (Beginner):",
			#里面有create expose run set 命令
			Commands: []*cobra.Command{ 
   
				create.NewCmdCreate(f, ioStreams),
				expose.NewCmdExposeService(f, ioStreams),
				run.NewCmdRun(f, ioStreams),
				set.NewCmdSet(f, ioStreams),
			},
		},
		{ 
   
			#中级命令
			Message: "Basic Commands (Intermediate):",
			#包含explain get edit 等
			Commands: []*cobra.Command{ 
   
				explain.NewCmdExplain("kubectl", f, ioStreams),
				get.NewCmdGet("kubectl", f, ioStreams),
				edit.NewCmdEdit(f, ioStreams),
				delete.NewCmdDelete(f, ioStreams),
			},
		},
		{ 
   	#部署相关的内容
			Message: "Deploy Commands:",
			Commands: []*cobra.Command{ 
   
				rollout.NewCmdRollout(f, ioStreams),
				scale.NewCmdScale(f, ioStreams),
				autoscale.NewCmdAutoscale(f, ioStreams),
			},
		},
		...
		# kubectl下面添加的其他的一些子命令
		cmds.AddCommand(alpha)
	cmds.AddCommand(cmdconfig.NewCmdConfig(clientcmd.NewDefaultPathOptions(), ioStreams))
	cmds.AddCommand(plugin.NewCmdPlugin(ioStreams))
#create.NewCmdCreate(f, ioStreams),
func NewCmdCreate(f cmdutil.Factory, ioStreams genericclioptions.IOStreams) *cobra.Command { 
   
	o := NewCreateOptions(ioStreams)
	
	cmd := &cobra.Command{ 
   
		Use:                   "create -f FILENAME",#范例和我们的命令很相似
		DisableFlagsInUseLine: true,
		Short:                 i18n.T("Create a resource from a file or from stdin"),
		Long:                  createLong,
		Example:               createExample,	#提供的其他一些创建的实例
		
		Run: func(cmd *cobra.Command, args []string) { 
   
			#文件名是否为空
			if cmdutil.IsFilenameSliceEmpty(o.FilenameOptions.Filenames, o.FilenameOptions.Kustomize) { 
   
			...
			}
			#验证参数
			cmdutil.CheckErr(o.ValidateArgs(cmd, args))
			#真正的运行create函数
			cmdutil.CheckErr(o.RunCreate(f, cmd))
		},
	}
	...
	#创建create 下面的子命令
	// create subcommands
	cmd.AddCommand(NewCmdCreateNamespace(f, ioStreams))
	...
}
#RunCreate
#f为传入的Factory 主要是封装了与kube-apiserver交互的客户端
func (o *CreateOptions) RunCreate(f cmdutil.Factory, cmd *cobra.Command) error { 
   	
	...
	#验证命令是否合法
	schema, err := f.Validator(cmdutil.GetFlagBool(cmd, "validate"))
	if err != nil { 
   
		return err
	}
	...
	#builder
	r := f.NewBuilder().
		...
		NamespaceParam(cmdNamespace).DefaultNamespace().
		#支持那种类型的filename  支持 管道的 也支持http 和 https的
		FilenameParam(enforceNamespace, &o.FilenameOptions).
		...
		#真正执行代码
		Do()
	err = r.Err()
	if err != nil { 
   
		return err
	}
		...
		count++
		#最后在命令行打印create XXX成功创建
		return o.PrintObj(info.Object)
	})
	...
}

Create->CreateWithOptions->createResource

# createResource
#客户端采用RESTFUL风格的 runtime,object是对资源的抽象
func (m *Helper) createResource(c RESTClient, resource, namespace string, obj runtime.Object, options *metav1.CreateOptions) (runtime.Object, error) { 
   
	#Post对应RestFul里面 post方法
	return c.Post().
		NamespaceIfScoped(namespace, m.NamespaceScoped).
		Resource(resource).
		VersionedParams(options, metav1.ParameterCodec).
		Body(obj).
		#将request转换成result
		Do(context.TODO()).
		#将result转换成为资源对象
		Get()
}
#Do函数
func (r *Request) Do(ctx context.Context) Result { 
   
	var result Result
	#发送请求到server创建资源
	err := r.request(ctx, func(req *http.Request, resp *http.Response) { 
   
		根据返回的resp和req转换对象
		result = r.transformResponse(resp, req)
	})
	return result
}

Do –> r.request->resp, err := client.Do(req) –> resp, err := client.Do(req) –> esp, didTimeout, err = c.send(req, deadline) –> resp, didTimeout, err = send(req, c.transport(), deadline) –> RoundTrip(*Request) (*Response, error) 轮询算法 –> 发送请求给server 获得response

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169046.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mybatis插件安装提示证书问题_maven 插件

    mybatis插件安装提示证书问题_maven 插件先占位,在myeclipse下安装mybatis generator

    2022年10月7日
    2
  • file指定路径_目标实现的策略与路径

    file指定路径_目标实现的策略与路径FileProvider路径配置策略的理解★FileProvider的使用在AndroidManifest.xml中<providerandroid:name="android.support.v4.content.FileProvider"android:authorities="set_your……

    2025年7月30日
    4
  • c语言stat函数返回值,stat函数

    c语言stat函数返回值,stat函数一.概述:表头文件:#include#include定义函数:intstat(constchar*file_name,structstat*buf);函数说明:通过文件名filename获取文件信息,并保存在buf所指的结构体stat中返回值:执行成功则返回0,失败返回-1,错误代码存于errno错误代码:ENOENT参数fil…

    2022年8月21日
    13
  • 微信集赞作弊_朋友圈分享集赞是非法行为吗

    微信集赞作弊_朋友圈分享集赞是非法行为吗从古至今,无论是征战沙场的猛将,还是心怀天下的文豪,抑或探索人生真理的大哲学家,都将“独立、自由”等当做人之所以为人的奋斗目标和根本标准。但可惜的是,无论是外来环境、文化的影响,还是内在的个人成长过程,都缺乏对“独立、自由”的尊重和支撑。而在当下的移动互联网时代,以微信为代表的社交应用,更是在某种程度上扼杀着大众的独立和自由。虽然这并不是微信有意去做…

    2025年9月2日
    7
  • golang 大数据平台_golang 如何处理大数据[通俗易懂]

    golang 大数据平台_golang 如何处理大数据[通俗易懂]Golang被证明非常适合并发编程,goroutine比异步编程更易读、优雅、高效。本文提出一个适合由Golang实现的Pipeline执行模型,适合批量处理大量数据(ETL)的情景。想象这样的应用情景:(推荐学习:go)从数据库A(Cassandra)加载用户评论(量巨大,例如10亿条);根据每条评论的用户ID、从数据库B(MySQL)关联用户资料;调用…

    2022年5月23日
    61
  • pdaf的一些计算「建议收藏」

    pdaf的一些计算「建议收藏」 Pdaf数据获取流程根据上层的isCommand命令,在otp中获取到pdinfo。构建flowcontrolpdaf相关信息的结构体pd_profile,通过sendCommand在snesordriver文件中获取信息pdafcapacity、pdafinfo、vcinfo、cropwininfo。将矫正数据送入PDcore中,会将otp中的pdinfo和driver中进行对比,不一致则报错。在convertPDBufFormat中将pd点统一转换成raw16的格式,

    2025年9月24日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号