helm源码分析之create命令

 欢迎关注我的公众号:

 目前刚开始写一个月,一共写了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完全手册

 

-------------------------------------------------------------------------------------------------------------

type createOptions struct {//create结构体
	starter    string // --starter
	name       string
	starterDir string
}
func newCreateCmd(out io.Writer) *cobra.Command {//创建create命令
	o := &createOptions{}//初始化结构体

	cmd := &cobra.Command{//创建cobra命令
		Use:   "create NAME",
		Short: "create a new chart with the given name",
		Long:  createDesc,
		Args:  require.ExactArgs(1),
		RunE: func(cmd *cobra.Command, args []string) error {
			o.name = args[0]//设置name
			o.starterDir = helmpath.DataPath("starters")//设置starter目录
			return o.run(out)//运行
		},
	}

	cmd.Flags().StringVarP(&o.starter, "starter", "p", "", "The name or absolute path to Helm starter scaffold")//starter选项
	return cmd
}
func (o *createOptions) run(out io.Writer) error {//运行
	fmt.Fprintf(out, "Creating %s\n", o.name)//打印

	chartname := filepath.Base(o.name)//获取chart名称
	cfile := &chart.Metadata{//构造chart元数据
		Name:        chartname,
		Description: "A Helm chart for Kubernetes",
		Type:        "application",
		Version:     "0.1.0",
		AppVersion:  "0.1.0",
		APIVersion:  chart.APIVersionV2,
	}

	if o.starter != "" {//如果starter不为空
		// Create from the starter
		lstarter := filepath.Join(o.starterDir, o.starter)//获取starter路径
		// If path is absolute, we don't want to prefix it with helm starters folder
		if filepath.IsAbs(o.starter) {//如果是绝对路径,设置lstarter
			lstarter = o.starter
		}
		return chartutil.CreateFrom(cfile, filepath.Dir(o.name), lstarter)//从starter创建chart
	}

	_, err := chartutil.Create(chartname, filepath.Dir(o.name))//创建chart
	return err
}
//从starter创建chart
func CreateFrom(chartfile *chart.Metadata, dest, src string) error {
	schart, err := loader.Load(src)//加载starter chart
	if err != nil {
		return errors.Wrapf(err, "could not load %s", src)
	}

	schart.Metadata = chartfile//设置chart元数据

	var updatedTemplates []*chart.File

	for _, template := range schart.Templates {//遍历templates
		newData := transform(string(template.Data), schart.Name())//转换template chart名称
		updatedTemplates = append(updatedTemplates, &chart.File{Name: template.Name, Data: newData})
	}

	schart.Templates = updatedTemplates//设置templates
	b, err := yaml.Marshal(schart.Values)//把values转换成yaml
	if err != nil {
		return errors.Wrap(err, "reading values file")
	}

	var m map[string]interface{}
	if err := yaml.Unmarshal(transform(string(b), schart.Name()), &m); err != nil {//转换values里的chart名称,然后转成map
		return errors.Wrap(err, "transforming values file")
	}
	schart.Values = m//设置values

	// SaveDir looks for the file values.yaml when saving rather than the values
	// key in order to preserve the comments in the YAML. The name placeholder
	// needs to be replaced on that file.
	for _, f := range schart.Raw {//遍历chart文件
		if f.Name == ValuesfileName {
			f.Data = transform(string(f.Data), schart.Name())//转换文件中chart的名称
		}
	}

	return SaveDir(schart, dest)//保存chart
}
func Create(name, dir string) (string, error) {//创建chart
	path, err := filepath.Abs(dir)//获取chart绝对路径
	if err != nil {
		return path, err
	}

	if fi, err := os.Stat(path); err != nil {//判断路径是否存在
		return path, err
	} else if !fi.IsDir() {//判断路径是否是目录
		return path, errors.Errorf("no such directory %s", path)
	}

	cdir := filepath.Join(path, name)//获取chart目录
	if fi, err := os.Stat(cdir); err == nil && !fi.IsDir() {//判断chart目录是否存在并且是目录
		return cdir, errors.Errorf("file %s already exists and is not a directory", cdir)
	}

	files := []struct {//设置要生成的chart文件
		path    string
		content []byte
	}{
		{
			// Chart.yaml
			path:    filepath.Join(cdir, ChartfileName),
			content: []byte(fmt.Sprintf(defaultChartfile, name)),
		},
		{
			// values.yaml
			path:    filepath.Join(cdir, ValuesfileName),
			content: []byte(fmt.Sprintf(defaultValues, name)),
		},
		{
			// .helmignore
			path:    filepath.Join(cdir, IgnorefileName),
			content: []byte(defaultIgnore),
		},
		{
			// ingress.yaml
			path:    filepath.Join(cdir, IngressFileName),
			content: transform(defaultIngress, name),
		},
		{
			// deployment.yaml
			path:    filepath.Join(cdir, DeploymentName),
			content: transform(defaultDeployment, name),
		},
		{
			// service.yaml
			path:    filepath.Join(cdir, ServiceName),
			content: transform(defaultService, name),
		},
		{
			// serviceaccount.yaml
			path:    filepath.Join(cdir, ServiceAccountName),
			content: transform(defaultServiceAccount, name),
		},
		{
			// NOTES.txt
			path:    filepath.Join(cdir, NotesName),
			content: transform(defaultNotes, name),
		},
		{
			// _helpers.tpl
			path:    filepath.Join(cdir, HelpersName),
			content: transform(defaultHelpers, name),
		},
		{
			// test-connection.yaml
			path:    filepath.Join(cdir, TestConnectionName),
			content: transform(defaultTestConnection, name),
		},
	}

	for _, file := range files {//遍历文件
		if _, err := os.Stat(file.path); err == nil {//如果文件存在则跳过
			// File exists and is okay. Skip it.
			continue
		}
		if err := writeFile(file.path, file.content); err != nil {//写入文件到磁盘
			return cdir, err
		}
	}
	// Need to add the ChartsDir explicitly as it does not contain any file OOTB
	if err := os.MkdirAll(filepath.Join(cdir, ChartsDir), 0755); err != nil {//添加charts目录
		return cdir, err
	}
	return cdir, nil
}

