Kubernetes Nacos

一、概覽

Nacos 是阿里巴巴推出來的一個新開源項目,這是一個更易於構建雲原生應用的動態服務發現、配置管理和服務管理平臺。

Nacos 致力於幫助您發現、配置和管理微服務。Nacos 提供了一組簡單易用的特性集,幫助您快速實現動態服務發現、服務配置、服務元數據及流量管理。

Nacos 幫助您更敏捷和容易地構建、交付和管理微服務平臺。 Nacos 是構建以“服務”爲中心的現代應用架構 (例如微服務範式、雲原生範式) 的服務基礎設施。

中文官網:https://nacos.io/zh-cn

 

什麼是 Nacos?

服務(Service)是 Nacos 世界的一等公民。Nacos 支持幾乎所有主流類型的“服務”的發現、配置和管理:

Kubernetes Service

gRPC & Dubbo RPC Service

Spring Cloud RESTful Service

Nacos 的關鍵特性包括:

  • 服務發現和服務健康監測

    Nacos 支持基於 DNS 和基於 RPC 的服務發現。服務提供者使用 原生SDKOpenAPI、或一個獨立的Agent TODO註冊 Service 後,服務消費者可以使用DNS TODO 或HTTP&API查找和發現服務。

    Nacos 提供對服務的實時的健康檢查,阻止向不健康的主機或服務實例發送請求。Nacos 支持傳輸層 (PING 或 TCP)和應用層 (如 HTTP、MySQL、用戶自定義)的健康檢查。 對於複雜的雲環境和網絡拓撲環境中(如 VPC、邊緣網絡等)服務的健康檢查,Nacos 提供了 agent 上報模式和服務端主動檢測2種健康檢查模式。Nacos 還提供了統一的健康檢查儀表盤,幫助您根據健康狀態管理服務的可用性及流量。

  • 動態配置服務

    動態配置服務可以讓您以中心化、外部化和動態化的方式管理所有環境的應用配置和服務配置。

    動態配置消除了配置變更時重新部署應用和服務的需要,讓配置管理變得更加高效和敏捷。

    配置中心化管理讓實現無狀態服務變得更簡單,讓服務按需彈性擴展變得更容易。

    Nacos 提供了一個簡潔易用的UI (控制檯樣例 Demo) 幫助您管理所有的服務和應用的配置。Nacos 還提供包括配置版本跟蹤、金絲雀發佈、一鍵回滾配置以及客戶端配置更新狀態跟蹤在內的一系列開箱即用的配置管理特性,幫助您更安全地在生產環境中管理配置變更和降低配置變更帶來的風險。

  • 動態 DNS 服務

    動態 DNS 服務支持權重路由,讓您更容易地實現中間層負載均衡、更靈活的路由策略、流量控制以及數據中心內網的簡單DNS解析服務。動態DNS服務還能讓您更容易地實現以 DNS 協議爲基礎的服務發現,以幫助您消除耦合到廠商私有服務發現 API 上的風險。

    Nacos 提供了一些簡單的 DNS APIs TODO 幫助您管理服務的關聯域名和可用的 IP:PORT 列表.

  • 服務及其元數據管理

    Nacos 能讓您從微服務平臺建設的視角管理數據中心的所有服務及元數據,包括管理服務的描述、生命週期、服務的靜態依賴分析、服務的健康狀態、服務的流量管理、路由及安全策略、服務的 SLA 以及最首要的 metrics 統計數據。

  • 更多的特性列表 ...

 

Nacos 地圖

  • 特性大圖:要從功能特性,非功能特性,全面介紹我們要解的問題域的特性訴求
  • 架構大圖:通過清晰架構,讓您快速進入 Nacos 世界
  • 業務大圖:利用當前特性可以支持的業務場景,及其最佳實踐
  • 生態大圖:系統梳理 Nacos 和主流技術生態的關係
  • 優勢大圖:展示 Nacos 核心競爭力
  • 戰略大圖:要從戰略到戰術層面講 Nacos 的宏觀優勢

 

Nacos 生態圖

如 Nacos 全景圖所示,Nacos 無縫支持一些主流的開源生態,例如

使用 Nacos 簡化服務發現、配置管理、服務治理及管理的解決方案,讓微服務的發現、管理、共享、組合更加容易。

 

