configmap中json或者yaml文件内容格式问题

configmapjson或者yaml文件内容格式问题

一、问题现象说明:

比如我有一个yaml格式的配置文件config.yaml,内容如下:

service:
  port: 8001
  # release
  mode: release
  url: kube-prometheus.monitoring
  port: 9090
common:
  file:
    upload: /opt/data/common/file/

把该配置文件使用configmap方式创建:

kubectl create configmap myconfig --from-file=config.yaml

我们希望在命令行终端查看到的内容如下

[root@node1 ~]# kubectl get configmaps myconfig -o yaml
apiVersion: v1
data:
  config.yaml: |
    service:
      port: 8001
      # release
      mode: release
      url: kube-prometheus.monitoring
      port: 9090
    common:
      file:
        upload: /opt/data/common/file/
kind: ConfigMap
metadata:
  creationTimestamp: 2019-04-24T05:59:52Z
  name: myconfig
  namespace: default
  resourceVersion: "1774515"
  selfLink: /api/v1/namespaces/default/configmaps/myconfig
  uid: 2d066fef-6656-11e9-96e0-005056bf291a
[root@node1 ~]# 

但是有时候我们看到如下格式错乱的configmap内容:

[root@intellif-0 ~]# kubectl get configmaps myconfig -o yaml
apiVersion: v1
data:
  config.yaml: "service:\n  port: 8001\n  # release\n  mode: release\n  url: kube-prometheus.monitoring\n
    \ port: 9090\ncommon:\n  file:\n    upload: /opt/data/common/file/  \n"
kind: ConfigMap
metadata:
  creationTimestamp: 2019-04-24T06:01:42Z
  name: myconfig
  namespace: default
  resourceVersion: "1774818"
  selfLink: /api/v1/namespaces/default/configmaps/myconfig
  uid: 6eac963e-6656-11e9-96e0-005056bf291a
[root@intellif-0 ~]# 

二、分析与解决

