银河麒麟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
确认有后,我们就可以开始安装了:
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 /f --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
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 /f --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 '/f'
exited
查看发现,redis的配置⽂件/f的属组是root,我们将其改为redis:root。
[root@172-17-102-254 ~]#chown redis:root /f
继续重启服务: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的配置⽂件/f的属组是否为redis:root
另外,经过测试发现,如果你想要把redis的服务以后台进程 daemon 的⽅式运⾏,可以修改配置⽂件 /f,把其中的 daemonize 的选项由 no 改为 yes,并且 /lib/systemd/system/redis.service ⽂件⾥ Type 选项由 notify 改为
forKing,systemd 的分析,这⾥就不做过多介绍了。
总⽽⾔之,要仔细看配置⽂件,碰到问题,需要多看⽇志⽂件来解决问题。
到此这篇关于银河麒麟V10sp1服务器系统安装redis不能使⽤的快速解决办法的⽂章就介绍到这了,更多相关麒麟V10sp1服务器安装redis内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。