kubectl源码分析之rollout restart

迈不过友情╰ 2023-02-15 12:39 35阅读 0赞

欢迎关注我的公众号:

watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAaHhwamF2YTE_size_8_color_FFFFFF_t_70_g_se_x_16

目前刚开始写一个月,一共写了18篇原创文章,文章目录如下:

istio多集群探秘,部署了50次多集群后我得出的结论

istio多集群链路追踪,附实操视频

istio防故障利器,你知道几个,istio新手不要读,太难!

istio业务权限控制,原来可以这么玩

istio实现非侵入压缩,微服务之间如何实现压缩

不懂envoyfilter也敢说精通istio系列-http-rbac-不要只会用AuthorizationPolicy配置权限

不懂envoyfilter也敢说精通istio系列-02-http-corsFilter-不要只会vs

不懂envoyfilter也敢说精通istio系列-03-http-csrf filter-再也不用再代码里写csrf逻辑了

不懂envoyfilter也敢说精通istio系列http-jwt_authn-不要只会RequestAuthorization

不懂envoyfilter也敢说精通istio系列-05-fault-filter-故障注入不止是vs

不懂envoyfilter也敢说精通istio系列-06-http-match-配置路由不只是vs

不懂envoyfilter也敢说精通istio系列-07-负载均衡配置不止是dr

不懂envoyfilter也敢说精通istio系列-08-连接池和断路器

不懂envoyfilter也敢说精通istio系列-09-http-route filter

不懂envoyfilter也敢说精通istio系列-network filter-redis proxy

不懂envoyfilter也敢说精通istio系列-network filter-HttpConnectionManager

不懂envoyfilter也敢说精通istio系列-ratelimit-istio ratelimit完全手册

