linux 安装redis4.0.6,Redis(4.0.6)在Linux(CentOS7)下的安装
構建 Redis
redis 目前沒有官方 RPM 安裝包,需要從源代碼編譯,編譯需要安裝 Make 和 GCC。
yum install gcc make
從官網下載 tar 壓縮包。
curl http://download.redis.io/releases/redis-4.0.6.tar.gz
(這種方式下載下來的包,解壓的時候提示gzip:stdin:not in gzip format,網上查找解決方法,說重命名壓縮包,去掉.gz就好了。結果不行。解決方法:直接從上邊的地址下載壓縮包,然后拷貝到Linux下,然后解壓就可以了。)
解壓縮
備注:linux下輸入命令的輔助提示Tab鍵,可以在敲入一部分命令后,Tab一下,后邊的自動出來。
tar zxvf redis-4.0.6.tar.gz
cd redis-4.0.6
make
安裝
cd src
復制 Redis 的服務器和客戶端到 /usr/local/bin。
cp redis-server redis-cli /usr/local/bin
把 sentinel,benchmark 和 check 復制過去。
cp redis-sentinel redis-benchmark redis-check-aof /usr/local/bin
創建redis 配置文件夾
mkdir /etc/redis
在/var/lib/redis 下創建有效的保存數據的目錄
mkdir -p /var/lib/redis/6379
系統參數
為了讓 redis 正常工作需要配置一些內核參數。
配置 vm.overcommit_memory 為1,這可以避免數據被截斷。
sysctl -w vm.overcommit_memory=1
修改 backlog 連接數的最大值超過 redis.conf 中的 tcp-backlog 值,即默認值511。
sysctl -w net.core.somaxconn=512
取消對透明巨頁內存(transparent huge pages)的支持,因為這會造成 redis 使用過程產生延時和內存訪問問題。
echo never >/sys/kernel/mm/transparent_hugepage/enabled
redis.conf
redis.conf 是 redis 的配置文件,然而你會看到這個文件的名字是 6379.conf ,而這個數字就是 redis 監聽的網絡端口。如果你想要運行超過一個的 redis 實例,推薦用這樣的名字。
復制示例的 redis.conf 到/etc/redis/6379.conf。
cp redis.conf /etc/redis/6379.conf
現在編輯這個文件并且配置參數。
vi /etc/redis/6379.conf (也可以通過WinSCP可視化修改)
daemonize
設置 daemonize 為 no,systemd 需要它運行在前臺,否則 redis 會突然掛掉。
daemonize no
pidfile
設置 pidfile 為 /var/run/redis_6379.pid。
pidfile /var/run/redis_6379.pid
port
如果不準備用默認端口,可以修改。
port 6379
loglevel
設置日志級別。
loglevel notice
logfile
修改日志文件路徑。
logfile /var/log/redis_6379.log
dir
設置目錄為 /var/lib/redis/6379
dir /var/lib/redis/6379
requirepass
你可能需要遠程訪問,如果是,那么你應該設置密碼,這樣子每次操作之前要求輸入密碼。
requirepass password
快照
默認情況下,redis 會周期性的將數據集轉儲到我們設置的目錄下的dump.rdb文件。你可以使用 save 命令配置轉儲的頻率,它的第一個參數是以秒為單位的時間幀,第二個參數是在數據文件上進行修改的數量。
每隔15分鐘并且最少修改過一次鍵。
save 900 1
每隔5分鐘并且最少修改過10次鍵。
save 300 10
每隔1分鐘并且最少修改過10000次鍵。
save 60 10000
文件 /var/lib/redis/6379/dump.rdb 包含了從上次保存以來內存里數據集的轉儲數據。因為它先創建臨時文件然后替換之前的轉儲文件,這里不存在數據破壞的問題,你不用擔心,可以直接復制這個文件。
開機時啟動
你可以使用 systemd 將 redis 添加到系統開機啟動列表。
復制示例的 init_script 文件到 /etc/init.d,注意腳本名所代表的端口號。
cp utils/redis_init_script /etc/init.d/redis_6379
現在我們要使用 systemd,所以在 /etc/systems/system 下創建一個單位文件名字為 redis_6379.service。
vi /etc/systemd/system/redis_6379.service
[Unit]
Description=Redis on port 6379
[Service]
Type=forking
ExecStart=/etc/init.d/redis_6379 start
ExecStop=/etc/init.d/redis_6379 stop
[Install]
WantedBy=multi-user.target
現在添加我之前在 /etc/sysctl.conf 里面修改過的內存過量使用和 backlog 最大值的選項。
vm.overcommit_memory = 1
net.core.somaxconn=512
對于透明巨頁內存支持,并沒有直接 sysctl 命令可以控制,所以需要將下面的命令放到 /etc/rc.local 的結尾。
echo never >/sys/kernel/mm/transparent_hugepage/enabled
備注:參考了https://www.cnblogs.com/bincoding/p/6165506.html 這篇文章,結合自己操作中遇到的問題,加了備注。
打開一個窗口,嘗試運行服務端:sudo ./redis-server /etc/redis/6379.conf
或者直接運行 redis-server
打開另一個窗口,嘗試運行客戶端:./redis-cli
因為需要驗證身份,輸入auth password,驗證通過后,嘗試設置key-value
set foo bar
get foo? ?輸出"bar"說明安裝成功,運行成功!
備注:運行各種命令時候提示權限不足時,用sudo來運行。
查看redis運行狀態:ps aux|grep redis
關閉redis server端(比如修改redis遠程登錄密碼后,需要重啟redisserver,先停止,再啟動):kill -9 PID
然后,啟動redis服務端? redis-server /etc/redis/6379.conf
啟動redis客戶端:redis-cli ,如果開啟了遠程使用需要密碼(requirepass),需要輸入auth password 來登錄
使用redis時候,可能在server黑屏下看到,過了一會兒server端準備把內存中的數據寫入到dump.rdb文件,但是權限拒絕。方法:給redis目錄權限:sudo chmod 777 redis
新建rdb文件:touch dump.rdb 賦權限:sudo chmod 777 dump.rdb
c# 客戶端使用csredis連接redis服務端,一直都提示“連接超時”,開始以為是代碼:
using (var redis=new RedisClient("host"))這句話沒加端口導致的,結果,加了6379端口也不起作用,最后發現,即使不加6379,代碼也默認用這個端口,和這個無關。又懷疑redis沒有開啟遠程訪問,于是,上網找資料,說要將6379.conf文件中的bind 127.0.0.1 注釋掉,并且把protected-mode 改為false,結果嘗試后還是失敗。最后,懷疑防火墻的問題,于是,開發6379端口給所有用戶:
>>>?開啟端口
firewall-cmd --zone=public --add-port=6379/tcp --permanent
然后,重啟防火墻:firewall-cmd --reload
再次,重啟redis服務,這次發現c#客戶端訪問已經成功!
總結
以上是生活随笔為你收集整理的linux 安装redis4.0.6,Redis(4.0.6)在Linux(CentOS7)下的安装的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 超级赛亚人四是谁画的啊?
- 下一篇: 个性签名简短唯美