国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Nginx cache初體驗

SexySix / 2695人閱讀

摘要:粗線條一點根據(jù)的位置,一般會有瀏覽器,服務器,和應用服務器等。比如安全,解壓縮功能對所有請求都是通用的,這是可以搞定的,它一般不會終結業(yè)務類的處理,而是將他們交給后面的應用服務器。一致性,因為是冗余的,各個節(jié)點間的失效時間是不同步的。

前言

大家都知道cache對于網(wǎng)站性能的重要性,提高用戶響應速度,減輕后端壓力,節(jié)省資源等等。一談到cache其實是個很大話題,從前端瀏覽器到最終響應請求的服務器可能要經(jīng)過很多次跳轉(zhuǎn),每次跳轉(zhuǎn)經(jīng)過的服務器都有機會提供cache。單從成本上而言,越靠近用戶的cache越經(jīng)濟,實際情況中都需要根據(jù)當前線上的業(yè)務部署情況,開發(fā)成本收益比,可維護性等因素考慮采取在哪個地方cache,如何cache。粗線條一點根據(jù)cache的位置,一般會有瀏覽器,web服務器,CDN和應用服務器cache等。這里我結合最近自己完成的nginx服務器上的cache工作,談一下nginx提供了哪些實用的cache服務。


Nginx承擔反向代理服務器的工作,一般它處理的業(yè)務都是比較通用的處理,或者說一般不會處理很個性化的請求。比如安全,解壓縮功能對所有請求都是通用的,這是nginx可以搞定的,它一般不會終結業(yè)務類的處理,而是將他們交給后面的應用服務器。正是因為Nginx的這種特性,如果在nginx節(jié)點上做cache,一般cache的是整個http請求的response。自然cache的key也一般從http請求的url和參數(shù)得來。目前我接觸到兩種nginx cache方式:

本地文件系統(tǒng)cache (proxy_cache )

集中的內(nèi)存cache (srcache-nginx-module)

Proxy_cache

這是Nginx原生的ngx_http_proxy_module自帶的cache解決方案。http response的內(nèi)容以文件的形式存在了本地的文件系統(tǒng),同時開了一個share memory冗余存key值可以快速判斷是否cache命中。一般會這么部署。

如何配置nginx使能proxy cache,可以參考NGINX CONTENT CACHING 和 A Guide to Caching with NGINX
因為這個方案是本地文件系統(tǒng)存cache,可以比較容易理解具有以下缺點:

cache冗余,不同的nginx node間分別存cache。

cache一致性,因為是冗余的,各個節(jié)點間cache的失效時間是不同步的。

cache訪問速度慢,讀磁盤自然會慢一些。

cache效率低,因為各個node各有自己的cache不共享,即使某個node cache里存了某個請求,如果另外的nginx node來處理請求還是cache miss。

基于上面的問題,有更好的方案,比如agentzhang的srcache-nginx-module模塊。

srcache-nginx-module

這個模塊旨在構建一個cache中間層,cache的存儲介質(zhì)是集中的,一般使用memcached或者redis。這樣解決了冗余,也就解決了上面的各種問題,同時速度也快很多。對比著,它是這樣部署的。另外集中的cache存儲可以選擇redis或者memcached(memc-nginx-module提供API),memcached集群方案需要nginx配置配合解決。

順便感謝agentzhang將Lua引入到nginx。nginx出色的擴展性已經(jīng)很靈活了,lua-nginx-module將腳本語言處理文本的便捷性直接引入nginx,使得開發(fā)人員可以方便的在http request/response處理的各個階段都能嵌入定制的功能。比如我可以很方便的使用lua模塊在rewrite階段根據(jù)url和args生成定制的cache key--刨除一些參數(shù)(比如不影響response結果的那些參數(shù))。附上兩篇不錯的lua-nginx-module的資料:
lua-nginx-module
OpenResty最佳實踐
使用memc-nginx和srcache-nginx模塊構建高效透明的緩存機制

另外附上自己的nginx.conf以備后查。

#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
error_log  logs/error.log  info;

pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


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"";

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;
    #
    # cache server 1
    upstream memcache1 {
        server 127.0.0.1:11211;
        #keepalive 512 single;
    }
    # cache server 2
    #upstream memcache2 {
    #    server 127.0.0.1:11211;
    #}
    upstream_list memcache_servers memcache1;

    server {
        listen       8080;
        server_name  localhost;
        #memc-nginx-module
        location /memc {
            internal;
            memc_connect_timeout 100ms;
            memc_send_timeout 100ms;
            memc_read_timeout 100ms;
            set $memc_key $query_string;
            set $memc_exptime 30;
            set_hashed_upstream $backend memcache_servers  $memc_key;
            memc_pass $backend;
        }
        location /s {
            # key gerneration for cache
        set $args_for_key "";
            rewrite_by_lua "
               ngx.var.args_for_key = string.gsub(ngx.var.args, "queryid=%d+","queryid=0")
            ";
            #echo $args_for_key;
            srcache_fetch GET /memc $uri$args_for_key;
            srcache_store PUT /memc $uri$args_for_key;
            proxy_pass http://192.168.1.100:8000;
        }
        location / {
            root   /var/www;
            index  index.html index.htm index.php;
        }
        
        
    }
    server {
        listen 8081;
        location / {
            default_type text/html;
            content_by_lua "
                ngx.say("

hello, world

") "; } } }

文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/39291.html

相關文章

  • Nginx cache體驗

    摘要:粗線條一點根據(jù)的位置,一般會有瀏覽器,服務器,和應用服務器等。比如安全,解壓縮功能對所有請求都是通用的,這是可以搞定的,它一般不會終結業(yè)務類的處理,而是將他們交給后面的應用服務器。一致性,因為是冗余的,各個節(jié)點間的失效時間是不同步的。 前言 大家都知道cache對于網(wǎng)站性能的重要性,提高用戶響應速度,減輕后端壓力,節(jié)省資源等等。一談到cache其實是個很大話題,從前端瀏覽器到最終響應請...

    zombieda 評論0 收藏0
  • Terraform體驗(二) 第一個demo執(zhí)行

    摘要:初始化在終端中執(zhí)行。首次執(zhí)行初始化操作,會有較長的時間去獲取中定義的信息,在第一次初始化后沒有信息的變化,可以跳過初始化直接開始部署。執(zhí)行部署命令時,會將的列出來展示給用戶,并由用戶確定執(zhí)行。則刪除由創(chuàng)建的容器。通過Terraform在本地運行docker nginx前置條件: 1. 安裝好windows docker 2. 安裝好terraform安裝docker安裝windows doc...

    Tecode 評論0 收藏0
  • Service Workers (PWA 體驗

    摘要:是一個注冊在指定源和路徑下的事件驅(qū)動。可以提供有效有效的離線體驗,攔截網(wǎng)絡請求。出于安全原因,要求必須在下才能運行。返回一個對象,的結果是對象值對象組成的數(shù)組。當事件的處理程序執(zhí)行完畢后,可以認為安裝完成了。 在前端越來越重的這個時代,頁面加載速度成為了一個重要的指標。對于這個問題,業(yè)界也有一些解決方案。 瀏覽器緩存、協(xié)議緩存、強緩存 懶加載(首屏) CDN 多域名突破下載并發(fā)限制。...

    twohappy 評論0 收藏0
  • Service Workers (PWA 體驗

    摘要:是一個注冊在指定源和路徑下的事件驅(qū)動。可以提供有效有效的離線體驗,攔截網(wǎng)絡請求。出于安全原因,要求必須在下才能運行。返回一個對象,的結果是對象值對象組成的數(shù)組。當事件的處理程序執(zhí)行完畢后,可以認為安裝完成了。 在前端越來越重的這個時代,頁面加載速度成為了一個重要的指標。對于這個問題,業(yè)界也有一些解決方案。 瀏覽器緩存、協(xié)議緩存、強緩存 懶加載(首屏) CDN 多域名突破下載并發(fā)限制。...

    劉厚水 評論0 收藏0

發(fā)表評論

0條評論

SexySix

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<