004.etcd集群部署-動態發現

来源:https://www.cnblogs.com/itzgr/archive/2019/01/09/10245825.html
-Advertisement-
Play Games

一 etcd發現簡介 1.1 需求背景 在實際環境中,集群成員的ip可能不會提前知道。如使用dhcp自動獲取的情況,在這些情況下,使用自動發現來引導etcdetcd集群,而不是指定靜態配置,這個過程被稱為“發現”。 etcd Discovery 使用已有的 etcd cluster 來註冊和啟動 D ...


一 etcd發現簡介

1.1 需求背景

在實際環境中,集群成員的ip可能不會提前知道。如使用dhcp自動獲取的情況,在這些情況下,使用自動發現來引導etcdetcd集群,而不是指定靜態配置,這個過程被稱為“發現”。
  • etcd Discovery
使用已有的 etcd cluster 來註冊和啟動
  • DNS發現
使用 DNS 啟動。

1.2 實現機制

Discovery service protocol幫助新的etcd成員使用共用URL在集群引導階段發現所有其他成員。 該協議使用新的發現令牌來引導一個唯一的etcd集群。一個發現令牌只能代表一個etcd集群。只要此令牌上的發現協議啟動,即使它中途失敗,也不能用於引導另一個etcd集群。 提示:Discovery service protocol僅用於集群引導階段,不能用於運行時重新配置或集群監視。

1.3 協議工作流程

Discovery protocol是使用內部etcd集群來協調新集群的引導程式。首先,所有新成員都與發現服務交互,並幫助生成預期的成員列表。然後,每個新成員使用此列表引導其伺服器,該列表執行與--initial-cluster標誌相同的功能,即設置所有集群的成員信息。

二 集群部署-etcd自帶發現

2.1 環境準備

ntp配置:略 #建議配置ntp服務,保證時間一致性 etcd版本:v3.3.9 防火牆及SELinux:關閉防火牆和SELinux
名稱 地址 主機名 備註
etcd1 172.24.8.71 etcd1.example.com  
etcd2 172.24.8.72 etcd2.example.com  
etcd3 172.24.8.73 etcd3.example.com  
  1 # hostnamectl set-hostname etcd1.example.com
  2 # hostnamectl set-hostname etcd2.example.com
  3 # hostnamectl set-hostname etcd3.example.com
  4 # vi /etc/hosts
  5 #……
  6 172.24.8.71 etcd1.example.com
  7 172.24.8.72 etcd2.example.com
  8 172.24.8.73 etcd3.example.com
提示:CentOS6.x則修改/etc/sysconfig/network,以上為建議配置項。

2.2 安裝etcd

  1 # ETCD_VER=v3.3.9
  2 # GITHUB_URL=https://github.com/coreos/etcd/releases/download
  3 # DOWNLOAD_URL=${GITHUB_URL}
  4 # rm -f /tmp/etcd-${ETCD_VER}-linux-amd64.tar.gz
  5 # rm -rf /tmp/etcd-download-test
  6 # mkdir -p /tmp/etcd-download-test		#創建下載保存目錄
  7 # curl -L ${DOWNLOAD_URL}/${ETCD_VER}/etcd-${ETCD_VER}-linux-amd64.tar.gz -o /tmp/etcd-${ETCD_VER}-linux-amd64.tar.gz
  8 # tar xzvf /tmp/etcd-${ETCD_VER}-linux-amd64.tar.gz -C /tmp/etcd-download-test --strip-components=1
  9 # cp /tmp/etcd-download-test/etcd /usr/local/bin/
 10 # cp /tmp/etcd-download-test/etcdctl /usr/local/bin/
 11 # rm -f /tmp/etcd-${ETCD_VER}-linux-amd64.tar.gz
 12 
 13 # rm -rf /tmp/etcd-download-test/
 14 # ETCDCTL_API=3
 15 # etcd --version
 16 # etcdctl --version				#查看已安裝版本
提示:所有節點均需要安裝etcd。

2.3 啟動前準備

  1 # mkdir -p /var/log/etcd/			#建議創建etcd日誌保存目錄
  2 # mkdir -p /data/etcd			#建議創建單獨的etcd數據目錄

2.4 創建集群發現

  1 [root@etcd1 ~]# curl https://discovery.etcd.io/new?size=3	#使用公共etcd發現服務
  2 https://discovery.etcd.io/c41a8c03922c32eaa4be1e7bcf6332a8

提示:size為集群節點數量,若未指定數量,則預設位3。

