繼Nginx和MySQL的部署腳本之后,相信只要你跟著寫了,那么里面的很多關(guān)鍵精髓你已經(jīng)知曉,今天就來練習(xí)一個(gè)寫Redis部署的腳本吧。
同樣地,先給出部署步驟:
1)下載
cd /usr/local/src sudo wget -O redis-7.0.4.tar.gz https://codeload.github.com/redis/redis/tar.gz/refs/tags/7.0.4
2)安裝
#解壓 sudo tar zxvf redis-7.0.4.tar.gz cd redis-7.0.4/ ## 編譯,安裝并指定路徑 sudo make sudomakePREFIX=/usr/local/redisinstall ## 創(chuàng)建conf和log目錄 sudo mkdir /usr/local/redis/{conf,log} ## 創(chuàng)建數(shù)據(jù)目錄 sudo mkdir -p /data/redis ##創(chuàng)建redis服務(wù)的用戶,并更改目錄屬主 sudo useradd -s /sbin/nologin redis sudo chown redis /data/redis /usr/local/redis/log
3)修改配置文件
sudo cp redis.conf /usr/local/redis/conf/ sudo vi /usr/local/redis/conf/redis.conf #修改如下 daemonize no 改為 daemonize yes logfile "" 改為 logfile "/usr/local/redis/log/redis.log" dir ./ 改為 dir /data/redis pidfile /var/run/redis_6379.pid 改為 pidfile /usr/local/redis/log/redis_6379.pid 在# requirepass foobared 下面增加一行 requirepass aminglinux.Com
4)定義systemd服務(wù)管理腳本
sudo vi /lib/systemd/system/redis.service ##內(nèi)容如下 [Unit] Description=redis After=network.target [Service] User=redis Type=forking TimeoutSec=0 PIDFile=/usr/local/redis/log/redis_6379.pid ExecStart=/usr/local/redis/bin/redis-server /usr/local/redis/conf/redis.conf ExecReload=/bin/kill -s HUP $MAINPID ExecStop=/bin/kill -s QUIT $MAINPID PrivateTmp=true [Install] WantedBy=multi-user.target
5)啟動redis服務(wù)
## 更改內(nèi)核參數(shù) sudo vi /etc/sysctl.conf #加入兩行 net.core.somaxconn = 2048 vm.overcommit_memory = 1 ##使內(nèi)核參數(shù)生效 sudo sysctl -p ##加載redis服務(wù) sudo systemctl daemon-reload ##開啟開機(jī)自啟 sudo systemctl enable redis ##啟動服務(wù) sudo systemctl start redis
把部署步驟寫成shell腳本:
#!/bin/bash ck_ok() { if [ $? -ne 0 ] then echo "$1 error." exit 1 fi } download_redis() { cd /usr/local/src if [ -f redis-7.0.4.tar.gz ] then echo "當(dāng)前目錄已存在redis-7.0.4.tar.gz" echo "檢測MD5" file_md5=`md5sum redis-7.0.4.tar.gz | awk '{print $1}'` if [ ${file_md5} == '3a2ce76ef8f5ca3cc6463c487f2d532c' ] then return 0 else echo "file redis-7.0.4.tar.gz md5 check failed" /bin/mv redis-7.0.4.tar.gz redis-7.0.4.tar.gz.old fi fi sudo wget -O redis-7.0.4.tar.gz https://codeload.github.com/redis/redis/tar.gz/refs/tags/7.0.4 ck_ok "下載redis" } install_redis() { cd /usr/local/src sudo tar zxf redis-7.0.4.tar.gz ck_ok "解壓redis源碼包" cd redis-7.0.4/ sudo make && sudo make PREFIX=/usr/local/redis install ck_ok "編譯和安裝redis" sudo mkdir -p /usr/local/redis/{conf,log} sudo mkdir -p /data/redis if id redis &>/dev/null then echo "系統(tǒng)已經(jīng)存在redis用戶,跳過創(chuàng)建" else echo "創(chuàng)建redis用戶" sudo useradd -s /sbin/nologin redis fi ck_ok "創(chuàng)建redis用戶" sudo chown -R redis /data/redis /usr/local/redis/log } config_redis() { echo "配置redis.conf" sudo /bin/cp /usr/local/src/redis-7.0.4/redis.conf /usr/local/redis/conf/redis.conf sudo sed -i 's/daemonize no/daemonize yes/' /usr/local/redis/conf/redis.conf sudo sed -i 's@logfile ""@logfile "/usr/local/redis/log/redis.log"@' /usr/local/redis/conf/redis.conf sudo sed -i 's@dir ./@dir /data/redis@' /usr/local/redis/conf/redis.conf sudo sed -i 's@pidfile /var/run/redis_6379.pid@pidfile /usr/local/redis/log/redis_6379.pid@' /usr/local/redis/conf/redis.conf sudo sed -i '/# requirepass foobared/a requirepass aminglinux.Com' /usr/local/redis/conf/redis.conf echo "配置systemd service" cat >/lib/systemd/system/redis.service <
說明:幾個(gè)關(guān)鍵要領(lǐng)
1)下載之前要先判斷本地是否已經(jīng)下載過該包,如果本地已經(jīng)有包,還需要判斷該包的md5是否符合預(yù)期;
2)解壓后和make以及make install后都要做判斷,這是關(guān)鍵操作,如果這個(gè)沒做對,后面的步驟沒必要執(zhí)行;
3)創(chuàng)建用戶之前先做判斷,看看用戶是否已經(jīng)存在;
4)啟動完服務(wù)還要檢查服務(wù)到底有沒有起來。
審核編輯:劉清
-
MYSQL數(shù)據(jù)庫
+關(guān)注
關(guān)注
0文章
96瀏覽量
9534 -
Redis
+關(guān)注
關(guān)注
0文章
380瀏覽量
11046
原文標(biāo)題:快來檢驗(yàn)一下你到底有沒有掌握這些腳本精髓吧
文章出處:【微信號:aming_linux,微信公眾號:阿銘linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
給你一篇部署文檔,你能不能寫一個(gè)腳本出來
Redis Stream應(yīng)用案例
記一次寫shell腳本的經(jīng)歷記錄
如何使用redis實(shí)現(xiàn)分布式鎖的lua腳本出現(xiàn)和資料說明
寫一個(gè)自動化重啟服務(wù)腳本
一個(gè)比Redis性能更強(qiáng)的數(shù)據(jù):KeyDB
Redis的主從、哨兵、Redis Cluster集群

評論