Centos下Zookeeper的安裝部署

来源:https://www.cnblogs.com/yangyuanhu/archive/2020/06/06/13057785.html
-Advertisement-
Play Games

一 安裝jdk zookeeper是採用java開發的,所以需要依賴jdk環境,我們需要先安裝jdk,最便捷的方式就是採用yum,但是yum的官方源速度很慢,我們可以先更換yum源; #備份初始源 mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos ...


一 安裝jdk

zookeeper是採用java開發的,所以需要依賴jdk環境,我們需要先安裝jdk,最便捷的方式就是採用yum,但是yum的官方源速度很慢,我們可以先更換yum源;

#備份初始源 
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
#下載新的CentOS-Base.repo 源文件 
cd /etc/yum.repos.d
curl -O http://mirrors.aliyun.com/repo/Centos-7.repo
mv Centos-7.repo CentOS-Base.repo
#更新緩存
yum clean all
yum makecache

ok現在我們就可以使用yum安裝需要的jdk了

yum -y install java-1.8.0-openjdk-demo.x86_64
#驗證一下  
java -version

二 安裝zookeeper

#下載二進位壓縮包
wget https://mirror.bit.edu.cn/apache/zookeeper/zookeeper-3.6.1/apache-zookeeper-3.6.1-bin.tar.gz

#解壓縮
tar -zxvf apache-zookeeper-3.5.7-bin.tar.gz
#移動至local下
mv apache-zookeeper-3.5.7-bin /usr/local
# 創建軟連接
ln -s /usr/local/apache-zookeeper-3.5.7-bin /usr/local/zookeeper
# 添加至環境變數
echo export PATH=\"\$PATH:/usr/local/zookeeper/bin\" >> ~/.bashrc
source ~/.bashrc

目錄結構:

image-20200507153419750

配置文件模板:

image-20200507153439527

主要配置項:

image-20200507153454381

三 啟動與訪問

#在啟動前需要先提供 一個dataDir,在安裝目錄下創建名為data的目錄
#該目錄預設指向tmp必須修改,用於存儲zookeeper持久化數據和日誌文件;
cd /usr/local/zookeeper
mkdir data

#複製配置模板更名為zoo.cfg
cd /usr/local/zookeeper/conf
cp zoo_sample.cfg  zoo.cfg

#修改zoo.cfg中的dataDir指向新建的data目錄
#dataDir=/usr/local/zookeeper/data

#啟動
zkServer.sh start

客戶端訪問

zkCli.sh
#當伺服器不在當前機器上時通過 -server參數指定主機地址 
zkCli.sh -server 10.211.55.3:2181

四 集群搭建

集群搭建準備

在開始搭建集群之前我們需要先瞭解一下概念:

三種角色:

為了避免 Zookeeper 的單點問題,zk 也是以集群的形式出現的。zk 集群中的角色主要有 以下三類:

  • Leader 集群的主節點,可以處理寫請求,並將數據同步至從節點

  • Follower 從節點,跟隨者,決策者,學習者,僅可以處理讀請求,收到寫請求是自動轉發給leader,具備選舉權,被選舉權,決策權

  • Observer 學習者 僅可處理讀請求,且不具備選舉權,被選舉權和決策權

    由於選舉leader的過程使用的是paxos演算法,參與選舉的節點越多則選舉過程越慢,且選舉過程中節點不可對外服務,Observe可以縮短leader選舉過程所需的時間; 減少集群不可用;

法定人數

zookeeper伺服器運行於兩種模式:獨立模式和集群模式。集群模式下,會複製所有伺服器的 數據樹。但如果讓客戶端等待所有複製完成,延遲太高。這裡引入法定人數概念,指為了使zookeeper 集群正常工作,必須有效運行的伺服器數量。同時也是伺服器通知客戶端保存成功前,必須保存數據的 伺服器最小數。例如我們有一個5台伺服器的zookeeper集群,法定人數為3,只要任何3個伺服器保存了數據,客戶端就會收到確認。

image-20200606132424972

另外當法定人數為3時,集群中只要有3台伺服器存活,整個zookeeper集群就是可用的。

image-20200606132648464

註意:observer不算在法定人數內

集群應有奇數個節點

zookeeper節點數量因當是大於1的奇數,因為zookeeper集群必須在大多數節點都可用的情況下才能正常提供訪問,若節點為3個則運行宕機1個,若節點為4個同樣只允許宕機1個,偶數個節點的允許宕機的節點占比更低;

集群搭建

ip配置

通常虛擬機會以dhcp的方式獲得ip,ip可能會發生變化,造成無法連接伺服器,所以我們先對克隆得到的虛擬機,進行靜態ip配置,同時修改hostname,保證集群中所有伺服器的主機名和地址都是不同的

#修改主機名稱  zk1 是新的主機名
echo zk1 > /etc/hostname
#修改 ip配置
vim /etc/sysconfig/network-scripts/ifcfg-eth0

修改後的文件內容:

image-20200507153513399

只修改標註的內容,其他的保持原樣

防火牆設置:

為了使伺服器之間能互相訪問,需要開放對應埠,或是停止防火牆(僅限測試環境),相關 指令 如下:

#1.禁止firewall開機啟動
systemctl disable firewalld
#2.設置開機啟動防火牆
systemctl enable firewalld.service

zookeeper集群部署

