佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 銀河麒麟V10sp1服務器系統(tǒng)安裝redis不能使用的快速解決辦法

銀河麒麟V10sp1服務器系統(tǒng)安裝redis不能使用的快速解決辦法

熱門標簽:鐵路電話系統(tǒng) 網站排名優(yōu)化 呼叫中心市場需求 服務外包 百度競價排名 地方門戶網站 Linux服務器 AI電銷

我們在適配時,經常需要安裝redis,但是在銀河麒麟 V10sp1 服務器系統(tǒng)上安裝使用 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.

發(fā)現服務啟動失敗。

3. 查看服務和日志,定位問題

我們先來看服務的狀態(tài),看能不能獲取到相關信息:

[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.

查看狀態(tài)沒有獲取到特別有用的信息,我們再來看系統(tǒng)日志/var/log/messages,發(fā)現有兩處報錯:

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

發(fā)現系統(tǒng)/var/log/下沒有redis目錄,手動創(chuàng)建一個:

[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 用戶的記錄,我們來手動創(chuàng)建一個 redis 用戶,并指定 shell 為 /usr/sbin/nologin:

[root@172-17-102-254 ~]#useradd redis -s /usr/sbin/nologin

并且,把剛剛創(chuàng)建的日志目錄的屬組改成redis:root:

[root@172-17-102-254 ~]#chown -R redis:root /var/log/redis

再來重啟服務:systemctl restart redis,發(fā)現還是啟動失敗,繼續(xù)看messages日志,發(fā)現有這一句:

redis-server[10631]: 10631:C 11 Dec 14:15:22.548 # Fatal error,can't open config file '/etc/redis.conf'

查看發(fā)現,redis的配置文件/etc/redis.conf的屬組是root,我們將其改為redis:root。

[root@172-17-102-254 ~]#chown redis:root /etc/redis.conf

繼續(xù)重啟服務:systemctl restart redis,還是失敗,而且系統(tǒng)日志messages里沒有提供有效信息,有點頭大。我們再來看下 /var/log/redis/redis.log,發(fā)現有一句報錯:

Can't chdir to '/var/lib/redis': No such file or directory

我們來手動創(chuàng)建一下該目錄,并修改屬組:

[root@172-17-102-254 ~]# mkdir -p /var/lib/redis

[root@172-17-102-254 ~]# chown -R redis:root /var/lib/redis

繼續(xù)重啟服務:systemctl restart redis,發(fā)現終于啟動成功了,而且能正常使用。

4. 總結

要在銀河麒麟v10sp1服務器系統(tǒng)上安裝使用redis,有以下幾個步驟需要祚:

a. 添加好redis用戶,并指定shell為nologin

useradd redis -s /usr/sbin/nologin

b. 配好外網,使用銀河麒麟軟件源安裝redis:

c. 創(chuàng)建redis的日志目錄,并修改屬組為redis:root:

mkdir -p /var/log/redis

chown -R redis:root /var/log/redis

d. 創(chuàng)建redis的庫目錄,并修改屬組為redis:root:

mkdir -p /var/lib/redis

chown -R redis:root

e. 確認以下redis的配置文件/etc/redis.conf的屬組是否為redis:root

另外,經過測試發(fā)現,如果你想要把redis的服務以后臺進程 daemon 的方式運行,可以修改配置文件 /etc/redis.conf,把其中的 daemonize 的選項由 no 改為 yes,并且 /lib/systemd/system/redis.service 文件里 Type 選項由 notify 改為 forKing,systemd 的分析,這里就不做過多介紹了。

總而言之,要仔細看配置文件,碰到問題,需要多看日志文件來解決問題。

到此這篇關于銀河麒麟V10sp1服務器系統(tǒng)安裝redis不能使用的快速解決辦法的文章就介紹到這了,更多相關麒麟V10sp1服務器安裝redis內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Redis實現分布式Session管理的機制詳解
  • kubernetes環(huán)境部署單節(jié)點redis數據庫的方法
  • 使用lua+redis解決發(fā)多張券的并發(fā)問題
  • 使用docker搭建redis主從的方法步驟
  • 基于redis setIfAbsent的使用說明

標簽:銅川 衡水 湘潭 湖南 崇左 仙桃 蘭州 黃山

巨人網絡通訊聲明:本文標題《銀河麒麟V10sp1服務器系統(tǒng)安裝redis不能使用的快速解決辦法》,本文關鍵詞  ;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    曲阜市| 岗巴县| 双流县| 大兴区| 屏东县| 安多县| 高邮市| 冕宁县| 邳州市| 青海省| 德江县| 航空| 商城县| 秦安县| 拜泉县| 衡阳县| 荥经县| 岐山县| 碌曲县| 特克斯县| 榆社县| 亳州市| 新蔡县| 邓州市| 桂林市| 滨海县| 屯留县| 南投市| 孝感市| 兴安盟| 丽江市| 光泽县| 广汉市| 新竹县| 虞城县| 绥德县| 青龙| 新干县| 南靖县| 琼海市| 思南县|