二、快速開始

本項目包含一個可構建的Nacos Docker Image,旨在利用StatefulSets在Kubernetes上部署Nacos

 

環境說明

操作系統 ip 主機名 配置 備註
centos 7.6 192.168.31.150  k8s-master 2核4G Kubernetes1.16.3
centos 7.6 192.168.31.183  k8s-node01 2核8G Kubernetes1.16.3
centos 7.6 192.168.31.152 nfs-server 1核2G NFS

 

 

 

 

 

說明

由於node01需要運行mysql主從以及nacos,因此可用內存必須要大於4G才行。

NFS作爲一臺獨立服務器,非K8S集羣節點。

 

Kubernetes1.16.3安裝,請參考鏈接:

https://www.cnblogs.com/xiao987334176/p/11899321.html

 

Clone 項目

登錄到master節點

yum install -y git
mkdir /data/
cd /data/
git clone https://github.com/nacos-group/nacos-k8s.git

 

簡單例子

如果你使用簡單方式快速啓動,請注意這是沒有使用持久化卷的,可能存在數據丟失風險:

cd nacos-k8s
chmod +x quick-startup.sh
./quick-startup.sh

 

測試

服務註冊

查看cluster-ip,等待幾分鐘,保證每一個pod都處於Running狀態。

[root@k8s-master nacos-k8s]# kubectl get pods -o wide
NAME                 READY   STATUS    RESTARTS   AGE    IP              NODE         NOMINATED NODE   READINESS GATES
mysql-master-xptvv   1/1     Running   0          2m6s   10.244.85.195   k8s-node01   <none>           <none>
mysql-slave-d68ls    1/1     Running   0          2m6s   10.244.85.196   k8s-node01   <none>           <none>
nacos-0              1/1     Running   0          2m6s   10.244.85.197   k8s-node01   <none>           <none>
nacos-1              1/1     Running   0          15s    10.244.85.198   k8s-node01   <none>           <none>
nacos-2              1/1     Running   0          7s     10.244.85.199   k8s-node01   <none>           <none>

注意:默認會啓動mysql主從和3個nacos。

其中,我們要的cluster-ip,就是指nacos的ip地址。

 

服務發現

使用第一個nacos的ip地址

# curl -X PUT 'http://10.244.85.197:8848/nacos/v1/ns/instance?serviceName=nacos.naming.serviceName&ip=20.18.7.10&port=8080'
ok

 

服務發現

# curl -X GET 'http://10.244.85.197:8848/nacos/v1/ns/instances?serviceName=nacos.naming.serviceName'

 

發佈配置

# curl -X POST "http://10.244.85.197:8848/nacos/v1/cs/configs?dataId=nacos.cfg.dataId&group=test&content=helloWorld"
true

 

獲取配置

# curl -X GET "http://10.244.85.197:8848/nacos/v1/cs/configs?dataId=nacos.cfg.dataId&group=test"
helloWorld

 

三、高級使用

在高級使用中,Nacos在K8S擁有自動擴容縮容和數據持久特性,請注意如果需要使用這部分功能請使用PVC持久卷,Nacos的自動擴容縮容需要依賴持久卷,以及數據持久化也是一樣,本例中使用的是NFS來使用PVC.

安裝NFS服務器

登錄到nfs-server主機,使用Yum安裝nfs

yum -y install nfs-utils rpcbind
mkdir -p /data/nfs-share

echo "/data/nfs-share *(rw,no_root_squash,sync)" >> /etc/exports
systemctl start nfs && systemctl enable nfs

 

注意:路徑是/data/nfs-share,和deploy/nfs/deployment.yaml 中的路徑是對應的。

* 表示允許任意ip訪問,由於Pod ip是會變動的,因此改爲*

 

安裝NFS客戶端

登錄到k8s-node01,執行

[root@k8s-node01 ~]# yum install nfs-utils -y

注意:由於node節點需要掛載NFS,因此必須要安裝客戶端才能掛載。

 

部署 NFS

創建角色

登錄到k8s-master節點執行

[root@k8s-master nacos-k8s]# kubectl create -f deploy/nfs/rbac.yaml

 

創建 ServiceAccount 和部署 NFS-Client Provisioner

