三、單redis升級redis集群+哨兵

来源:https://www.cnblogs.com/dingdingCat/archive/2022/05/12/16259015.html
-Advertisement-
Play Games

針對假如已經是安裝了redis,只是是單部署,需要把他切換成redis集群+哨兵模式,我因為偷懶,就寫了個腳本來執行,各位看官,請品~你品~你細品~ 首先準備個升級包,放到任意路徑,內容如下: 第一個文件不用管,第二個跟第四個,是把裡面的配置改好,如何配置請參考我之前寫的redis集群一, 然後是u ...


針對假如已經是安裝了redis,只是是單部署,需要把他切換成redis集群+哨兵模式,我因為偷懶,就寫了個腳本來執行,各位看官,請品~你品~你細品~

首先準備個升級包,放到任意路徑,內容如下:

 

 第一個文件不用管,第二個跟第四個,是把裡面的配置改好,如何配置請參考我之前寫的redis集群一,

然後是upgrade.sh腳本內容:

  1 #!/bin/bash
  2 
  3 base_path=/home/zmoon
  4 redis_package_name=redis-5.0.12
  5 
  6 #安裝文件名稱(安裝文件位置=安裝位置+安裝文件名稱)
  7 redis_path=/redis-5.0.12
  8 redis_conf=/etc/redis.conf
  9 sentinel_conf=/etc/sentinel.conf
 10 monitor_redis=/home/zmoon/bin
 11 
 12 
 13 
 14 #判斷redis是否安裝
 15 check_redis(){
 16     if [ -d "$base_path$redis_path" ]; then
 17         echo "redis 已安裝,無需再次安裝!"
 18         return 1
 19     else
 20         return 0
 21     fi
 22 }
 23 
 24 #判斷etc
 25 check_redis_conf(){
 26     if [ -f "$base_path$redis_path$redis_conf" ]; then
 27         echo "redis.conf 已存在,無需再次安裝!"
 28         return 1
 29     else
 30         return 0
 31     fi
 32 }
 33 
 34 #判斷etc redis.conf,sentinel.conf是否存在
 35 check_sentinel_conf(){
 36     if [ -f "$base_path$redis_path$sentinel_conf" ]; then
 37         echo "sentinel.conf 已存在,無需再次安裝!"
 38         return 1
 39     else
 40         return 0
 41     fi
 42 }
 43 
 44 
 45 copy_redis_conf(){
 46     mkdir -p $base_path$redis_path/etc
 47     cp redis.conf $base_path$redis_path/etc/redis.conf
 48     return 2
 49 }
 50 
 51 copy_sentinel_conf(){
 52     mkdir -p $base_path$redis_path/etc
 53     cp sentinel.conf $base_path$redis_path/etc/sentinel.conf
 54     return 2
 55 }
 56 
 57 copy_monitor_sh(){
 58     cp install-zm-redis.sh $monitor_redis/install-zm-redis.sh
 59     return 2
 60 }
 61 
 62 install_redis(){
 63     echo "安裝redis"
 64     
 65     tar -zxvf $redis_package_name.tar.gz
 66     
 67     echo "開始編譯及安裝。。。" 
 68     cd $redis_package_name
 69     
 70     make
 71     make PREFIX=$base_path$redis_path install
 72     
 73     #切換到redis目錄 新建etc文件夾
 74     mkdir -p $base_path$redis_path/etc
 75 
 76     cd ..
 77     
 78     #把配置好的文件複製過來
 79     cp redis.conf $base_path$redis_path/etc/redis.conf
 80     cp sentinel.conf $base_path$redis_path/etc/sentinel.conf
 81     
 82     return 2
 83 
 84 }
 85 
 86 main(){
 87     echo "base_path:$base_path"
 88     
 89     #判斷當前用戶是否為root用戶,不是則終止部署
 90     if [ `whoami` != "root" ]; then
 91         echo "部署請將用戶切換到root用戶,安裝終止"
 92         exit 1
 93     fi
 94 
 95     if [ ! -d "$base_path" ]; then
 96         mkdir $base_path 
 97     fi
 98     
 99     #檢查是否有redis進程
100     # 停止正在運行的services-應用
101     echo "檢查是否有redis進程"
102     pids=`ps -ef|grep redis-server|grep -v 'grep'|awk '{print $2}'`
103     pidsentinel=`ps -ef|grep redis-sentinel|grep -v 'grep'|awk '{print $2}'`
104     pids=${pids%/*}
105     if [ -n "$pids" ];then
106         for pid in $pids
107         do 
108             kill -9 $pid
109         done
110     fi
111 
112     pidsentinel=${pidsentinel%/*}
113     if [ -n "$pidsentinel" ];then
114         for pid in $pidsentinel
115         do 
116             kill -9 $pid
117         done
118     fi
119     
120     echo "------------------------------------------------"
121     echo "Redis service stop"
122     echo "------------------------------------------------"
123     
124     #安裝redis
125     check_redis
126     if [ $? -eq 0 ]; then
127         install_redis
128         
129         if [ $? -eq 2 ]; then
130             echo "redis 安裝成功!"
131         else
132             echo "redis 安裝失敗,安裝終止!"
133             exit 1
134         fi
135     fi
136     
137     #安裝redis
138     check_redis_conf
139     if [ $? -eq 0 ]; then
140         copy_redis_conf
141         
142         if [ $? -eq 2 ]; then
143             echo "redis.conf copy成功!"
144         else
145             echo "redis.conf copy失敗,copy終止!"
146             exit 1
147         fi
148     fi
149     
150     #安裝redis
151     check_sentinel_conf
152     if [ $? -eq 0 ]; then
153         copy_sentinel_conf
154         
155         if [ $? -eq 2 ]; then
156             echo "sentinel.conf copy成功!"
157         else
158             echo "sentinel.conf copy失敗,copy終止!"
159             exit 1
160         fi
161     fi
162     
163     copy_monitor_sh
164         
165         if [ $? -eq 2 ]; then
166             echo "看門貓redis腳本 copy成功!"
167         else
168             echo "看門貓redis腳本 copy失敗,copy終止!"
169             exit 1
170         fi
171     
172     #提示“請輸入當前節點IP(xx.xx.xx.xx):”,把輸入IP保存入變數selfIp中
173     read -p "請輸入當前節點IP(xx.xx.xx.xx):" selfIp
174     #提示“請輸入Redis主節點IP(xx.xx.xx.xx):”,把輸入IP保存入變數nodeIp中
175     read -p "請輸入當前主節點IP(xx.xx.xx.xx):" nodeIp
176 
177 
178     if [ $selfIp = $nodeIp ]
179     then
180         sed -i 's#.*'"sentinel monitor mymaster.*#sentinel monitor mymaster ${nodeIp} 6379 2"'#' /home/zmoon/redis-5.0.12/etc/sentinel.conf
181     else
182         echo -e "replicaof ${nodeIp} 6379" >>  /home/zmoon/redis-5.0.12/etc/redis.conf
183         
184         sed -i 's#.*'"sentinel monitor mymaster.*#sentinel monitor mymaster ${nodeIp} 6379 2"'#' /home/zmoon/redis-5.0.12/etc/sentinel.conf
185     fi
186     
187     #啟動redis
188     $base_path$redis_path/bin/redis-server $base_path$redis_path/etc/redis.conf &
189     $base_path$redis_path/bin/redis-sentinel $base_path$redis_path/etc/sentinel.conf &
190 }
191 main $1
192 exit 0

裡面首先判斷是否有redis進程與sentinel進程,有則kill掉,

然後又判斷是否有安裝redis,

然後是etc下的兩個配置文件是否存在,

進而是修改配置文件的內容,

最後啟動redis服務與哨兵服務,redis升級完成。

請各位看官大大參與評論,指點不足~


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

-Advertisement-
Play Games
更多相關文章
  • 介紹 powerjob提供了容器功能,用來做一些靈活的任務處理。這裡容器為 JVM 級容器,而不是操作系統級容器(Docker)。(至於為什麼取“容器”這個有歧義的名字是因為作者沒想出來更合適的稱呼,哈哈) 用途 有一些任務完全獨立於業務,代碼量也不大,既不希望耦合於原業務代碼,也不值得再搞一套新建 ...
  • 一、問題描述 1、項目需求要求使用PHP8.1.*版本 2、運行程式發現驗證碼不生效報錯如下: 二、錯誤描述 1、報錯信息得出:從浮點(數字)到整數的隱式轉換將失去精度 三、解決流程 1、找到報錯文件位置 vendor\topthink\think-captcha\src\Captcha.php l ...
  • 桑基圖,它的核心是對不同點之間,通過線來連接。線的粗細代表流量的大小。很多工具都能實現桑基 圖,比如:Excel、tableau,我們今天要用 Pyecharts 來繪製。 因為沒有用戶行為路徑相關的公開數據,所以本次實現可視化是根據泰坦尼克號,其生存與遇難的人的 數據,來分析流向路徑。學會思路,你 ...
  • 一個工作3年的小伙子,去面試被問到Spring裡面的問題。 這個問題比較簡單,但是他卻沒有回答上來。 雖然他可以通過搜索引擎找到答案,但是如果沒有理解,下次面試還是不會! 這個面試題是: “Spring中的Bean,作用域有哪些?” 對於這個問題,看看普通人和高手的回答。 普通人: 嗯。。。。。。。 ...
  • 你是否有遇到過這樣的情況,在開發過程中需要比較兩列數據,但使用文本比對工具的話他是按行基準比對的,我還得對每列數據先進行排序,但排序又去哪裡排, 想到 excel 可以排序 , 折騰下來,特別麻煩, 不知道為啥這麼一個小工具都沒有人提供, 這裡 sanri-tools-maven 提供了這個小工具, ...
  • 半年前我開源了 DreamScene2 一個小而快並且功能強大的 Windows 動態桌面軟體。有很多的人喜歡,這使我有了繼續做開源的信心。這是我的第二個開源作品 ScreenshotEx 一個簡單易用的 Windows 截屏增強工具。 歡迎 Star 和 Fork https://github.c ...
  • 在項目中有一個需求是需要在區域網內跨PC遠程調用一個程式,並且要求有界面顯示,調查了一些資料,能實現遠程調用的.Net技術大概有PsExec、WMI、Schedule Task。 這三種方式都做了一個嘗試,結果發現PsExec、WMI都只能在進程列表中看到程式執行,卻無法顯示界面,無法執行程式中的管 ...
  • 本文先給出“win10找不到無線網路報錯”的通用解決方案,併在方案中介紹本次出現的“Windows無法自動將IP協議堆棧綁定到網路適配器”問題。 ...
一周排行
    -Advertisement-
    Play Games
  • # 通過圖片流來返回圖片 # 前言 之前寫了個圖片介面,然後做了個授權,但是光返回圖片地址雖然能適應大部分需求,但是考慮到有些人不想去處理返回值,也是做了個直接返回圖片流的介面。 # 介面展示 ## 返回指定寬度和高度圖片流 ![image](https://img2023.cnblogs.com/ ...
  • System.Speech是.NET框架的一部分,提供了語音識別和語音合成的功能。通過使用System.Speech命名空間中的類,開發人員可以在.NET應用程式中實現語音識別功能。 在本文中,我將演示如何使用 System.Speech.NET,這是開發語音應用程式比較牛逼的內庫。它適用於 .NE ...
  • 導航屬性 導航屬性是作為.NET ORM核心功能中的核心,在SqlSugar沒有支持導航屬性前,都說只是一個高級DbHelper, 經過3年的SqlSugar重構已經擁有了一套 非常成熟的導航屬性體系,本文不是重點講SqlSugar而是重點講導航屬性的作用,讓更多寫Sql人還未使用ORM的人瞭解到O ...
  • SM2是國家密碼管理局於2010年12月17日發佈的橢圓曲線公鑰密碼演算法。 產生背景: 隨著密碼技術和電腦技術的發展,目前常用的1024位RSA演算法面臨嚴重的安全威脅,我們國家密碼管理部門經過研究,決定採用SM2橢圓曲線演算法替換RSA演算法。 SM2演算法和RSA演算法都是公鑰密碼演算法,SM2演算法是一種 ...
  • # 使用c#實現23種常見的設計模式 設計模式通常分為三個主要類別: - 創建型模式 - 結構型模式 - 行為型模式。 這些模式是用於解決常見的對象導向設計問題的最佳實踐。 以下是23種常見的設計模式並且提供`c#代碼案例`: ## 創建型模式: ### 1. 單例模式(Singleton) ``` ...
  • ## 一:背景 ### 1. 講故事 在這麼多的案例分析中,往往會發現一些案例是卡死線上程的內核態棧上,但拿過來的dump都是用戶態模式下,所以無法看到內核態棧,這就比較麻煩,需要讓朋友通過其他方式生成一個藍屏的dump,這裡我們簡單彙總下。 ## 二:如何生成內核態dump ### 1. 案例代碼 ...
  • 有時候,我們為了方便,我們往往使用擴展函數的代碼方式創建很多GridView的操作功能,如在隨筆《在DevExpress中使用BandedGridView表格實現多行表頭的處理》中介紹過多行表頭的創建及綁定處理,在《基於DevExpress的GridControl實現的一些界面處理功能》也介紹了一些... ...
  • # 1、背景 在我們開發的過程中有這麼一種場景, `/projectA` 目錄是 `hadoopdeploy`用戶創建的,他對這個目錄有`wrx`許可權,同時這個目錄屬於`supergroup`,在這個組中的用戶也具有這個目錄的`wrx`許可權,對於其他人,不可訪問這個目錄。現在有這麼一個特殊的用戶`r ...
  • 基於java的倉庫管理系統設計與實現,可適用於出庫、入庫、庫存管理,基於java的出入庫管理,java出入庫管理系統,基於java的WMS倉庫管理系統,庫存物品管理系統。 ...
  • 清醒點[toc] # Java虛擬線程 > 翻譯自 screencapture-pradeesh-kumar-medium-an-era-of-virtual-threads-java ```mermaid flowchart LR introduction-->a(why thread)-->b( ...