### redis持久化
RDB(Redis Database),內存中的數據不定期通過快照拷貝到磁盤
AOF(Append Only File),對將數據操作的執行指令存儲下來,實現數據恢復,優先采用AOF方式進行數據恢復,數據完整度更高。
* 如果沒有持久化存儲需求可以關閉RDB和AOF功能,redis就成為了內存數據庫
### redis配置文件
#### 查看配置文件
~~~
redis-cli config get \*
127.0.0.1:6379> config get *
~~~
### 配置解讀
#### 基本配置
~~~
daemonize no #默認值no,redis并不以daemon方式運行;yes --> daemon在后臺運行
pidfile /path/to/file #默認值/var/run/redis.pid
bind ip1 ip2 ... #指定綁定的ip,可以有多個,空格分開
port 6379 #默認值6379
#unixsocket /tmp/redis.sock #指定socket
#unixsocketperm 755 #指定socket的權限
timeout 0 #當客戶端一直沒有請求redis服務,timeout用來設置redis服務端主動關閉這個連接的超時時間;0表示一直不超時
tcp-keepalive 0 #tcp連接保活策略;tcp連接或占用系統資源,為了減少占用,會定發送ACK請求檢測客戶端是否掛掉;0表示一直不檢測
databases 16 #設置數據庫數量,0~15,使用select n來選擇指定的庫,使用keys *查看庫中的所有鍵
~~~
#### 日志配置
~~~
loglevel notice #日志級別;warning --> notice --> verbose --> debug 日志級別-->詳細
logfile /path/to/file #指定日志路徑
syslog enabled #是否將redis日志記錄到系統日志中
syslog-ident redis #指定redis在系統日志中的標志
syslog-facility local0 #指定syslog設備,可以是user或者local0~local7
~~~
#### RDB持久化配置
~~~
save 900 1 #900s內至少有1次key變化則觸發一次持久化(內存中的數據快照到磁盤上)
save 300 10 #300s內至少有10次key改變則觸發一次持久化(內存中的數據快照到磁盤上)
save 60 10000 #60s內至少有10000次key改變則觸發一次持久化(內存中的數據快照到磁盤上)
save "" #關閉持久化
stop-writes-on-bgsave-error yes #默認yes,redis持久化寫入失敗后,redis馬上停止寫操作
rdbcompression yes #啟用壓縮
rdbchecksum yes #進行數據校驗
dir /path/to/file #快照文件的存儲路徑
dbfilename dump.rdb #快照文件的名稱
~~~
#### AOF持久化設置
~~~
appendonly yes #開啟AOF持久化
appendfilename appendonly.aof #AOF文件名
appendfsync everysec #fsync()調用模式;no,不調用fsync;always,每次寫都會調用fsync;
#everysec,每秒鐘調用一次fsync;
#no速度最快;always最安全。但是性能差一些;默認是everysec。
no-appendfsync-on-rewrite no #no可以避免當寫入量非常大時磁盤IO阻塞
auto-aof-rewrite-percentage 10 #達到多少百分比時觸發AOF重寫
auto-aof-rewrite-min-size 64mb #重寫條件 > 64mb
~~~
#### 安全相關配置
~~~
requirepass pass #指定密碼,登錄時使用-a指定密碼,如redis-cli -a hiyang
rename-command CONFIG hi.config #處于安全考慮,將config重命名為hi.config
127.0.0.1:6379> hi.config set timeout 100 #通過config設置timeout
127.0.0.1:6379> hi.config get timeout #查看timeout
rename-command CONFIG "" #禁用config
~~~
### 限制相關配置
~~~
maxclients 10000 #限制最大客戶連接數量
maxmemory <bytes> #限制最大內存使用空間
maxmemory-policy volatile-lru #指定內存清理規則,lru最近最少使用
maxmemory-samples 3 #使用lru算法時,檢查樣本的數量
2.2.7 redis慢日志設置
slowlog-log-slower-than 10000 #慢于10000ms則記錄進慢日志
slowlog-max-len 128 #慢日志長度,滿時會清除較舊的日志
~~~
- 目錄
- 離散的內容
- IO模型
- 網卡綁定
- ssh
- 硬件測試
- 硬件
- limits
- 網絡流量
- 硬盤IO
- 硬盤
- tmux
- 主機名和域名
- http_proxy
- iptables
- 內核參數
- 塊設備和字符設備
- 內存
- 虛擬內存并非交換分區
- 網絡延時
- 概念
- 多核壓縮
- linux基礎
- SSH協議
- 軟件管理
- yum
- 制作本地源 yum系列
- 制作本地源 apt系列
- apt
- 在 Linux 中移除從源代碼安裝的程序的一種簡單的方法
- 其他
- 源碼編譯和二進制安裝后更改配置
- DNS
- bind
- 守護進程
- 特殊權限
- limit.conf配置
- 網絡
- shell-ok
- 變量ok
- 數組ok
- 系統變量和環境變量
- 運算符和計算-ok
- 條件測試-ok
- 選擇-ok
- shell循環-ok
- 輸出echo和printf-ok
- 技巧-ok
- pre-web
- http協議
- web服務器
- Apache
- apache安裝
- yum安裝
- 二進制安裝
- 編譯安裝
- httpd命令
- 運行 監控apache
- apache配置文件
- 常用配置
- MPM多處理模塊
- 編譯模塊
- apache模塊
- apache核心模塊
- apache標準模塊
- apache第三方模塊
- 虛擬主機
- 1
- CGI-FastCGI-SSI
- 別名和重定向
- apache應用
- 301重定向
- apache防盜鏈
- http轉化為https
- 訪問時間段控制
- 控制訪問目錄
- 限制指定USER_AGENT
- 不同客戶端訪問不同網頁
- apache黑名單
- httpd之禁止解析php
- 不記錄css/js/img的訪問日志
- 瀏覽器端靜態緩存
- apache訪問日志自動切割
- order-require
- 壓縮傳輸
- httpd-ssl
- apache代理
- 正向代理
- 反向代理
- apache調優
- httpd壓力測試工具ab
- CGI測試
- php
- php原理
- httpd和php的結合方式
- php yum安裝之DSO模式
- php 編譯安裝之DSO模式
- php-fpm詳解
- php yum安裝之php-fpm模式
- php 編譯安裝之FastCGI模式
- php擴展之mysql
- php擴展之gd
- php擴展之pcntl
- php擴展之xcache
- php擴展之ZendGuardLoader
- phpMyAdmin
- wordpress
- 數據庫-mysql
- 數據庫原理
- mysql數據庫原理
- mysql源碼編譯安裝
- mysql二進制包安裝
- mysql命令行工具
- 更改密碼
- 數據庫授權grant
- mysql日志
- 命令
- 常用
- 小命令大作為
- awk 報告生成器
- 網絡命令
- 命令查找
- 壓縮歸檔命令
- 文件管理
- 文件管理命令
- 文件查看命令
- 目錄管理命令
- 用戶管理命令
- 用戶權限管理
- curl
- cheat
- chrony
- command
- crontab任務計劃
- cut
- date
- dd
- df
- echo
- find
- grep
- hash
- iftop
- kill pkill killall
- ls
- lsmod和modprobe
- lsof
- man
- mkpasswd
- mount
- mtr
- netstat
- nmap
- nc
- NTP
- passwd
- rm
- rdate
- pv
- sar系統活動情況報告
- sed文本處理命令
- setup
- screen
- shutdown
- sort 命令
- sudo
- tcpdump
- top
- uniq
- wget
- who
- xargs
- 監控
- zabbix郵件報警
- Redis
- redis安裝
- redis數據類型和操作方法
- redis持久化和配置
- redis主從配置
- php連接redis
- redis實現session共享
- 安裝測試
- redis設置密碼
- ELK日志分析系統
- elasticsearch
- logstash
- logstash插件
- filebeat日志收集
- kibana
- jenkins
- jenkins安裝與配置
- 案例1
- 案例2
- 案例3
- 代碼倉庫之svn
- svn服務端配置
- 常用操作
- svn備份
- LB集群
- LVS負載均衡集群
- ipvsadm使用方法
- LVS調度方法
- NAT原理
- NAT實踐
- DR原理
- DR實踐
- TUN原理
- LVS持久連接
- HA集群
- HPC集群
- 共享存儲
- ftp協議
- vsftpd
- NFS
- 網站架構發展
- 文件同步
- rsync基本用法
- rsync安裝和使用_拉取模式
- lsyncd安裝和用法
- zabbix
- zabbix服務端安裝
- zabbix客戶端安裝
- zabbix編譯安裝
- zabbix監控tomcat
- zabbix監控mysql
- gitlab
- supervisor
- nsq
- ruby
- nodejs
- consul
- mesos
- zookeeper
- rwho
- 對象存儲
- 工具
- rclone
- minio
- linux 性能調優
- CPU
- 第一部分 CPU
- 安全