返回顶部
首页 > 资讯 > 后端开发 > GO >Golang合并yaml文件过程逐步讲解
  • 398
分享到

Golang合并yaml文件过程逐步讲解

Golang合并yamlGolang合并yaml文件Golangyaml 2023-01-10 12:01:24 398人浏览 安东尼
摘要

目录读配置写配置合并配置当前有趋势使用环境变量代替配置文件,主要是为了方便容器部署,因为文件需要额外文件权限。但环境变量也有缺点,如长度和因数量太多造成的复杂性,另外嵌套也很难实现,

当前有趋势使用环境变量代替配置文件,主要是为了方便容器部署,因为文件需要额外文件权限。但环境变量也有缺点,如长度和因数量太多造成的复杂性,另外嵌套也很难实现,此时配置文件则更合适。

本文就介绍golang读写配置文件,以及合并配置获得最终配置信息。

读配置

首先准备配置文件config.yaml:

name: test
image: tom.png
environment:
  os: linux
  group: admin
  user: testAdmin
limits:
  cpu: 4
  memory: 512M

为了加载配置,需要定义结构体及标签,和JSON标记类似:

type Spec struct {
	// Name: name of the function
	Name string `yaml:"name"`
	// Image: Docker image name of the function
	Image       string            `yaml:"image"`
	Environment map[string]string `yaml:"environment,omitempty"`
	// Limits for the function
	Limits *FunctionResources `yaml:"limits,omitempty"`
}
// FunctionResources Memory and CPU
type FunctionResources struct {
	Memory string ` yaml:"memory"`
	CPU    string ` yaml:"cpu"`
}

这里仅用yaml代替json,下面解析也同样使用Unmarshal接口生成对象:

import (
    "fmt"
    "os"
	"Gopkg.in/yaml.v2"
)
func ReadYaml() {
	bytesOut, err := os.ReadFile("config.yaml")
	if err != nil {
		panic(err)
	}
	spec := Spec{}
	if err := yaml.Unmarshal(bytesOut, &spec); err != nil {
		panic(err)
	}
	fmt.Printf("Function name: %s\tImage: %s\tEnvs: %d\n", spec.Name, spec.Image,
		len(spec.Environment))
	fmt.Printf("Limists: %s, %s\n", spec.Limits.CPU, spec.Limits.Memory)
}

输出结果:

Function name: test    Image: tom.png    Envs: 3
Limists: 4, 512M

写配置

写文件首先使用接口Marshal把对象序列化为字节数组,然后调用os方法写yaml文件:

func WriteYaml() {
	spec := Spec{
		Image: "docker.io/functions/figlet:latest",
		Name:  "figlet",
	}
	bytesOut, err := yaml.Marshal(spec)
	if err != nil {
		panic(err)
	}
	err = os.WriteFile("figlet.yaml", bytesOut, os.ModePerm)
	if err != nil {
		panic(err)
	}
	fmt.Printf("Wrote: figlet.yaml. . OK. \n")
}

运行程序成功生成figlet.yaml文件并输出:

Wrote: figlet.yaml. . OK. 

使用yaml.v2库可以快速实现配置文件相关工作,下面介绍如何合并多个配置信息。

合并配置

如果配置信息包括包括很多字段,则可能需要维护一个示例文件,并允许用户提供新的值进行修改。我们可以使用mergo库实现合并功能,当然其他库也可以实现类似功能,该方法支持内存中任何结构体,不一定为YAML:

import "GitHub.com/imdario/mergo"
func MergeYaml() {
	base := Spec{
		Image:       "docker.io/functions/figlet:latest",
		Name:        "figlet",
		Environment: map[string]string{"stage": "develop"},
		Limits:      &FunctionResources{Memory: "512Mi", CPU: "60Mi"},
	}
	production := Spec{
		Environment: map[string]string{"stage": "production"},
		Limits:      &FunctionResources{Memory: "1Gi", CPU: "100Mi"},
	}
	overrides := []Spec{
		base,
		production,
	}
	merged := Spec{}
	for _, override := range overrides {
		err := mergo.Merge(&merged, override, mergo.WithOverride)
		if err != nil {
			panic(err)
		}
	}
	bytesOut, err := yaml.Marshal(merged)
	if err != nil {
		panic(err)
	}
	fmt.Printf("Merged content: \n\n%s\n", string(bytesOut))
}

运行测试输出结果:

Merged content: 

name: figlet
image: docker.io/functions/figlet:latest
environment:
  stage: production
limits:
  memory: 1Gi
  cpu: 100Mi

我们在Merge方法指定后面覆盖前置配置,读者还可以通过源码查看其他的合并方法。

到此这篇关于Golang合并yaml文件过程逐步讲解的文章就介绍到这了,更多相关Golang合并yaml内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: Golang合并yaml文件过程逐步讲解

本文链接: https://lsjlt.com/news/177273.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作