问题原因: 文件中某一行结尾有空格,示例中是最后一行(使用vim工具:set invlist
正常的yaml文件

# vim config.yaml
service:$
  port: 8001$
  # release$
  mode: release$
  url: kube-prometheus.monitoring$
  port: 9090$
common:$
  file:$
    upload: /opt/data/common/file/$                                                                                                                                                                                     
~                                                                                                                                                                                          
~                                                                                                                                                                                                                                                                                                                                                                                
~                                                                                                                                                                                          
~                                                                                                                                                                                          
~                                                                                                                                                                                          
~                                                                                                                                                                                          
:set invlist 

异常的yaml文件

# vim config.yaml
service:$
  port: 8001$
  # release$
  mode: release$
  url: kube-prometheus.monitoring$
  port: 9090$
common:$
  file:$
    upload: /opt/data/common/file/  $                                                                                                                                                                                     
~                                                                                                                                                                                          
~                                                                                                                                                                                                                                                                                                                                                                                
~                                                                                                                                                                                          
~                                                                                                                                                                                          
~                                                                                                                                                                                          
~                                                                                                                                                                                          
:set invlist 
  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: JDK可以通过使用yaml库来读取yaml文件并将其转换为Map对象。YAML是一种轻量级的数据序列化语言,它类似于XML和JSON,但更易于阅读和编写。 要读取yaml文件,可以使用Java的yaml库,如SnakeYamlYamlBeans。这些库可以通过在pom.xml添加依赖项来引入。 在使用yaml库时,可以使用以下代码将文件读取为Map对象: ``` Map<String, Object> map = null; Yaml yaml = new Yaml(new Constructor(Map.class)); InputStream input = ClassLoader.getSystemResourceAsStream("config.yml"); map = (Map<String, Object>)yaml.load(input); ``` 此代码首先创建一个Yaml对象,并使用Map.class作为构造函数参数。然后,它打开一个输入流并加载yaml文件。最后,它将文件内容转换为Map对象,并将其存储在一个名为map的变量。 此时,你可以像访问Map对象一样使用map变量的数据。 如此一来就可以使用JDK读取yaml文件并将其转换成Map对象的操作了。 ### 回答2: JDK是Java开发者工具包,它提供了Java语言的开发环境和标准库。在JDK,我们可以使用Java语言提供的类库来读取yaml文件并将其转换成Map对象。 首先,我们需要使用yaml或snakeyaml等库来解析yaml文件,然后将其转换成Java的Map对象。在JDK8版本之前,我们可以使用yamlbeans库来处理yaml文件,但是在JDK8版本及之后,Java已经原生支持了yaml文件的处理,我们可以通过使用java.util.Map、java.util.List和java.util.Properties类来将yaml文件转换成Map对象。 下面是一个使用JDK读取yaml文件并将其转换成Map对象的示例代码: ```java import java.io.*; import java.util.*; import org.yaml.snakeyaml.Yaml; public class YamlToMap { public static void main(String[] args) { File file = new File("data.yaml"); Yaml yaml = new Yaml(); Map<String, Object> map = new HashMap<>(); try { map = (Map<String, Object>)yaml.load(new FileInputStream(file)); } catch (Exception e) { e.printStackTrace(); } System.out.println(map); } } ``` 在代码,我们首先定义了一个File对象,该对象指向我们要处理的yaml文件。然后,我们创建了一个Yaml对象,用于解析yaml文件。接着,我们定义了一个Map对象,用于存储yaml文件的数据。最后,我们使用Yaml对象的load方法读取yaml文件并将其转换成Map对象,并将其输出。 需要注意的是,在读取yaml文件并将其转换成Map对象时,我们需要考虑yaml文件可能出现的各种数据类型并根据需要进行处理,否则可能会出现类型转换错误。同时,我们还需要考虑yaml文件可能出现的空值、重复键等特殊情况,并根据需要进行处理。 ### 回答3: Java开发工具包(JDK)是Java开发的标准工具包,其包含了许多开发Java程序所需要的工具和类库,而YAML是一种轻量级的数据序列化格式,旨在以易读易写的方式表达数据。因此,JDK读取YAML文件并将其转换为map,可以很方便地实现Java程序对YAML文件的读取。 JDK读取YAML文件需要借助第三方库,常见的有jyaml、snakeyaml等。本文以snakeyaml为例,介绍JDK如何读取YAML文件并转换为map。 首先,需要在Maven或Gradle项目引入snakeyaml依赖。 Maven项目依赖: ```xml <dependency> <groupId>org.yaml</groupId> <artifactId>snakeyaml</artifactId> <version>1.29</version> </dependency> ``` Gradle项目依赖: ```gradle compile 'org.yaml:snakeyaml:1.29' ``` 然后在Java代码,使用Yaml类的load方法读取YAML文件,并将其转换为Map对象。示例代码如下: ```java import org.yaml.snakeyaml.Yaml; import java.io.FileInputStream; import java.io.InputStream; import java.util.Map; public class YamlUtils { public static Map<String, Object> readYaml(String filePath) { Map<String, Object> yamlMap = null; try (InputStream input = new FileInputStream(filePath)) { Yaml yaml = new Yaml(); yamlMap = yaml.load(input); } catch (Exception e) { e.printStackTrace(); } return yamlMap; } } ``` 其,readYaml方法接收一个文件路径作为参数,并返回一个Map对象。使用try-with-resources语句打开文件输入流,通过Yaml类的load方法将输入流转换为Map对象。 如果读取的YAML文件是一个包含多个文档的文件,可以使用Yaml类的loadAll方法返回一个包含全部文档的List对象。示例代码如下: ```java import org.yaml.snakeyaml.Yaml; import java.io.FileInputStream; import java.io.InputStream; import java.util.List; public class YamlUtils { public static List<Map<String, Object>> readYaml(String filePath) { List<Map<String, Object>> yamlList = null; try (InputStream input = new FileInputStream(filePath)) { Yaml yaml = new Yaml(); yamlList = yaml.loadAll(input); } catch (Exception e) { e.printStackTrace(); } return yamlList; } } ``` 通过Yaml类读取YAML文件并将其转换为map,可以方便地在Java程序读取YAML格式的配置文件或数据。同时,也能更好地满足Java程序与其他应用程序的数据交换需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值