Mac OS、Ubuntu 安裝及使用 Consul

来源:http://www.cnblogs.com/xishuai/archive/2016/12/28/macos-ubuntu-install-consul.html
-Advertisement-
Play Games

Consul 概念(摘錄): Consul 是 HashiCorp 公司推出的開源工具,用於實現分散式系統的服務發現與配置。與其他分散式服務註冊與發現的方案,比如 Airbnb 的 SmartStack 等相比,Consul 的方案更“一站式”,內置了服務註冊與發現框 架、分佈一致性協議實現、健康檢 ...


Consul 概念(摘錄):

Consul 是 HashiCorp 公司推出的開源工具,用於實現分散式系統的服務發現與配置。與其他分散式服務註冊與發現的方案,比如 Airbnb 的 SmartStack 等相比,Consul 的方案更“一站式”,內置了服務註冊與發現框 架、分佈一致性協議實現、健康檢查、Key/Value 存儲、多數據中心方案,不再需要依賴其他工具(比如 ZooKeeper 等)。使用起來也較 為簡單。Consul 用 Golang 實現,因此具有天然可移植性(支持 Linux、windows 和 Mac OS X);安裝包僅包含一個可執行文件,方便部署,與 Docker 等輕量級容器可無縫配合。

Consul 功能:

  • 服務發現(Service Discovery):客戶端通過 Consul 提供服務,其他客戶端可以通過 Consul 利用 dns 或者 http 發現依賴服務
  • 健康檢查(Health Checking): Consul 提供任務的健康檢查,可以用來操作或者監控集群的健康,也可以在服務發現時去除失效的服務
  • 鍵值對存儲(Key/Value Store): 存儲層級鍵值對
  • 多數據中心(Multi Datacenter): Consul 支持開箱即用的多數據中心

架構圖:


Mac OS 安裝(使用 homebrew):

$ brew install consul

Ubuntu 安裝:

$ wget https://releases.hashicorp.com/consul/0.7.2/consul_0.7.2_linux_amd64.zip
$ sudo apt-get install unzip

$ ls

$ unzip consul_0.7.2_linux_amd64.zip
$ sudo mv consul /usr/local/bin/consul

$ wget https://releases.hashicorp.com/consul/0.7.2/consul_0.7.2_web_ui.zip
$ unzip consul_0.7.2_web_ui.zip
$ mkdir -p /usr/share/consul
$ mv dist /usr/share/consul/ui

Consul 壓縮包地址:https://www.consul.io/downloads.html

驗證安裝是否成功:

$ consul
usage: consul [--version] [--help] <command> [<args>]

Available commands are:
    agent          Runs a Consul agent
    event          Fire a new event
    exec           Executes a command on Consul nodes
    force-leave    Forces a member of the cluster to enter the "left" state
    info           Provides debugging information for operators
    join           Tell Consul agent to join cluster
    keygen         Generates a new encryption key
    leave          Gracefully leaves the Consul cluster and shuts down
    members        Lists the members of a Consul cluster
    monitor        Stream logs from a Consul agent
    reload         Triggers the agent to reload configuration files
    version        Prints the Consul version
    watch          Watch for changes in Consul

配置 Consul(官方資料):

$ consul agent -dev
$ consul agent -server -bootstrap-expect 1 -data-dir /tmp/consul -ui-dir=./dist  -config-dir /etc/consul.d -bind=192.168.1.100
$ consul agent -data-dir /tmp/consul -node=ubuntu64 -bind=10.9.10.176

上面三種配置說明:

  1. Sever 模式,快捷配置,一般用於調試模式,不建議使用
  2. Sever 模式
  3. Client 模式

配置參數說明:

  • -server:- Serve 模式(不配置為 Client 模式),數量一般為 3-5 個
  • -bootstrap-expect: - Server 數量
  • -data-dir: - 數據目錄
  • -ui-dir: - UI目錄
  • -node: - Node名稱
  • -bind: - 集群通訊地址

Server 模式後臺訪問地址:http://localhost:8500

其他命令:

  • consul members:查看集群成員
  • consul info:查看當前伺服器的狀況
  • consul leave:退出當前服務集群
  • ctrl + c:停止服務

consul members命令示例:

Node                Address            Status  Type    Build  Protocol  DC
server1.consul.com  200.21.1.101:8301  alive   server  0.5.2  2         dc1
agent1.consul.com   200.21.1.201:8301  alive   client  0.5.2  2         dc1
agent2.consul.com   200.21.1.202:8301  alive   client  0.5.2  2         dc1
server2.consul.com  200.21.1.102:8301  alive   server  0.5.2  2         dc1
server3.consul.com  200.21.1.103:8301  alive   server  0.5.2  2         dc1
agent3.consul.com   200.21.1.203:8301  alive   client  0.5.2  2         dc1

參考資料:


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

-Advertisement-
Play Games
更多相關文章
  • 本人是ABP初學者,在看英文文檔和@tkb至簡 的ABP框架理論研究總結(典藏版)時,發現大神@tkb至簡中少了對Value Objects的翻譯,看文檔是新的,大神沒時間把,小弟給補充上。 介紹 值對象基類 最佳實踐 介紹 值對象基類 最佳實踐 介紹 “用於描述領域的某個方面而本身沒有概念標識的對 ...
  • import java.util.ArrayList; import java.util.List; /** * 觀察者模式 * @author TMAC-J * 牽一發而動全身來形容觀察者模式在合適不過了 * 分為拉模式和推模式,這裡不詳細說了 */ public class ObserverPa... ...
  • /** * 模塊模式 * @author TMAC-J * 將一個完整的演算法分離,分成不同的模塊 * 用於有很多步驟的時候,可能以後這些步驟還會增加,把這些步驟分離 * 將有共性的部分放在抽象類中 * 避免代碼重覆 * 有利於演算法擴展 * 假設這個演算法是人,人具有的共性是早上起來穿衣服,吃飯,工作 ... ...
  • /** * 策略模式 * @author TMAC-J * 根據環境的不同選擇不同的策略,把策略用介面抽象出來 */ public class StrategyPattern { interface Strategy{ void operate(); } public class StrategyA... ...
  • import java.util.Hashtable; /** * 享元模式 * @author TMAC-J * 享元模式一般和工廠模式一起使用,但此處為了更好說明,只用享元模式 * 定義:享元模式針對於是一種以時間來切換空間的方式,其公用同一實例,線程池,string都是其應用 */ publi... ...
  • import java.util.LinkedList; /** * 組合模式 * * @author TMAC-J 主要用於樹狀結構,用於部分和整體區別無區別的場景 想象一下,假設有一批連鎖的理髮店,你到每個店去理髮都是等同的 * 那麼假設不用組合模式,你到10家店理髮,你需要知道這10家店或者是... ...
  • Chatper 2 命令模式 命令是一個具象化(實例化)的方法調用。 A command is a reified method call. 定義一個基類,命令的控制對象由參數傳入: 為不同的游戲命令創建子類: 在輸入處理中,為每個按鈕存儲一個指針,綁定一個命令,且可以靈活替換新的命令: 1 cla ...
  • 這裡分析了php面向對象中static靜態屬性和靜態方法的調用。關於它們的調用(能不能調用,怎麼樣調用),需要弄明白了他們在記憶體中存放位置,這樣就非常容易理解了。靜態屬性、方法(包括靜態與非靜態)在記憶體中,只有一個位置(而非靜態屬性,有多少實例化對象,就有多少個屬性)。 <?phpclass Hum ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...