2.5 啟動集群

  1 [root@etcd1 ~]# etcd --name etcd1 --data-dir /data/etcd \
  2 --initial-advertise-peer-urls http://172.24.8.71:2380 \
  3 --listen-peer-urls http://172.24.8.71:2380 \
  4 --listen-client-urls http://172.24.8.71:2379,http://127.0.0.1:2379 \
  5 --advertise-client-urls http://172.24.8.71:2379 \
  6 --discovery https://discovery.etcd.io/c41a8c03922c32eaa4be1e7bcf6332a8
  7 
  8 [root@etcd2 ~]# etcd --name etcd2 --data-dir /data/etcd \
  9 --initial-advertise-peer-urls http://172.24.8.72:2380 \
 10 --listen-peer-urls http://172.24.8.72:2380 \
 11 --listen-client-urls http://172.24.8.72:2379,http://127.0.0.1:2379 \
 12 --advertise-client-urls http://172.24.8.72:2379 \
 13 --discovery https://discovery.etcd.io/c41a8c03922c32eaa4be1e7bcf6332a8
 14 
 15 [root@etcd3 ~]# etcd --name etcd3 --data-dir /data/etcd \
 16 --initial-advertise-peer-urls http://172.24.8.73:2380 \
 17 --listen-peer-urls http://172.24.8.73:2380 \
 18 --listen-client-urls http://172.24.8.73:2379,http://127.0.0.1:2379 \
 19 --advertise-client-urls http://172.24.8.73:2379 \
 20 --discovery https://discovery.etcd.io/c41a8c03922c32eaa4be1e7bcf6332a8
  提示:每個成員必須指定不同的名稱標誌,否則發現將因重覆的名稱而失敗。

2.6 集群檢測

  1 [root@etcd1 ~]# etcdctl member list
  2 [root@etcd1 ~]# etcdctl cluster-health
  14_thumb1

三 集群部署-DNS發現

參考官方文檔:

https://github.com/etcd-io/etcd/blob/master/Documentation/op-guide/configuration.md


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 緣起 哈嘍大家周二好呀,剛剛經歷過了幾天火車搶票,整個人都不好了,不知道小伙伴對今年的春節是否還一如既往的期待呢,眼看都要春節了,本來也想寫篇2018總結篇,但是怕不免會出現雞湯文的窠臼嫌疑,想想還是算了,這幾天和老李聊起來關於寫博客文章,總感覺這一系列還沒有寫完,或者說還有一些沒有收尾好,眼看就要 ...
  • 一.服務的生存期 在容器中每個註冊的服務,根據程式應用需求都可以選擇合適的服務生存期,ASP.NET Core 服務有三種生存期配置: (1) Transient:暫時生存期,在每次請求時被創建。 這種生存期適合輕量級的,無狀態的服務。 (2) Scoped: 作用域生存期,在每次請求被創建一次。 ...
  • Producer:消息的生產者,也就是創建消息的對象 Exchange:消息的接受者,也就是用來接收消息的對象,Exchange接收到消息後將消息按照規則發送到與他綁定的Queue中。下麵我們來定義一個Producer與Exchange。 1.新建.netcore console項目,並引入Rabb ...
  • Linux實用命令 關於Linux中單雙引號的區別: 單引號里的任何字元都會原樣輸出,單引號字元串中的變數是無效的; 雙引號里可以有變數,雙引號里可以出現轉義字元 反引號param=`date`,命令替換,將命令的標準輸出賦值給變數,同$(date) 命令返回值 0 :執行成功(即正常執行,並返回預 ...
  • nginx狀態信息功能的介: Nginx 在編譯安裝 Nginx 的時候添加 --with-http_stub_status_module 參數,其功能是記錄 Nginx 的基本訪問狀態信息,讓使用者瞭解 Nginx 的工作狀態, 可以用 /application/nginx/sbin/nginx ...
  • 上一篇的SVS要用gcc6.3編譯,否則結果不正確,本來以為gcc很好裝,結果發現用apt-get安裝gcc6只能安裝6.5版本,代碼作者奇特的要求只能用gcc6.3,沒辦法只能用源碼裝了,期間碰見了各種各樣的問題,特此記錄。 1.環境要求 安裝gcc之前要安裝gmp,mpfr,mpc,isl這幾個 ...
  • (1)oscdimg下載路徑: 鏈接:https://pan.baidu.com/s/1U_SfamsOvI2nav9odAzujQ 提取碼:21fr (2)以管理員身份運行cmd命令: ...
  • 功能 顯示目錄文件 ls 選項[-alh] [路徑、文件或目錄】 -l(long) 表示 list,表示以詳細列表的形式進行展示;-h 用“k”“M”"G"來顯示文件的目錄和大小; -a (all)表示顯示所有的文件和文件夾(包含了隱藏文件(一般是以“.”開頭)和文件夾) 1、 #mkdir 路徑 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...