zoukankan      html  css  js  c++  java
  • 天翼云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
  • 相关阅读:
    ZendFramwork配置
    JS控制页面前进、后退
    PHP乱码
    php 文件和表单内容一起上传
    mysqli常用命令
    图解SQL多表关联查询
    mysql默认字符集修改
    mysql控制台命令
    Nanami's Digital Board

  • 原文地址:https://www.cnblogs.com/lzfhope/p/15533314.html
Copyright © 2011-2022 走看看