设为首页 收藏本站
查看: 942|回复: 0

[经验分享] srcache_nginx+redis构建缓存系统

[复制链接]

尚未签到

发表于 2018-11-5 11:16:59 | 显示全部楼层 |阅读模式
  本文将使用redis来作为缓存载体。nginx的srcache_nginx模块指令参数解释参见《memc_nginx+srcache_nginx+memcached构建透明的动态页面缓存》。
1. nginx模块
  --add-module=../modules/ngx_devel_kit-0.2.18
  --add-module=../modules/set-misc-nginx-module-0.22rc8
  --add-module=../modules/srcache-nginx-module-0.22
  --add-module=../modules/redis-nginx-module-0.3.6
  --add-module=../modules/redis2-nginx-module-0.10
2. redis安装配置
  安装步骤参见:http://www.ttlsa.com/html/1646.html
  配置参数解释参见:http://www.ttlsa.com/html/1226.html
  配置实例:
  # vim redis.conf
  daemonize yes
  pidfile /var/run/redis-6379.pid
  port 6379
  bind 127.0.0.1
  timeout 0
  tcp-keepalive 0
  loglevel notice
  logfile stdout
  databases 16
  stop-writes-on-bgsave-error yes
  rdbcompression yes
  rdbchecksum yes
  dbfilename dump.rdb
  slave-serve-stale-data yes
  slave-read-only yes
  repl-disable-tcp-nodelay no
  slave-priority 100
  maxmemory 8096mb
  maxmemory-policy volatile-ttl
  appendonly no
  appendfsync everysec
  no-appendfsync-on-rewrite no
  auto-aof-rewrite-percentage 100
  auto-aof-rewrite-min-size 64mb
  lua-time-limit 5000
  slowlog-log-slower-than 10000
  slowlog-max-len 128
  hash-max-ziplist-entries 512
  hash-max-ziplist-value 64
  list-max-ziplist-entries 512
  list-max-ziplist-value 64
  set-max-intset-entries 512
  zset-max-ziplist-entries 128
  zset-max-ziplist-value 64
  activerehashing yes
  client-output-buffer-limit normal 0 0 0
  client-output-buffer-limit slave 256mb 64mb 60
  client-output-buffer-limit pubsub 32mb 8mb 60
  hz 10
  aof-rewrite-incremental-fsync yes
  由于只把redis当做缓存使用,因此没有启用持久化。
3. nginx配置
  # vim nginx.conf
  http
  {
  include       mime.types;
  default_type  application/octet-stream;
  log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
  '"$status" $body_bytes_sent "$http_referer" '
  '"$http_user_agent" "$http_x_forwarded_for" '
  '"$gzip_ratio" $request_time $bytes_sent $request_length';
  log_format srcache_log '$remote_addr - $remote_user [$time_local] "$request" '
  '"$status" $body_bytes_sent $request_time $bytes_sent $request_length '
  '[$upstream_response_time] [$srcache_fetch_status] [$srcache_store_status] [$srcache_expire]';
  set_real_ip_from 10.0.0.0/8;
  real_ip_header X-Forwarded-For;
  include          vhosts/test.ttlsa.com.conf;
  }
  # vim vhosts/test.ttlsa.com.conf
  upstream redis {
  server 127.0.0.1:6379;
  keepalive 512;
  }
  server
  {
  listen       80;
  server_name  test.ttlsa.com;
  index index.html index.htm index.php;
  root  /data/test.ttlsa.com/webroot;
  location ~ .*\.php {
  srcache_store_private on;
  srcache_methods GET;
  srcache_response_cache_control off;
  if ($uri ~ /ttlsa.com/pp.php$){
  set $key $request_uri;
  set_escape_uri $escaped_key $key;
  srcache_fetch GET /redis $key;
  srcache_default_expire 172800;
  srcache_store PUT /redis2 key=$escaped_key&exptime=$srcache_expire;
  #add_header X-Cached-From $srcache_fetch_status;
  #set_md5 $md5key $key;
  #add_header X-md5-key $md5key;
  #add_header X-Cached-Store $srcache_store_status;
  #add_header X-Key $key;
  #add_header X-Query_String $query_string;
  #add_header X-expire $srcache_expire;
  access_log /data/httplogs/test.ttlsa.com-photo-access.log srcache_log;
  }
  include fastcgi_params;
  fastcgi_pass  127.0.0.1:9000;
  fastcgi_index index.php;
  fastcgi_connect_timeout 60;
  fastcgi_send_timeout 180;
  fastcgi_read_timeout 180;
  fastcgi_buffer_size 128k;
  fastcgi_buffers 4 256k;
  fastcgi_busy_buffers_size 256k;
  fastcgi_temp_file_write_size 256k;
  fastcgi_intercept_errors on;
  fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
  fastcgi_split_path_info ^(.+\.php)(.*)$;
  fastcgi_param PATH_INFO $fastcgi_path_info;
  }
  location = /redis {
  internal;
  set_md5 $redis_key $args;
  redis_pass redis;
  }
  location = /redis2 {
  internal;
  set_unescape_uri $exptime $arg_exptime;
  set_unescape_uri $key $arg_key;
  set_md5 $key;
  redis2_query set $key $echo_request_body;
  redis2_query expire $key $exptime;
  redis2_pass redis;
  }
  error_log  /data/httplogs/test.ttlsa.com-error.log;
  access_log  /data/httplogs/test.ttlsa.com-aceess.log main;
  }
4. 测试
  没有做缓存状态:

  有做缓存状态:

5. 响应头状态
  第一次请求:

  再次请求:

6. 查看redis是否缓存以及过期时间



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-631047-1-1.html 上篇帖子: redis数据导出,报错Could not connect to Redis at ip:port: Cannot assign requested addre 下篇帖子: CentOS6.5下redis安装部署配置指南、常用命令、主从同步集群、redis-php学习资料整合详解
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表