Redis服务管理

Redis服务实例应当遵守以下规范:

  • 实例的目录应当为 /srv/redis/{$端口}/

  • 实例的配置文件、回写文件、pid文件、日志文件应当都保存于自已的目录中

  • 实例应当使用systemctl统一管理,并开机自启动

  • 实例应当尽量设置回写规则,避免纯内存的使用方式,除非数据完全可丢失

  • Redis添加实例流程:

    到目标服务器的 /srv/redis 目录下创建新实例的目录:mkdir {$端口号}

  • 创建配置文件:cp /etc/redis.conf /srv/redis/{$端口号}

  • 修改配置文件,需要修改的配置项至少包括:port, pidfile, logfile, dir, save, maxmemory, maxmemory-policy, daemon(设置为1),还应当按情况考虑需要不需要修改 bind 配置项的值

  • 修改新实例目录和配置文件的权限:chown -R redis:redis /srv/redis/{$端口号}

  • 启动新实例:systemctl start redis@{$端口号}

  • 将新实例注册为服务:systemctl enable redis@{$端口号}

  • 如果是测试环境需要对内网开放端口,还需要将新实例的端口添加到防火墙规则中:firewall-cmd --add-port=6383/tcp --permanent

Redis多实例管理脚本:

使用systemctl管理多个redis实例需要使用redis@.service脚本,可复制192.168.0.212:/lib/systemd/system/redis@.service到目标服务器的相同位置。

文件内容

[Unit]
Description=Redis(Port %I)
After=network.target
Documentation=http://redis.io/documentation, man:redis-server(1)

[Service]
Type=forking
ExecStart=/usr/bin/redis-server /srv/redis/%I/redis.conf
PIDFile=/srv/redis/%I/redis.pid
TimeoutStopSec=0
Restart=always
User=redis
Group=redis

ExecStartPre=-/bin/run-parts --verbose /etc/redis/redis-server.pre-up.d
ExecStartPost=-/bin/run-parts --verbose /etc/redis/redis-server.post-up.d
ExecStop=-/bin/run-parts --verbose /etc/redis/redis-server.pre-down.d
ExecStop=/bin/kill -s TERM $MAINPID
ExecStopPost=-/bin/run-parts --verbose /etc/redis/redis-server.post-down.d

PrivateTmp=yes
PrivateDevices=yes
ProtectHome=yes
#ReadOnlyDirectories=/ #打开这一行开启会导致进程无法启动!
ReadWriteDirectories=-/srv/redis/%I
CapabilityBoundingSet=~CAP_SYS_PTRACE

# redis-server writes its own config file when in cluster mode so we allow
# writing there (NB. ProtectSystem=true over ProtectSystem=full)
ProtectSystem=true
#ReadWriteDirectories=-/etc/redis

[Install]
WantedBy=multi-user.target
#Alias=redis.service

centos7 Firewall防火墙开启80端口

centos7 默认是FirewallD 提供支持网络/防火墙区域(zone)定义网络链接以及接口安全等级的动态防火墙管理工具,利用FirewallD开启80端口操作如下:
开启80端口

firewall-cmd --zone=public --add-port=80/tcp --permanent
  • 1
  • 1

出现success表明添加成功

命令含义:

–zone #作用域

–add-port=80/tcp #添加端口,格式为:端口/通讯协议

–permanent #永久生效,没有此参数重启后失效

重启防火墙

systemctl restart firewalld.service
  • 1
  • 1

1、运行、停止、禁用firewalld

启动:# systemctl start firewalld

查看状态:# systemctl status firewalld 或者 firewall-cmd –state

停止:# systemctl disable firewalld

禁用:# systemctl stop firewalld

2、配置firewalld

查看版本:$ firewall-cmd –version

查看帮助:$ firewall-cmd –help

查看设置:

显示状态:$ firewall-cmd –state

查看区域信息: $ firewall-cmd –get-active-zones

查看指定接口所属区域:$ firewall-cmd –get-zone-of-interface=eth0

拒绝所有包:# firewall-cmd –panic-on

取消拒绝状态:# firewall-cmd –panic-off

查看是否拒绝:$ firewall-cmd –query-panic

更新防火墙规则:# firewall-cmd –reload

firewall-cmd –complete-reload

两者的区别就是第一个无需断开连接,就是firewalld特性之一动态添加规则,第二个需要断开连接,类似重启服务

将接口添加到区域,默认接口都在public

firewall-cmd –zone=public –add-interface=eth0

永久生效再加上 –permanent 然后reload防火墙

设置默认接口区域

firewall-cmd –set-default-zone=public

立即生效无需重启

打开端口(貌似这个才最常用)

查看所有打开的端口:

firewall-cmd –zone=dmz –list-ports

加入一个端口到区域:

firewall-cmd –zone=dmz –add-port=8080/tcp

若要永久生效方法同上

打开一个服务,类似于将端口可视化,服务需要在配置文件中添加,/etc/firewalld 目录下有services文件夹,这个不详细说了,详情参考文档

firewall-cmd –zone=work –add-service=smtp

移除服务

firewall-cmd –zone=work –remove-service=smtp
原文链接:http://www.zhaokeli.com/article/6321.html

附:systemctl命令如下
systemctl is-enabled iptables.service
systemctl is-enabled servicename.service #查询服务是否开机启动
systemctl enable *.service #开机运行服务
systemctl disable *.service #取消开机运行
systemctl start *.service #启动服务
systemctl stop *.service #停止服务
systemctl restart *.service #重启服务
systemctl reload *.service #重新加载服务配置文件
systemctl status *.service #查询服务运行状态
systemctl –failed #显示启动失败的服务

注:*代表某个服务的名字,如http的服务名为httpd

centos7 安装php7+mysql5.7+nginx+redis

1.先修改yum源  https://webtatic.com

rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
rpm -Uvh  http://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm

2.安装nginx 继续阅读“centos7 安装php7+mysql5.7+nginx+redis”