zookeeper節點數量因當是大於1的奇數,因為zookeeper集群必須在大多數節點都可用的情況下才能正常提供訪問,若節點為3個則運行宕機1個,若節點為4個同樣只允許宕機1個,偶數個節點的允許宕機的節點占比更低;

1.在配置文件中配置節點信息

image-20200507153528178

註意:若是在一臺機器上做測試,則需要需改clientPort,以及每個節點的通信埠和選舉埠,保證不與其他節點衝突

2.在dataDir目錄下創建myid

該文件用於存儲集群中各個zookeeper節點的編號

創建myid文件:

touch /usr/local/zookeeper/data/myid
#文件內容為當前zookeeper的節點編號與配置文件對應
echo 1 > /usr/local/zookeeper/data/myid

註意:若data目錄下有其他文件則需要刪除,在創建集群前要保持zookeeper是空的

3.克隆當前虛擬機

1.逐個啟動新的虛擬機並修改ip地址(按照上面的方法)

2.修改myid文件中的節點id與配置文件匹配

3.逐個啟動每個虛擬機上的zookeeper服務

zkServer.sh start
#啟動完成後可以通過以下指令查看當前zookeeper的狀態
zkServer.sh status

可以發現此時有一個leader和兩個follower表示集群已正常運行

Observer

為什麼需要Observer:

為了提高zookeeper的吞吐量,我們可以為其添加更多的follower,但是更多的follower會導致投票過程變得更慢,而客戶端的響應時間變長(因為投票過程zookeeper不能響應),因此zookeeper設計了Observer節點

什麼是Observer:

Observer與普通的 follower僅有一個區別: Observer不參與 投票環節; 但是提議 和commit同樣會發送給Observer,這意味著Observer中的數據也是一致的,既提高了整個集群的性能同時避免了,投票帶來的延遲;

配置方法:

只需要在 節點後面 添加observer關鍵字即可將節點作為Observer

echo server.4=10.211.55.9:28888:38888:observer >> /usr/local/zookeeper/conf/zoo.cfg
#添加後的內容:
server.1=10.211.55.5:28888:38888
server.2=10.211.55.6:28888:38888
server.3=10.211.55.7:28888:38888
server.4=10.211.55.8:28888:38888:observer

啟動集群後通過status查看節點狀態:

zkServer.sh status
/usr/bin/java
ZooKeeper JMX enabled by default
Using config: /usr/local/zookeeper/bin/../conf/zoo.cfg
Client port found: 2181. Client address: localhost.
Mode: observer

但要註意Observer不能算在法定人數內;


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

-Advertisement-
Play Games
更多相關文章
  • 1、圓角邊框 定義圓角邊框後,可以將盒子定義為圓角的 (1)長度方式 <html> <head> <meta charset="utf-8"> <title>盒子模型外邊距</title> <style> div{ width: 200px; height: 100px; background-co ...
  • 13.5 記憶體和性能 Javascript 中函數都是對象,過多被添加到事件的處理程式都會占用記憶體,記憶體中對象越多性能就越差。其次,事先指定好所有事件處理程式而導致的DOM訪問次數也會延遲整個頁面的交互就緒時間 對付“事件處理程式過多”的方案就是事件委托,事件委托利用了事件冒泡只指定一個事件處理程式 ...
  • 前面幾章蜻蜓點水的介紹了elasticsearch、apm相關的內容。本片主要介紹怎麼使用ELK Stack幫助我們打造一個支撐起日產TB級的日誌監控系統 背景 在企業級的微服務環境中,跑著成百上千個服務都算是比較小的規模了。在生產環境上,日誌扮演著很重要的角色,排查異常需要日誌,性能優化需要日誌, ...
  • 消息中間件作為分散式系統的重要成員,各大公司及開源均有許多解決方案。目前主流的開源解決方案包括RabbitMQ、RocketMQ、Kafka、ActiveMQ等。消息這個東西說簡單也簡單,說難也難。簡單之處在於好用方便,接入簡單使用簡單,非同步操作能夠解耦系統間的依賴,同時失敗後也能夠追溯重試。難的地 ...
  • 0 專輯概述 etcd 是雲原生架構中重要的基礎組件,由 CNCF 孵化托管。etcd 在微服務和 Kubernates 集群中不僅可以作為服務註冊與發現,還可以作為 key-value 存儲的中間件。 《徹底搞懂 etcd 系列文章》將會從 etcd 的基本功能實踐、API 介面、實現原理、源碼分 ...
  • 狀態模式用於解決系統中複雜對象的狀態轉換以及不同狀態下行為的封裝問題 模式動機 很多情況下,一個對象的行為取決於一個或多個動態變化的屬性,這樣的屬性叫做狀態。一個對象可以擁有多個狀態,這些狀態可以相互轉換,當對象狀態不同時,其行為也有所差異。 假設一個人就是對象,人根據心情不同會有很多狀態,比如開心 ...
  • 對於python中pip安裝庫文件超時問題 找了好多方法,發現更換安裝源最適合我 方案一:對於比較小的庫,可以延時處理 pip --default-timeout=100 install -U pip pip --default-timeout=100 install 第三方庫名方案二:更換安裝源 ...
  • https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1591472927710&di=fdd3da90a98ed401c87ddaf96fdbade2&imgtype=0&src=http%3A%2F%2F5b098... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...