Linux下Redis安裝和自啟動配置__Linux

來源:互聯網
上載者:User

Redis是一個C實現的基於記憶體、可持久化的索引值對資料庫,在分布式服務中常作為快取服務。本篇將介紹在CentOS下如何從零開始安裝到配置啟動服務。 一. 安裝Redis

Redis的安裝其實相當簡單,推薦的方式是下載redis的源碼,並在原生編譯後安裝。

首次進入主資料夾的下載目錄下,執行wget下載源碼

[zhxilin@localhost ~]$ cd 下載[zhxilin@localhost 下載]$ wget http://download.redis.io/redis-stable.tar.gz

接下來解壓之後,移動到/usr/redis目錄下

[zhxilin@localhost 下載]$ tar -zxvf redis-stable.tar.gz [zhxilin@localhost 下載]$ su mv redis-stable /usr/redis

然後進入redis目錄,執行make命令,編譯redis源碼

[root@localhost 下載]# cd /usr/redis/[root@localhost redis]# make

編譯完成之後,在src目錄下有2個重要程式產生,一個是redis-server,另一個是redis-cli;接著進入src目錄,執行make install,這時會把這些可執行程式拷貝到/usr/local/bin目錄下,由於/usr/local/bin是在系統的環境變數$PATH下定義的,因此終端在任意位置就可以執行redis-server和redis-cli了。

[root@localhost redis]# cd src/[root@localhost src]# make install

至此安裝redis的工作就完成了。

我們來看看編譯出來的幾個程式分別是幹什麼的:

redis-server:顧名思義,redis服務

redis-cli:redis client,提供一個redis用戶端,以供串連到redis服務,進行增刪改查等操作

redis-sentinel:redis執行個體的監控管理、通知和執行個體失效備援服務

redis-benchmark:redis的效能測試工具

redis-check-aof:若以AOF方式的持久化,當意外發生時用來快速修複

redis-check-rdb:若以RDB方式的持久化,當意外發生時用來快速修複

 

安裝完成之後,啟動redis-server,並運行redis-cli進行測試

[zhxilin@localhost ~]$ redis-server
[zhxilin@localhost ~]$ redis-cli 127.0.0.1:6379> PINGPONG127.0.0.1:6379> 

如此說明redis服務已經正常工作,如果redis服務未啟動,則運行redis-cli時會報Could not connect to Redis at 127.0.0.1:6379: Connection refused的錯誤。

  二. 配置自啟動

為了讓redis-server能在系統啟動時自動運行,需要將redis服務作為守護進程(daemon)來運行,我們回到/usr/redis/目錄中找到一個redis.conf的檔案,這個檔案是redis服務運行時載入的配置,我們先觀察一下其中的內容

[zhxilin@localhost redis]$ vi redis.conf 

此檔案內容非常長,但是大部分是注釋,我們重點關注其中的幾個設定daemonize和pidfile:

其中daemonize預設值是false,pidfile預設值是pidfile /var/run/redis_6379.pid

第一個表示是否daemon化,顯然我們要把它改成daemonize yes;

第二個表示當服務以守護進程方式運行時,redis預設會把pid寫入/var/run/redis_6379.pid檔案,服務運行中該檔案就存在,服務一旦停止該檔案就自動刪除,因而可以用來判斷redis是否正在運行。

儲存後退出。

有了基本配置,redis還需要有一個管理啟動、關閉、重啟的一個指令碼。redis源碼裡其實已經提供了一個初始化指令碼,位置在/usr/redis/utils/redis_init_script。

我們來看看這個指令碼做了些什麼:

#!/bin/sh#REDISPORT=6379EXEC=/usr/local/bin/redis-serverCLIEXEC=/usr/local/bin/redis-cliPIDFILE=/var/run/redis_${REDISPORT}.pidCONF="/etc/redis/${REDISPORT}.conf"case "$1" in    start)        if [ -f $PIDFILE ]        then                echo "$PIDFILE exists, process is already running or crashed"        else                echo "Starting Redis server..."                $EXEC $CONF        fi        ;;    stop)        if [ ! -f $PIDFILE ]        then                echo "$PIDFILE does not exist, process is not running"        else                PID=$(cat $PIDFILE)                echo "Stopping ..."                $CLIEXEC -p $REDISPORT shutdown                while [ -x /proc/${PID} ]                do                    echo "Waiting for Redis to shutdown ..."                    sleep 1                done                echo "Redis stopped"        fi        ;;    *)        echo "Please use start or stop as first argument"        ;;esac

指令碼中指定了連接埠、server路徑、cli路徑、pidfile路徑以及conf路徑,上述標黃的地方都需要正確配置,多說一句,如果在安裝時執行了make install,那麼這裡的指令碼不需要做多大改動,因為make install把server和cli都拷到/usr/local/bin下面了。

另外看到這裡conf的路徑,我們需要把redis目錄下的redis.conf檔案拷貝到/etc/redis/6379.conf

[root@localhost utils]# cd /etc[root@localhost etc]# mkdir redis[root@localhost etc]# cp /usr/redis/redis.conf /etc/redis/6379.conf 

接著將redis_init_script指令碼拷貝到/etc/init.d/redisd

[root@localhost etc]# cp /usr/redis/utils/redis_init_script /etc/init.d/redisd 

在/etc/init.d下的指令碼都是可以在系統啟動是自動啟動的服務,而現在還缺一個系統啟動時的配置:

[root@localhost zhxilin]# chkconfig redisd on

然後就會發現報了一個錯誤:服務 redisd 不支援 chkconfig 。

參考這篇文章, 這是因為我們需要在redis_init_script的開頭加一個小改動:

#!/bin/sh
# chkconfig: 2345 90 10
# description: Redis is a persistent key-value database

至於這裡2345 90 10分別代表什麼意思,請參考上面的文章連結。

儲存完重新拷貝到/etc/init.d/redisd後,再運行chkconfig就完成了。

 

一切就緒之後,可以執行以下命令檢驗service是否設定成功:

[root@localhost zhxilin]# service redisd start [root@localhost zhxilin]# service redisd stop

等價於

[root@localhost zhxilin]# /etc/init.d/redisd start [root@localhost zhxilin]# /etc/init.d/redisd stop

 

最後重啟一下系統吧,進入系統之後直接運行redis-cli檢驗redis服務是否已經自動運行了。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.