### Headlamp 工具简介 Headlamp 是一种用于 Kubernetes 集群管理的开源工具,旨在提供更友好的图形化界面来管理和监控集群资源。它支持多种功能,包括 Pod 查看、日志分析以及资源配置等功能。 --- ### 下载 Headlamp 的方法 可以通过官方 GitHub 仓库获取 Headlamp 的最新版本和安装包。以下是具体的下载方式: #### 方法一:通过 GitHub 获取二进制文件 访问 Headlamp 的官方 GitHub 发布页面,可以找到预编译的二进制文件供不同操作系统使用[^5]。 ```bash https://github.com/kubermatic/headlamp/releases/latest ``` 在该页面中,选择适合目标操作系统的压缩包(如 Linux 或 macOS),并将其解压至指定路径。 #### 方法二:通过 Helm Chart 安装 如果环境中已配置好 Helm 和 Kubernetes,则可以直接通过 Helm Chart 方式部署 Headlamp[^6]。 ```bash helm repo add headlamp https://charts.kubermatic.io/ helm install headlamp headlamp/headlamp --namespace=headlamp-system --create-namespace ``` 上述命令会在 `headlamp-system` 命名空间下完成 Headlamp 的安装过程。 #### 方法三:手动构建源码 对于需要自定义修改或测试开发版的情况,可以从源码自行构建 Headlamp 应用程序[^7]。 ```bash git clone https://github.com/kubermatic/headlamp.git cd headlamp make build ``` 完成后,在当前目录会生成可执行文件,适用于特定环境运行需求。 --- ### JDK 环境准备注意事项 由于部分用户可能还需要额外设置 Java 开发环境以便于某些插件或者扩展组件正常工作,请参照之前提到的相关说明进行 JDK 路径变量调整[^2][^4]。 例如: ```bash export JAVA_HOME=/usr/java/default export PATH=$PATH:$JAVA_HOME/bin ``` 以上步骤有助于确保即使是在复杂的企业级场景里也能顺利集成各类依赖库和服务端口映射关系等高级特性。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hxpjava1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值