加qq群,请联系:

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2h4cGphdmEx_size_16_color_FFFFFF_t_70
————————————————

  1. type RestartOptions struct {//restart结构体
  2. PrintFlags *genericclioptions.PrintFlags
  3. ToPrinter func(string) (printers.ResourcePrinter, error)
  4. Resources []string
  5. Builder func() *resource.Builder
  6. Restarter polymorphichelpers.ObjectRestarterFunc
  7. Namespace string
  8. EnforceNamespace bool
  9. resource.FilenameOptions
  10. genericclioptions.IOStreams
  11. }
  12. func NewRolloutRestartOptions(streams genericclioptions.IOStreams) *RestartOptions {
  13. return &RestartOptions{//初始化结构体
  14. PrintFlags: genericclioptions.NewPrintFlags("restarted").WithTypeSetter(scheme.Scheme),
  15. IOStreams: streams,
  16. }
  17. }
  18. //创建restart命令
  19. func NewCmdRolloutRestart(f cmdutil.Factory, streams genericclioptions.IOStreams) *cobra.Command {
  20. o := NewRolloutRestartOptions(streams)//初始化结构体
  21. validArgs := []string{"deployment", "daemonset", "statefulset"}
  22. cmd := &cobra.Command{//创建cobra命令
  23. Use: "restart RESOURCE",
  24. DisableFlagsInUseLine: true,
  25. Short: i18n.T("Restart a resource"),
  26. Long: restartLong,
  27. Example: restartExample,
  28. Run: func(cmd *cobra.Command, args []string) {
  29. cmdutil.CheckErr(o.Complete(f, cmd, args))//准备
  30. cmdutil.CheckErr(o.Validate())//校验
  31. cmdutil.CheckErr(o.RunRestart())//运行
  32. },
  33. ValidArgs: validArgs,//有效参数
  34. }
  35. usage := "identifying the resource to get from a server."
  36. cmdutil.AddFilenameOptionFlags(cmd, &o.FilenameOptions, usage)//文件选项
  37. o.PrintFlags.AddFlags(cmd)//打印选项
  38. return cmd
  39. }
  40. //准备函数
  41. func (o *RestartOptions) Complete(f cmdutil.Factory, cmd *cobra.Command, args []string) error {
  42. o.Resources = args//设置资源
  43. o.Restarter = polymorphichelpers.ObjectRestarterFn//设置Restarter函数
  44. var err error
  45. o.Namespace, o.EnforceNamespace, err = f.ToRawKubeConfigLoader().Namespace()//设置namespace和enforceNamespace
  46. if err != nil {
  47. return err
  48. }
  49. o.ToPrinter = func(operation string) (printers.ResourcePrinter, error) {//print flag 转printer函数
  50. o.PrintFlags.NamePrintFlags.Operation = operation
  51. return o.PrintFlags.ToPrinter()
  52. }
  53. o.Builder = f.NewBuilder//设置builder
  54. return nil
  55. }
  56. //校验
  57. func (o *RestartOptions) Validate() error {
  58. if len(o.Resources) == 0 && cmdutil.IsFilenameSliceEmpty(o.Filenames, o.Kustomize) {//资源和文件至少有一个
  59. return fmt.Errorf("required resource not specified")
  60. }
  61. return nil
  62. }
  63. //运行
  64. func (o RestartOptions) RunRestart() error {
  65. r := o.Builder().
  66. WithScheme(scheme.Scheme, scheme.Scheme.PrioritizedVersionsAllGroups()...).
  67. NamespaceParam(o.Namespace).DefaultNamespace().
  68. FilenameParam(o.EnforceNamespace, &o.FilenameOptions).
  69. ResourceTypeOrNameArgs(true, o.Resources...).
  70. ContinueOnError().
  71. Latest().
  72. Flatten().
  73. Do()//构造result对象
  74. if err := r.Err(); err != nil {
  75. return err
  76. }
  77. allErrs := []error{}
  78. infos, err := r.Infos()//获取info对象
  79. if err != nil {
  80. // restore previous command behavior where
  81. // an error caused by retrieving infos due to
  82. // at least a single broken object did not result
  83. // in an immediate return, but rather an overall
  84. // aggregation of errors.
  85. allErrs = append(allErrs, err)
  86. }
  87. for _, patch := range set.CalculatePatches(infos, scheme.DefaultJSONEncoder(), set.PatchFn(o.Restarter)) {//计算info补丁,并遍历
  88. info := patch.Info
  89. if patch.Err != nil {//补丁有错误,append错误继续
  90. resourceString := info.Mapping.Resource.Resource
  91. if len(info.Mapping.Resource.Group) > 0 {
  92. resourceString = resourceString + "." + info.Mapping.Resource.Group
  93. }
  94. allErrs = append(allErrs, fmt.Errorf("error: %s %q %v", resourceString, info.Name, patch.Err))
  95. continue
  96. }
  97. if string(patch.Patch) == "{}" || len(patch.Patch) == 0 {//如果补丁为空,则append错误
  98. allErrs = append(allErrs, fmt.Errorf("failed to create patch for %v: empty patch", info.Name))
  99. }
  100. obj, err := resource.NewHelper(info.Client, info.Mapping).Patch(info.Namespace, info.Name, types.StrategicMergePatchType, patch.Patch, nil)//用helper应用补丁到服务端
  101. if err != nil {
  102. allErrs = append(allErrs, fmt.Errorf("failed to patch: %v", err))
  103. continue
  104. }
  105. info.Refresh(obj, true)//刷新obj对象
  106. printer, err := o.ToPrinter("restarted")//printflag转printer
  107. if err != nil {
  108. allErrs = append(allErrs, err)
  109. continue
  110. }
  111. if err = printer.PrintObj(info.Object, o.Out); err != nil {//打印结果
  112. allErrs = append(allErrs, err)
  113. }
  114. }
  115. return utilerrors.NewAggregate(allErrs)
  116. }

发表评论

表情:
评论列表 (有 0 条评论,35人围观)

还没有评论,来说两句吧...

相关阅读