天翼云centos7.6安装redis6.2.6
以下部分的具体略:
1.wget获取源码
2.make
这里重点说下,如何使用 utils/install_server.sh脚本
使用install_service.sh添加服务
有了这个脚本,那么配置和安装为单机服务就很容易了,因为这个脚本:
1.手动提示输入多个配置参数,对于开发环境快速配置也是不错的选择,因为甚至不需要打开redis.conf文件,并亲自修改它。
2.安装一个服务叫redis_port的服务,如果port=8933 ,那么服务就叫redis_8933
当然,我们可以修改 install_server.sh脚本,生成不一样的服务名称。
注:这个不是一个推荐的方式,毕竟upstart是一个比较反人性的方式,最好还是直接看后文:使用systemctl 添加服务
linux加入systemctl就已经严重地意识到人性化的重要性。
由于是centos7,有systemctl组件,所以执行前得修改下install_server.sh,注释掉下面得脚本:
#bail if this system is managed by systemd
#_pid_1_exe="$(readlink -f /proc/1/exe)"
#if [ "${_pid_1_exe##*/}" = systemd ]
#then
# echo "This systems seems to use systemd."
# echo "Please take a look at the provided example service unit files in this directory, and adapt and install them. Sorry!"
# exit 1
#fi
之后,进入utils目录,执行
./install_server.sh
输入和输出如下:
[root@lzf-ty utils]# ./install_server.sh
Welcome to the redis service installer
This script will help you easily set up a running redis server This systems seems to use systemd.
Please take a look at the provided example service unit files in this directory, and adapt and install them. Sorry!
[root@lzf-ty utils]# ./install_server.sh
Welcome to the redis service installer
This script will help you easily set up a running redis server Please select the redis port for this instance: [9736]
Selecting default: 9736
Please select the redis config file name [/etc/redis/9736.conf] /soft/redis-6.2.6/src/redis.conf
Please select the redis log file name [/var/log/redis_9736.log]
Selected default - /var/log/redis_9736.log
Please select the data directory for this instance [/var/lib/redis/9736] /soft/redis-6.2.6/data
Please select the redis executable path [] /soft/redis-6.2.6/src/redis-server
Selected config:
Port : 9736
Config file : /soft/redis-6.2.6/src/redis.conf
Log file : /var/log/redis_9736.log
Data dir : /soft/redis-6.2.6/data
Executable : /soft/redis-6.2.6/src/redis-server
Cli Executable : /soft/redis-6.2.6/src/redis-cli
Is this ok? Then press ENTER to go on or Ctrl-C to abort.
Copied /tmp/9736.conf => /etc/init.d/redis_9736
Installing service...
Successfully added to chkconfig!
Successfully added to runlevels 345!
Starting Redis server...
Installation successful!
使用chkconfig查看下安装好得服务
[root@lzf-ty utils]# chkconfig --list Note: This output shows SysV services only and does not include native
systemd services. SysV configuration data might be overridden by native
systemd configuration. If you want to list systemd services use 'systemctl list-unit-files'.
To see services enabled on particular target use
'systemctl list-dependencies [target]'. mysqld 0:off 1:off 2:on 3:on 4:on 5:on 6:off
netconsole 0:off 1:off 2:off 3:off 4:off 5:off 6:off
network 0:off 1:off 2:on 3:on 4:on 5:on 6:off
redis_9736 0:off 1:off 2:on 3:on 4:on 5:on 6:off
最后启动,并验证下服务
[root@lzf-ty utils]# systemctl status redis_9736
● redis_9736.service - LSB: start and stop redis_9736
Loaded: loaded (/etc/rc.d/init.d/redis_9736; bad; vendor preset: disabled)
Active: active (exited) since Wed 2021-11-10 13:46:12 CST; 9s ago
Docs: man:systemd-sysv-generator(8)
Process: 5677 ExecStart=/etc/rc.d/init.d/redis_9736 start (code=exited, status=0/SUCCESS)
[root@lzf-ty src]# ./redis-cli -p 9736
127.0.0.1:9736> set lan java
OK
127.0.0.1:9736> get java
(nil)
127.0.0.1:9736> get lan
"java"
127.0.0.1:9736>
再看看redis日志,真得很贴心!!!
[root@lzf-ty log]# cat redis_9736.log
5632:C 10 Nov 2021 13:44:22.370 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
5632:C 10 Nov 2021 13:44:22.370 # Redis version=6.2.6, bits=64, commit=00000000, modified=0, pid=5632, just started
5632:C 10 Nov 2021 13:44:22.370 # Configuration loaded
5632:M 10 Nov 2021 13:44:22.371 * Increased maximum number of open files to 10032 (it was originally set to 1024).
5632:M 10 Nov 2021 13:44:22.371 * monotonic clock: POSIX clock_gettime
5632:M 10 Nov 2021 13:44:22.371 * Running mode=standalone, port=9736.
5632:M 10 Nov 2021 13:44:22.371 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.
5632:M 10 Nov 2021 13:44:22.371 # Server initialized
5632:M 10 Nov 2021 13:44:22.371 # WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.
5632:M 10 Nov 2021 13:44:22.372 * Ready to accept connections
这样,一个单机redis很快就完成了,当然,这些还是不够自动化,如果有必要可以全部编写为一个完全自动安装得脚本,从而至少可以节约30分钟以上!
使用systemctl 添加服务
毕竟init.d已经是比较落后的方式,centos/linux会逐渐使用systemctl来控制服务,所以可以使用systemctl来添加注册服务。
如何使用sytemctl注册服务,可以参阅 https://www.jianshu.com/p/79059b06a121
注意:systemctl可以管理两个配置的服务upstart(init.d)和systemd(....service)
在centos7.6中,查看系统服务都是systemd模式的:
这个版本的redis也很贴心地给了一个systemctl服务的模板,分单机和集群的,我们来看下单机的模板:
systemd-redis_server.service
# example systemd service unit file for redis-server
#
# In order to use this as a template for providing a redis service in your
# environment, _at the very least_ make sure to adapt the redis configuration
# file you intend to use as needed (make sure to set "supervised systemd"), and
# to set sane TimeoutStartSec and TimeoutStopSec property values in the unit's
# "[Service]" section to fit your needs.
#
# Some properties, such as User= and Group=, are highly desirable for virtually
# all deployments of redis, but cannot be provided in a manner that fits all
# expectable environments. Some of these properties have been commented out in
# this example service unit file, but you are highly encouraged to set them to
# fit your needs.
#
# Please refer to systemd.unit(5), systemd.service(5), and systemd.exec(5) for
# more information. [Unit]
Description=Redis data structure server
Documentation=https://redis.io/documentation
#Before=your_application.service another_example_application.service
#AssertPathExists=/var/lib/redis
Wants=network-online.target
After=network-online.target [Service]
ExecStart=/usr/local/bin/redis-server --supervised systemd --daemonize no
## Alternatively, have redis-server load a configuration file:
#ExecStart=/usr/local/bin/redis-server /path/to/your/redis.conf
LimitNOFILE=10032
NoNewPrivileges=yes
#OOMScoreAdjust=-900
#PrivateTmp=yes
Type=notify
TimeoutStartSec=infinity
TimeoutStopSec=infinity
UMask=0077
#User=redis
#Group=redis
#WorkingDirectory=/var/lib/redis [Install]
WantedBy=multi-user.target
如果不修改以上文件,则必须把redis.conf放在/etc下,否则会找不到。
如果不想放在/etc下,那么则必须修改redis.conf配置文件,并在配置文件中指定两个选项:
supervised -- 监护方式
daemonize -- 守护
来看下样例redis.conf中,关于这个参数的说明:
# By default Redis does not run as a daemon. Use 'yes' if you need it.
# Note that Redis will write a pid file in /var/run/redis.pid when daemonized.
# When Redis is supervised by upstart or systemd, this parameter has no impact.
# 中文大意:默认不使用守护模式(kill它都会困难,因为会反复重启)。如果使用 systemd的监管方式,那么这个参数如何设置无所谓
daemonize no # If you run Redis from upstart or systemd, Redis can interact with your
# supervision tree. Options:
# supervised no - no supervision interaction --没有交互,不能使用友好的命令的开启,查看,关闭,当然kill之类是可以的。
# supervised upstart - signal upstart by putting Redis into SIGSTOP mode -- upstart,传统的监管方式,就是创建init.d之类的文件
# requires "expect stop" in your upstart job config
# supervised systemd - signal systemd by writing READY=1 to $NOTIFY_SOCKET -- centos7之后的新潮监管模式,这是系统推荐的
# on startup, and updating Redis status on a regular
# basis.
# supervised auto - detect upstart or systemd method based on
# UPSTART_JOB or NOTIFY_SOCKET environment variables --自动模式,就看有没有配置环境变量UPSTART_JOB 或者NOTIFY_SOCKET
# Note: these supervision methods only signal "process is ready."
# They do not enable continuous pings back to your supervisor.
#
# The default is "no". To run under upstart/systemd, you can simply uncomment
# the line below:
#
# supervised auto
换言之,上面这一段,可以简化为两条(如果要使用systemctl)
# daemonize 不设置也无所谓
daemonize no
supervised systemd
当redis.conf中做了如上配置之后,则可以在systemd-redis_server.service,如下操作
[Service]
# 注释掉下面这一句,因为我没有把redis.conf放在/etc下
# ExecStart=/usr/local/bin/redis-server --supervised systemd --daemonize no
## Alternatively, have redis-server load a configuration file:
# 使用下面这个,因为我已经在redis.conf中设置了 daemonize,supervised两个参数
ExecStart=/usr/local/bin/redis-server /path/to/your/redis.conf
天翼云centos7.6安装redis6.2.6的更多相关文章
- 阿里云CentOS7.x安装nodejs及pm2
对之前文章的修订 您将了解 CentOS下如何安装nodejs CentOS下如何安装NVM CentOS下如何安装git CentOS下如何安装pm2 适用对象 本文档介绍如何在阿里云CentOS系 ...
- 阿里云CentOs7上安装Tomcat
一.下载安装tomcat8 cd /usr/ #创建tomcat目录 mkdir tomcat #从网上download 压缩包 wget tomcat8 url #解压 tar -zxvf apac ...
- 阿里云 Centos7.3安装mysql5.7.18 rpm安装
卸载MariaDB CentOS7默认安装MariaDB而不是MySQL,而且yum服务器上也移除了MySQL相关的软件包.因为MariaDB和MySQL可能会冲突,故先卸载MariaDB. 1.安装 ...
- 阿里云centos7成功安装和启动nginx,但是外网访问不了的解决方案
问题环境: 阿里云centos7.4.1708 问题描述:成功配置,启动成功,外网访问不了 解决方案: 经过查阅文档,去阿里云后台查看,原来是新购的服务器都加入和实例安全组. (OMG)立即去配置.加 ...
- 阿里云CentOS-7.2安装mysql
我下载的阿里云的服务器系统centos7.2是纯内核版本,并没有其他的工具,所以这个系统是非常干净的.所以我就需要给系统安装一一些工具,来方便系统的管理与操作,我们上面讲到了关于服务器的yum的配置在 ...
- 腾讯云centos7.2安装jdk1.7 tomcat7.0部署项目示例
说实话win server的性能并不好,所以程序员必须会在Linux上安装环境,部署项目. 第一步,官网下载tomcat和jdk压缩文件*.tar.gz 下载路径如下: jdk:http://www ...
- 阿里云CentOs7上安装GitLab
一.安装 基本上可以根据官网的教程来安装:https://www.gitlab.com.cn/installation/#centos-7 只不过我们暂时没有邮件服务器,所以postfix没有安装. ...
- centos7 编译安装 redis-6.0.5
安装redis sudo yum install redis centos自带的redis才3.2 太旧了所以使用源码编译 需要先安装gcc新版才能编译 centos7 默认的 gcc 版本为:4.8 ...
- 腾讯云centos7.2安装宝塔面板和LAMP
1.安装好centos7.2系统后,登录centos系统输入如下命令: yum install -y wget && wget -O install.sh http://downloa ...
- 腾讯云centos7.2安装mysql5.7
一.查看是否安装mysql rpm -qa | grep mysql 什么都没显示,说明没有安装 二.进入到opt目录下,使用wget下载官方yum源的rpm包 cd /opt wget https: ...
随机推荐
- dotnet 6 在 System.Text.Json 使用 source generation 源代码生成提升 JSON 序列化性能
这是一个在 dotnet 6 早就引入的功能,此功能的使用方法能简单,提升的效果也很棒.使用的时候需要将 Json 序列化工具类换成 dotnet 运行时自带的 System.Text.Json 进行 ...
- 在 VisualStudio 给文件起一个带分号的文件名会怎样
小伙伴都知道在 Windows 下是支持文件名使用分号的,而写过 Roslyn 的小伙伴都知道,在 csproj 项目里面使用分号分割数组.那么在 VS 里面将一个文件名添加分号会如何?下面让咱写写看 ...
- HarmonyOS 鸿蒙隔离层设计
在软件开发中,底层库的更换或升级是常见的需求,这可能由性能提升.新功能需求或安全性考虑等因素驱动.为了降低迁移成本,良好的设计模式至关重要. 在版本迭代过程中,网络请求库可能会经历从A到B再到C的演进 ...
- C语言程序设计-笔记6-数组
C语言程序设计-笔记6-数组 例7-1 输出所有大于平均值的数.输入n个整数(1 ),计算这些数的平均值,再输出所有大于平均值的数. #include<stdio.h> int main ...
- 后端每日一题 2:DNS 解析过程
本文首发于公众号:腐烂的橘子 本文梗概: DNS 是什么,有什么作用 一条 DNS 记录是什么样的 DNS 域名解析原理 DNS 服务器如何抵御攻击 DNS 是什么,有什么作用 DNS(Domain ...
- Gin框架
目录 gin的参数获取 header参数 post Raw json 请求示例 gin的参数获取 package main import ( "fmt" "github. ...
- 欧几里得算法求最大公因数gcd原理证明
要证明欧几里得算法原理,首先需要证明下面两个定理(其中a,b都是整数): 1 如果c可以整除a,同时c也可以整除b,那么c就可以整除au + bv(u,v是任意的整数). 这个定理的证明很简单,$\f ...
- python教程1.1:环境安装+代码编辑器安装
1.环境安装 打开官⽹ https://www.python.org/downloads/windows/ 下载中 下载后执⾏,点击下⼀步安装就⾏,注意选择添加Python到当前⽤户环境变量 2.代码 ...
- postgresql性能优化1:min和max的性能
select max(datatime) as id from mytable ---全表检索,时间慢执行时间5分钟 select max(datatime) as id from mytable w ...
- 【题解】[NOIP2001 普及组] 装箱问题
[NOIP2001 普及组] 装箱问题 这是一道动态规划题. 那就先定义状态吧(这里用的是一维滚动数组). \(f[j]\) 代表当我有 \(j\) 这么多容量可以用时,能装的最大重量是多少. 好,状 ...