我们在适配时,经常需要安装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 的分析,这里就不做过多介绍了。
总而言之,要仔细看配置文件,碰到问题,需要多看日志文件来解决问题。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]