• k8s实战为aspnetcore.webapi微服务注入配置信息


    1、浅析k8s配置信息


    • Secret()

         以密文的形式存储数据,可以用来保存一些敏感信息,例如:OAuth tokens、私钥、密码、数据库连接、事件总线连接等等需要安全存储的私人数据。

    • ConfigMap

        以明文的形式存储数据,可以用来保存一些非敏感信息,例如:应用的配置信息。

         k8s为Secret和ConfigMap提供了4种创建方式(字面量、文件、环境文件、yaml),其实归类来看就是两种创建方式,字面量和文件。

       1.1 如何注入到微服务应用程序呢 ?

         k8s已经为我们提供了两种方式,即通过存储卷(volume)和环境变量的方式注入到微服务应用程序。

    2、实战目的


          以环境变量的方式将k8s的ConfigMap里存储的应用程序配置信息注入到微服务。这也是微软微服务示例应用程序(eshopOnContainer)采用的方式。其他方式,希望大家下去自己实战。

    3、编写yaml资源文件


         ConfigMap资源文件,appsetting.yml如下:

         

           上面标红的就是我们需要注入的配置信息。

           hello-world-deployment-with-settings.yml如下:

                 

    4、创建k8s资源对象   


     通过dashboard查看集群概况,Deployment资源对象如下:

    ConfigMap资源对象如下:

     

    5、运行微服务,查看注入结果


     

    从上面可以看到,注入成功!!!

    6、附言


             当我们采用微服务架构来开发我们应用程序时,如何管理这些庞大的配置信息?如何实现不停机动态注入这些信息到微服务中?如何运用k8s的配置信息和数据存储机制来解耦配置信息与微服务应用程序?请继续关注,我们将一一实战。

    下一篇,我们将实战如何让微服务应用程序动态感知k8s管理的配置信息的变化。

    源码参考:https://github.com/justmine66/k8s.ecoysystem.apps

    做一个有底蕴的软件工作者
  • 相关阅读:
    java栈的实现
    浅谈JSON
    Java反射机制及IoC原理
    ApplicationContext之getBean方法详解
    web.xml中的contextConfigLocation的作用
    ApplicationContext的名称解释
    spring boot如何处理异步请求异常
    screen工具实现简单分析
    SO_LINGER选项的作用和意义
    gcc的异常处理机制
  • 原文地址:https://www.cnblogs.com/justmine/p/8638314.html
Copyright © 2020-2023  润新知