銀河麒麟V10sp1服務器系統安裝redis不能使用的快速解決辦法
我們在適配時,經常需要安裝redis,但是在銀河麒麟 V10sp1 服務器系統上安裝使用 redis 的時候會有諸多問題,今天我們就來逐步分析解決一下。
1. 配好外網,使用麒麟源安裝redis:
先在源裡搜索一下redis,查看是否有該軟件包:
[root@172-17-102-254 ~]# yum search redis
Last metadata expiration check: 1:46:38 ago on 2020年12月11日 星期五09時55分08秒.
================================================================================ Name Exactly Matched: redis =================================================================================
redis.aarch64 : A persistent key-value database
=============================================================================== Name & Summary Matched: redis ================================================================================
pcp-pmda-redis.aarch64 : Redis PCP metrics
rsyslog-hiredis.aarch64 : Redis support for rsyslog
hiredis-devel.aarch64 : Development files for hiredis
hiredis.aarch64 : A minimalistic C client library for the Redis database
python2-redis.noarch : The Python2 interface to the Redis key-value store
python3-redis.noarch : The Python3 interface to the Redis key-value store
確認有後,我們就可以開始安裝瞭:
yum install redis.aarch64
2. 啟動服務
[root@172-17-102-254 ~]# systemctl start redis
Job for redis.service failed because the control process exited with error code.
See “systemctl status redis.service” and “journalctl -xe” for details.
發現服務啟動失敗。
3. 查看服務和日志,定位問題
我們先來看服務的狀態,看能不能獲取到相關信息:
[root@172-17-102-254 ~]# systemctl status redis.service
●redis.service – Redis persistent key-value database
Loaded: loaded (/usr/lib/systemd/system/redis.service; disabled; vendor preset: disabled)
Active: failed (Result: exit-code) since Fri 2020-12-11 13:40:56 CST; 3min 44s ago
Process: 10223 ExecStart=/usr/bin/redis-server /etc/redis.conf –supervised systemd (code=exited, status=217/USER)
Main PID: 10223 (code=exited, status=217/USER)
12月11 13:40:56 172-17-102-254 systemd[1]: Starting Redis persistent key-value database…
12月11 13:40:56 172-17-102-254 systemd[1]: redis.service: Main process exited, code=exited, status=217/USER
12月11 13:40:56 172-17-102-254 systemd[1]: redis.service: Failed with result ‘exit-code’.
12月11 13:40:56 172-17-102-254 systemd[1]: Failed to start Redis persistent key-value database.
查看狀態沒有獲取到特別有用的信息,我們再來看系統日志/var/log/messages,發現有兩處報錯:
a.沒有日志路徑,不能打開日志文件
redis-server[23358]: *** FATAL CONFIG FILE ERROR ***
redis-server[23358]: Reading the configuration file, at line 171
redis-server[23358]: >>>’logfile /var/log/redis/redis.log’
redis-server[23358]:Can’t open the log file: No such file or directory
發現系統/var/log/下沒有redis目錄,手動創建一個:
[root@172-17-102-254 ~]# mkdir -p /var/log/redis
b.跟redis的systemd服務的用戶相關
systemd[10355]: redis.service: Failed to determine user credentials: No such process
systemd[10355]: redis.service: Failed at step USER spawning /usr/bin/redis-server: No such process
我們再來看一下redis的systemd服務:
[root@172-17-102-254 ~]# cat /lib/systemd/system/redis.service
[Unit]
Description=Redis persistent key-value database
After=network.target
[Service]
ExecStart=/usr/bin/redis-server /etc/redis.conf –supervised systemd
Type=notify
User=redis
Group=redis
RuntimeDirectory=redis
RuntimeDirectoryMode=0755
[Install]
WantedBy=multi-user.target
可以看到,redis.service 服務是用 redis 用戶來啟動的,然而查看瞭/etc/passwd 和 /etc/shadow 文件,都沒有 redis 用戶的記錄,我們來手動創建一個 redis 用戶,並指定 shell 為 /usr/sbin/nologin:
[root@172-17-102-254 ~]#useradd redis -s /usr/sbin/nologin
並且,把剛剛創建的日志目錄的屬組改成redis:root:
[root@172-17-102-254 ~]#chown -R redis:root /var/log/redis
再來重啟服務:systemctl restart redis,發現還是啟動失敗,繼續看messages日志,發現有這一句:
redis-server[10631]: 10631:C 11 Dec 14:15:22.548 # Fatal error,can't open config file '/etc/redis.conf'
查看發現,redis的配置文件/etc/redis.conf的屬組是root,我們將其改為redis:root。
[root@172-17-102-254 ~]#chown redis:root /etc/redis.conf
繼續重啟服務:systemctl restart redis,還是失敗,而且系統日志messages裡沒有提供有效信息,有點頭大。我們再來看下 /var/log/redis/redis.log,發現有一句報錯:
Can’t chdir to ‘/var/lib/redis’: No such file or directory
我們來手動創建一下該目錄,並修改屬組:
[root@172-17-102-254 ~]# mkdir -p /var/lib/redis [root@172-17-102-254 ~]# chown -R redis:root /var/lib/redis
繼續重啟服務:systemctl restart redis,發現終於啟動成功瞭,而且能正常使用。
4. 總結
要在銀河麒麟v10sp1服務器系統上安裝使用redis,有以下幾個步驟需要祚:
a. 添加好redis用戶,並指定shell為nologin
useradd redis -s /usr/sbin/nologin
b. 配好外網,使用銀河麒麟軟件源安裝redis:
c. 創建redis的日志目錄,並修改屬組為redis:root:
mkdir -p /var/log/redis chown -R redis:root /var/log/redis
d. 創建redis的庫目錄,並修改屬組為redis:root:
mkdir -p /var/lib/redis chown -R redis:root
e. 確認以下redis的配置文件/etc/redis.conf的屬組是否為redis:root
另外,經過測試發現,如果你想要把redis的服務以後臺進程 daemon 的方式運行,可以修改配置文件 /etc/redis.conf,把其中的 daemonize 的選項由 no 改為 yes,並且 /lib/systemd/system/redis.service 文件裡 Type 選項由 notify 改為 forKing,systemd 的分析,這裡就不做過多介紹瞭。
總而言之,要仔細看配置文件,碰到問題,需要多看日志文件來解決問題。
到此這篇關於銀河麒麟V10sp1服務器系統安裝redis不能使用的快速解決辦法的文章就介紹到這瞭,更多相關麒麟V10sp1服務器安裝redis內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Mongo服務重啟異常問題的處理方法
- redis如何設置database個數
- redis通過6379端口無法連接服務器(redis-server.exe閃退)
- Redis3.2.11在centos9安裝與卸載過程詳解
- Windows下redis下載、redis安裝及使用教程