先修改deploy/nfs/deployment.yaml,紅色部分是修改的,完整代碼如下:

apiVersion: v1
kind: ServiceAccount
metadata:
  name: nfs-client-provisioner
---
kind: Deployment
apiVersion: apps/v1
metadata:
  name: nfs-client-provisioner
spec:
  replicas: 1
  selector:
    matchLabels:
      app: nfs-client-provisioner
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: nfs-client-provisioner
    spec:
      serviceAccount: nfs-client-provisioner
      containers:
      - name: nfs-client-provisioner
        image: registry.cn-hangzhou.aliyuncs.com/open-ali/nfs-client-provisioner:latest
        volumeMounts:
        - name: nfs-client-root
          mountPath: /persistentvolumes
        env:
        - name: PROVISIONER_NAME
          value: fuseim.pri/ifs
        - name: NFS_SERVER
          value: 192.168.31.152
        - name: NFS_PATH
          value: /data/nfs-share
      volumes:
      - name: nfs-client-root
        nfs:
          server: 192.168.31.152
          path: /data/nfs-share

說明:

1. 由於是Kubernetes1.16.3版本,因此extensions/v1beta1是不支持的,必須要改成apps/v1

2. 使用apps/v1後,必須要指定selector字段,因此增加了selector相關代碼。

3. 由於默認的quay.io/external_storage/nfs-client-provisioner:latest無法下載,需要改成阿里雲鏡像才行。

4. 指定NFS服務器的ip地址。

 

打label標籤,這裏指定k8s-node01節點

[root@k8s-master nacos-k8s]# kubectl label node k8s-node01 app=nfs-client-provisioner

 

執行yaml文件

[root@k8s-master nacos-k8s]# kubectl create -f deploy/nfs/deployment.yaml

 

創建 NFS StorageClass

[root@k8s-master nacos-k8s]# kubectl create -f deploy/nfs/class.yaml

 

驗證NFS部署成功

[root@k8s-master nacos-k8s]# kubectl get pod -l app=nfs-client-provisioner
NAME                                      READY   STATUS    RESTARTS   AGE
nfs-client-provisioner-76d8f94ddc-h7dj6   1/1     Running   0          61s

 

部署數據庫

由於在 quick-startup.sh 腳本中,已經部署了mysql主從,這裏就不需要重複執行了。

 

部署Nacos

由於在 quick-startup.sh 腳本中,已經部署了 nacos,這裏就不需要重複執行了。

默認創建了3個副本。

 

四、訪問Nacos

這裏以nodeport方式,發佈 Nacos service

修改yaml文件

[root@k8s-master nacos-k8s]# vi ./deploy/nacos/nacos-quick-start.yaml

 

增加紅色部分

---
apiVersion: v1
kind: Service
metadata:
  name: nacos-headless
  labels:
    app: nacos-headless
spec:
  type: NodePort
  ports:
    - port: 8848
      name: server
      targetPort: 8848
      protocol: TCP
      nodePort: 30848
  selector:
    app: nacos
---

 

重新發布

[root@k8s-master nacos-k8s]# kubectl apply -f ./deploy/nacos/nacos-quick-start.yaml

 

查看svc

[root@k8s-master nacos-k8s]# kubectl get svc
NAME             TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)          AGE
kubernetes       ClusterIP   10.1.0.1       <none>        443/TCP          28d
mysql-master     ClusterIP   10.1.100.185   <none>        3306/TCP         60m
mysql-slave      ClusterIP   10.1.39.252    <none>        3306/TCP         60m
nacos-headless   NodePort    10.1.118.226   <none>        8848:30848/TCP   60m

 

訪問頁面

使用 http://master ip:30848/nacos,比如:

http://192.168.31.150:30848/nacos

 

登錄信息:

默認賬號:nacos
默認密碼:nacos

 

 

登錄之後,效果如下:

 

 

本文參考鏈接:

https://nacos.io/zh-cn/docs/use-nacos-with-kubernetes.html

https://www.jianshu.com/p/21d916643560
https://www.cnblogs.com/mutong1228/p/11124590.html
http://d0o0bz.cn/2018/10/k8s-nfs-client-provisioner/

 

發佈了287 篇原創文章 · 獲贊 10 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章