2013-11-28 137 views
0

我在配置default.vcl問題VirtulHosts:清漆阻止登錄到phpMyAdmin的,總是告訴我的登錄頁面驗證之後。光油配置與phpMyAdmin和

Web服務器只能託管WordPress站點和phpMyAdmin,其中每個用戶都可以管理其數據庫。

http://phpMyAdmin.domain.com //for phpMyAdmin where users access their database 
http://www.site1.com 
http://www.site2.com 
http://www.site3.com //and so on 

我在哪裏出錯或缺少什麼?

這是我的實際default.vcl

backend default { 
    .host = "127.0.0.1"; 
    .port = "8000"; 
} 

acl purge { 
    # Web server with plugin which will issue PURGE requests 
    "127.0.0.1"; 
    "localhost"; 
} 

sub vcl_recv { 
    if (req.request == "PURGE") { 
     if (!client.ip ~ purge) { 
      error 405 "Not allowed."; 
     } 
     ban("req.url ~ ^" + req.url + "$ && req.http.host == " + req.http.host); 
    } 

    # Normalize content-encoding 
    if (req.http.Accept-Encoding) { 
     if (req.url ~ "\.(jpg|png|gif|gz|tgz|bz2|lzma|tbz)(\?.*|)$") { 
      remove req.http.Accept-Encoding; 
     } elsif (req.http.Accept-Encoding ~ "gzip") { 
      set req.http.Accept-Encoding = "gzip"; 
     } elsif (req.http.Accept-Encoding ~ "deflate") { 
      set req.http.Accept-Encoding = "deflate"; 
     } else { 
      remove req.http.Accept-Encoding; 
     } 
    } 

    # Remove cookies and query string for real static files 
    if (req.url ~ "^/[^?]+\.(gif|jpg|jpeg|swf|css|js|txt|flv|mp3|mp4|pdf|ico|png|gz|zip|lzma|bz2|tgz|tbz)(\?.*|)$") { 
     unset req.http.cookie; 
     set req.url = regsub(req.url, "\?.*$", ""); 
    } 

    # Don't cache backend 
    if (req.url ~ "wp-(login|admin|comments-post.php|cron.php)") { 
     return (pass); 
    } 

    if (req.url ~ "pmacloud") { 
     return(pass); 
    } 

    return (lookup); 
} 

sub vcl_fetch { 
    # Don't store backend 
    if (req.url ~ "wp-(login|admin|comments-post.php|cron.php)" || req.url ~ "preview=true" || req.url ~ "xmlrpc.php") { 
    return (hit_for_pass); 
    } 
    if ((!(req.url ~ "(wp-(login|admin|comments-post.php|cron.php)|login)")) || (req.request == "GET")) { 
    unset beresp.http.set-cookie; 
    set beresp.ttl = 4h; 
    } 
    if (req.url ~ "\.(gif|jpg|jpeg|swf|css|js|txt|flv|mp3|mp4|pdf|ico|png)(\?.*|)$") { 
    set beresp.ttl = 30d; 
    } #else { 
    # set beresp.do_esi = true; 
    #} 
} 
sub vcl_hit { 
     if (req.request == "PURGE") { 
       purge; 
       error 200 "Purged."; 
     } 
} 

sub vcl_miss { 
     if (req.request == "PURGE") { 
       purge; 
       error 200 "Purged."; 
     } 
} 

回答

0

,使訪問phpMyAdmin是在

子vcl_recv添加解決方案

if (req.http.Host == "phpMyAdmin.domain.com") { 
    return (pass); 
} 

子vcl_fetch

if (req.http.Host == "phpMyAdmin.domain.com") { 
    return (hit_for_pass); 
} 
0

在您的vcl_fetch中,您將丟棄set-cookie標頭,除了WordPress特定的URL以外的其他所有標頭。

Speficically:

# Don't store backend 
if (req.url ~ "wp-(login|admin|comments-post.php|cron.php)" || req.url ~ "preview=true" || req.url ~ "xmlrpc.php") { 
    return (hit_for_pass); 
} 
if ((!(req.url ~ "(wp-(login|admin|comments-post.php|cron.php)|login)")) || (req.request == "GET")) { 
    unset beresp.http.set-cookie; 
    set beresp.ttl = 4h; 
} 

您需要調整這兩個線以尋找特定的phpMyAdmin的網址或域名。

例如,如果phpMyAdmin是始終phpmyadmin.domain.com託管,你可以做到以下幾點:

# Don't store backend 
if ( 
    req.http.host ~ "phpmyadmin" 
    || req.url ~ "wp-(login|admin|comments-post.php|cron.php)" 
    || req.url ~ "preview=true" 
    || req.url ~ "xmlrpc.php" 
) { 
    return (hit_for_pass); 
} 
if (
    req.http.host ~ "phpmyadmin" 
    || (!(req.url ~ "(wp-(login|admin|comments-post.php|cron.php)|login)")) 
    || (req.request == "GET") 
) { 
    unset beresp.http.set-cookie; 
    set beresp.ttl = 4h; 
}