部署Chart應用並使用.net core讀取Kubernetes中的configMap

上一篇文章講了 k8s使用helm打包chart並上傳到騰訊雲TencentHub,今天就講一下使用Helm部署應用並使用configMap代替asp.net core 中的appsettings.json文件。
html

把Chart上傳到TencentHub以後,咱們就能夠經過騰訊雲的容器服務,直接部署Helm應用了。git

部署Helm應用

點擊新建而後選擇TencentHub,私有倉庫,就能夠看到本身上傳的Chart了。填寫一下應用名稱,拉到最下方點擊完成便可建立應用。github

 注意:若是你的yaml文件寫的不對,如少個空格,變量參數名稱寫錯或者不存在,都沒法建立成功。spring

 能夠點擊新建下方那個查看詳情,能夠看到Helm應用安裝日誌,安裝失敗會提示錯誤信息,本身跟據錯誤提示修復本身的錯誤。json

成功安裝後點擊應用能夠查看資源信息和狀態app

注意:Chart部署成功不表明你的服務已經成功啓動了,若是你的服務自己是有問題起不來的話,這裏不會有提示,須要本身去查看Pod是否已經正常啓動成功。asp.net

好了,應用部署完成後,咱們來試試如何讀取configMap。async

讀取configMap

上篇文章沒有把config.yaml文件的內容放出來,裏面內容以下 函數

其中metadata中的name是必選項,namespace不寫的話默認是default,labels用於條件過濾篩選。微服務

data就是咱們的配置內容,key-value的形式存在。

------------------------------------------------分割線-----------------------------------------------------

.net core調用k8s須要使用KubeClient,這裏我使用 https://github.com/tintoy/dotnet-kube-client 來調用k8s的接口。

直接使用nuget搜索KubeClient便可找到。

KubeClient支持依賴注入。須要安裝

KubeClient.Extensions.DependencyInjection
void ConfigureServices(IServiceCollection services)
{
    services.AddKubeClient(new KubeClientOptions
    {
        ApiEndPoint = new Uri("http://localhost:8001"),
        AuthStrategy = KubeAuthStrategy.BearerToken,
        AccessToken = "my-access-token",
        AllowInsecure = true // Don't validate server certificate
    });
}

最簡單的建立一個KubeClient方法以下:

KubeApiClient client = KubeApiClient.Create(new KubeClientOptions
{
    ApiEndPoint = new Uri("http://localhost:8001"),
    AuthStrategy = KubeAuthStrategy.BearerToken,
    AccessToken = "my-access-token",
    AllowInsecure = true // Don't validate server certificate
});

這裏我只是簡單讀取k8s中的configMap,至於用途下面再講。

使用console控制檯程序編寫以下代碼。

class Program
    {
        static async Task Main(string[] args)
        {
            KubeApiClient client = KubeApiClient.Create(new KubeClientOptions
            {
                ApiEndPoint = new Uri("https://xxxxxxx.tencent-cloud.com"),
                AuthStrategy = KubeAuthStrategy.BearerToken,
                AccessToken = "GzxxxxxxxxxxxxxT",
                AllowInsecure = true // Don't validate server certificate
            });
            var configClient = client.ConfigMapsV1();
            var configList = await configClient.List( labelSelector:"configMap=wechat", kubeNamespace: "dev" );
            Console.WriteLine(JsonConvert.SerializeObject(configList));
            Console.ReadKey();
        }
    }

使用KubeApiClient獲取一個configClient,而後configClient.List()獲取k8s中的全部configMap,labelSelector和kubeNamespace都是默承認空參數,用於過濾篩選configMap。

這裏咱們經過斷點能夠看到,已經讀取到wechat中的configMap信息,AppMode:Devlopment 就是咱們config.yaml中data中的內容。

 至此咱們已經完成了.net core讀取configMap的事情了。

asp.net core中加載configMap

使用nuget安裝

KubeClient

KubeClient.Extensions.Configuration

在Startup.cs中的構造函數添加下面代碼便可。

var configBuilder = new ConfigurationBuilder();
var
client = KubeApiClient.Create(new KubeClientOptions
 { ApiEndPoint = new Uri("https://xxxxxxx.tencent-cloud.com"), AuthStrategy = KubeAuthStrategy.BearerToken, AccessToken = "GzxxxxxxxxxxxxxT", AllowInsecure = true // Don't validate server certificate  });
) 
configuration.AddKubeConfigMap(client,
"extensions-sample", reloadOnChange: true);

Configuration = configBuilder.Build();

使用configMap的緣由

如今asp.net core通常是使用appsettings.json文件來讀取項目的配置信息,這樣作很是簡單易容,可是在生產環境特別是微服務上面咱們每每須要一個配置中心來管理應用配置。

目前充當配置中心的產品有不少,如攜程的Apollo,springCloud中的SpringCloudConfigconsul也能夠充當配置中心。

這些都須要額外部署多一個服務,而configMap也能夠實現配置中心的功能,何樂而不爲呢。至於有不一樣意見的讀者,歡迎評論指點指點。

k8s中存儲配置信息的不僅configMap,一些敏感信息,咱們可使用Secret,Secret以密文的方式存儲數據,避免了直接在配置文件中保存敏感信息。

Pod能夠經過Volume或者環境變量的方式使用configMap和Secret。

總結一下

 因爲本身也是剛接觸這個不久,不少都還不沒有深刻理解到,就暫且說說遇到的一些問題吧......

首先最基本的,yaml格式錯誤,yaml很好用無需置疑,可是當配置信息以多起來的時候,yaml空格的問題就容易犯了,畢竟誰不會手誤呢~~~( ͡° ͜ʖ ͡°)

一個是yaml的分號: 後面必須加上一個空格。另外一個是yaml的對象層級是跟據空格劃分的,雖然沒有規定幾個空格一層,可是要同層次的空格都是必須一致的。在yaml上面慎用TAB......(o≖◡≖)

而後呢,就是Chart模板的配置信息。

Chart模板中資源類型是經過kind區分的,而後資源的基本信息是在metadata中描述。

好比說config.yaml中,kind是ConfigMap。

metadata中包含資源的name,namespace,labels等,雖然至於name是必須項,可是最好儘可能把能寫的都寫上。

第一次操做的時候只填寫了name,而後再查詢的時候怎麼都查不出來(ノへ ̄、)而後才知道namespace不對......默認namespace是defalut 〒▽〒

而後,把namespace補上去了,而後再拉一次,出來了,可是是一次性拉取namespace下的全部configMap,無法過濾,而後看了下API才發現能夠用label過濾(;´༎ຶД༎ຶ`)

嗯,而後又補了個labels上去了╮(╯▽╰)╭

嗯,還有其餘不少細節,暫時還沒去接觸,這就不說了(✿◡‿◡)

最後

最後呢,期待各位大佬指點指點○( ^皿^)っHiahiahia…

相關文章
相關標籤/搜索