1. 程式人生 > 其它 >Linux下載安裝部署Redis

Linux下載安裝部署Redis

下載Redis

Redis版本 5.0.4
伺服器版本 Linux CentOS 7.6 64位
官網下載地址:https://redis.io/download/
中文網下載地址:http://www.redis.cn/download.html

上傳並解壓並安裝Redis

解壓
下載完成後需要將壓縮檔案解壓,輸入以下命令解壓到當前目錄

tar -zvxf redis-5.0.4.tar.gz

移動redis目錄
一般都會將redis目錄放置到 /usr/local/redis目錄,所以這裡輸入下面命令將目前在/root目錄下的redis-5.0.4資料夾更改目錄,同時更改資料夾名稱為redis。
mv /root/redis-5.0.4 /usr/local/redis

cd到/usr/local/redis目錄,輸入命令make執行編譯命令,接下來控制檯會輸出各種編譯過程中輸出的內容

make

結果報錯了:

因為下載下來的Redis是C語言的原始碼,不能直接執行,所以要make,所報的錯應該是沒有gcc環境,
安裝 gcc 環境,它是Linux下一個編譯器集合

yum install gcc-c++


中間遇到要輸入的,一路yes就可以了
安裝後,可以使用 gcc –v 檢視gcc版本檢測是否安裝好。

執行 make 命令,它會去遠端伺服器下載所有需要的檔案並配置上,因此該操作需要一點時間,稍等一會兒。
結果還是不盡人意,還是報錯了:

針對這個錯誤,我們可以在README.md 檔案中看到解釋。

---------

Selecting a non-default memory allocator when building Redis is done by setting
the `MALLOC` environment variable. Redis is compiled and linked against libc
malloc by default, with the exception of jemalloc being the default on Linux
systems. This default was picked because jemalloc has proven to have fewer
fragmentation problems than libc malloc.

To force compiling against libc malloc, use:

    % make MALLOC=libc

To compile against jemalloc on Mac OS X systems, use:

    % make MALLOC=jemalloc

Verbose build
-------------

解決辦法:清理上次編譯殘留檔案,重新編譯

make distclean  && make


等待出現:

導致出現這個錯誤的原因:錯誤的本質是我們在開始執行make 時遇到了錯誤(大部分是由於gcc未安裝),然後我們安裝好了gcc 後,我們再執行make ,這時就出現了jemalloc/jemalloc.h: No such file or directory。這是因為上次的編譯失敗,有殘留的檔案,我們需要清理下,然後重新編譯就可以了。

安裝

make PREFIX=/usr/local/redis install

這裡多了一個關鍵字: PREFIX= 這個關鍵字的作用是編譯的時候用於指定程式存放的路徑。比如我們現在就是指定了redis必須存放在/usr/local/redis目錄。假設不新增該關鍵字Linux會將可執行檔案存放在/usr/local/bin目錄,庫檔案會存放在/usr/local/lib目錄。配置檔案會存放在/usr/local/etc目錄。其他的資原始檔會存放在usr/local/share目錄。這裡指定號目錄也方便後續的解除安裝,後續直接rm -rf /usr/local/redis 即可刪除redis。

啟動redis

根據上面的操作已經將redis安裝完成了。在目錄/usr/local/redis 輸入下面命令啟動redis

./bin/redis-server& ./redis.conf


上面的啟動方式是採取後臺程序方式,下面是採取顯示啟動方式(如在配置檔案設定了daemonize屬性為yes則跟後臺程序方式啟動其實一樣)。

./bin/redis-server ./redis.conf

兩種方式區別無非是有無帶符號&的區別。 redis-server 後面是配置檔案,目的是根據該配置檔案的配置啟動redis服務。redis.conf配置檔案允許自定義多個配置檔案,通過啟動時指定讀取哪個即可。

這裡列舉下比較重要的配置項:

配置項名稱 配置項值範圍 說明
daemonize yes、no yes表示啟用守護程序,預設是no即不以守護程序方式執行。其中Windows系統下不支援啟用守護程序方式執行
port 指定 Redis 監聽埠,預設埠為 6379
bind 繫結的主機地址,如果需要設定遠端訪問則直接將這個屬性備註下或者改為bind * 即可,這個屬性和下面的protected-mode控制了是否可以遠端訪問 。
protected-mode yes 、no 保護模式,該模式控制外部網是否可以連線redis服務,預設是yes,所以預設我們外網是無法訪問的,如需外網連線rendis服務則需要將此屬性改為no。
timeout 300 當客戶端閒置多長時間後關閉連線,如果指定為 0,表示關閉該功能
loglevel debug、verbose、notice、warning 日誌級別,預設為 notice
databases 16 設定資料庫的數量,預設的資料庫是0。整個通過客戶端工具可以看得到
rdbcompression yes、no 指定儲存至本地資料庫時是否壓縮資料,預設為 yes,Redis 採用 LZF 壓縮,如果為了節省 CPU 時間,可以關閉該選項,但會導致資料庫檔案變的巨大。
dbfilename dump.rdb 指定本地資料庫檔名,預設值為 dump.rdb
dir 指定本地資料庫存放目錄
requirepass 設定 Redis 連線密碼,如果配置了連線密碼,客戶端在連線 Redis 時需要通過 AUTH 命令提供密碼,預設關閉
maxclients 0 設定同一時間最大客戶端連線數,預設無限制,Redis 可以同時開啟的客戶端連線數為 Redis 程序可以開啟的最大檔案描述符數,如果設定 maxclients 0,表示不作限制。當客戶端連線數到達限制時,Redis 會關閉新的連線並向客戶端返回 max number of clients reached 錯誤資訊。
maxmemory XXX 指定 Redis 最大記憶體限制,Redis 在啟動時會把資料載入到記憶體中,達到最大記憶體後,Redis 會先嚐試清除已到期或即將到期的 Key,當此方法處理 後,仍然到達最大記憶體設定,將無法再進行寫入操作,但仍然可以進行讀取操作。Redis 新的 vm 機制,會把 Key 存放記憶體,Value 會存放在 swap 區。配置項值範圍列裡XXX為數值。

這裡我要將daemonize改為yes,不然我每次啟動都得在redis-server命令後面加符號&,不這樣操作則只要回到Linux控制檯則redis服務會自動關閉,同時也將bind註釋,將protected-mode設定為no。
這樣啟動後我就可以在外網訪問了。

設定密碼的流程如下:

vim  /etc/redis.conf

requirepass foobared去掉註釋,foobared改為自己的密碼,我在這裡改為

requirepass 123456

後臺啟動命令:

./bin/redis-server ./redis.conf

參考:
https://blog.csdn.net/bai_shuang/article/details/122945185
https://www.cnblogs.com/operationhome/p/10342258.html