{"id":1415,"date":"2013-06-19T00:26:07","date_gmt":"2013-06-18T15:26:07","guid":{"rendered":"http:\/\/blog.xcir.net\/?p=1415"},"modified":"2013-06-19T00:31:49","modified_gmt":"2013-06-18T15:31:49","slug":"varnish3-0-4%e3%81%8c%e5%85%ac%e9%96%8b%e3%81%95%e3%82%8c%e3%81%be%e3%81%97%e3%81%9f","status":"publish","type":"post","link":"https:\/\/blog.xcir.net\/?p=1415","title":{"rendered":"Varnish3.0.4\u304c\u516c\u958b\u3055\u308c\u307e\u3057\u305f"},"content":{"rendered":"<p>Varnish3.0.4\u304c\u516c\u958b\u3055\u308c\u307e\u3057\u305f\u3002<br \/>\n\u4eca\u56de\u306f\u307b\u3068\u3093\u3069BugFix\u3067\u3059\u304c\u3001\u3044\u304f\u3064\u304b\u306e\u6a5f\u80fd\u6539\u5584\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<p><a href=\"https:\/\/www.varnish-cache.org\/releases\/varnish-cache-3.0.4\">\u516c\u5f0f\u30ea\u30ea\u30fc\u30b9\u30ce\u30fc\u30c8(3.0.4)<\/a><\/p>\n<h3>\u30d0\u30b0\u30d5\u30a3\u30c3\u30af\u30b9<\/h3>\n<p>\u25a0<b><a href=\"https:\/\/www.varnish-cache.org\/lists\/pipermail\/varnish-announce\/2013-June\/000684.html\">CVE-2013-4090<\/a> \u7279\u5b9a\u6761\u4ef6\u3067ACL\u3067\u60f3\u5b9a\u5916\u306e\u30de\u30c3\u30c1\u30fb\u30de\u30c3\u30c1\u6f0f\u308c\u304c\u8d77\u3053\u308b<\/b><br \/>\n<a href=\"https:\/\/www.varnish-cache.org\/trac\/ticket\/1312\">#1312<\/a><br \/>\n\u5bfe\u8c61\u306f3.0.3\u307e\u3067\u306e\u5168\u3066\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u3067\u3059<br \/>\n\u5f15\u3063\u304b\u304b\u308b\u6761\u4ef6\u306f\u4ee5\u4e0b\u3060\u3068\u601d\u3044\u307e\u3059<br \/>\n\u30fbCIDR\u5f62\u5f0f\u306e\u5b9a\u7fa9\u304c\u5b58\u5728(\/8,\/16,\/24\u3092\u9664\u304f)<br \/>\n\u30fb\u5358\u4e00\u306eIP\u30a2\u30c9\u30ec\u30b9\u3092\u6307\u5b9a\u3057\u3066\u3044\u308b<br \/>\n\u30fb\u305d\u306e\u5b9a\u7fa9\u7bc4\u56f2\u304c\u91cd\u8907\u3057\u3066\u3044\u308b<br \/>\n\u3053\u3093\u306a\u611f\u3058\u3067\u3059<br \/>\nVCL\u30b3\u30fc\u30c9<\/p>\n<pre class=\"brush: plain; \">\n\r\nacl foo {\r\n  &quot;127.0.0.2&quot;;\r\n  &quot;127.0.0.0&quot;\/19; \/\/(127.0.0.1 ~ 127.0.31.254\u3067127.0.0.2\u3092\u542b\u3080)\r\n}\r\n\n<\/pre>\n<p>C\u306b\u5909\u63db\u3057\u305f\u30b3\u30fc\u30c9(3.0.3)<\/p>\n<pre class=\"brush: c; \">\n\r\nstatic int\r\nmatch_acl_named_foo(const struct sess *sp, const void *p)\r\n{\r\n    const unsigned char *a;\r\n    unsigned short fam;\r\n\r\n    a = p;\r\n    VRT_memmove(&amp;amp;amp;fam, a + 0, sizeof fam);\r\n    if (fam == 2)\r\n        a += 4;\r\n    else if (fam == 10)\r\n        a += 8;\r\n    else {\r\n        VRT_acl_log(sp, &quot;NO_FAM foo&quot;);\r\n        return(0);\r\n    }\r\n\r\n    if (fam == 2) {\r\n     if (a[0] == 127) {\r\n      if (a[1] == 0) {\r\n       if (a[2] == 0) {\/\/\u3053\u3053\u3067\u672c\u6765\u30de\u30c3\u30c1\u3057\u306a\u304f\u3066\u306f\u884c\u3051\u306a\u3044127.0.1\uff5e127.0.31\u304c\u6392\u9664\u3055\u308c\u308b\r\n        if (a[3] == 2) {\r\n         VRT_acl_log(sp, &quot;MATCH foo &quot; &quot;127.0.0.2&quot;);\r\n         return (1);\r\n        }\r\n        VRT_acl_log(sp, &quot;MATCH foo &quot; &quot;127.0.0.0&quot; &quot;\/19&quot; );\r\n        return (1);\r\n       }\r\n      }\r\n     }\r\n    }\r\n    VRT_acl_log(sp, &quot;NO_MATCH foo&quot;);\r\n    return (0);\r\n}\r\n\n<\/pre>\n<p>C\u306b\u5909\u63db\u3057\u305f\u30b3\u30fc\u30c9(3.0.4)<\/p>\n<pre class=\"brush: c; \">\n\r\nstatic int\r\nmatch_acl_named_foo(const struct sess *sp, const void *p)\r\n{\r\n        const unsigned char *a;\r\n        unsigned short fam;\r\n\r\n        a = p;\r\n        VRT_memmove(&amp;amp;amp;fam, a + 0, sizeof fam);\r\n        if (fam == 2)\r\n                a += 4;\r\n        else if (fam == 10)\r\n                a += 8;\r\n        else {\r\n                VRT_acl_log(sp, &quot;NO_FAM foo&quot;);\r\n                return(0);\r\n        }\r\n\r\n        if (fam == 2) {\r\n         if (a[0] == 127) {\r\n          if (a[1] == 0) {\r\n           if (a[2] == 0) {\r\n            if (a[3] == 2) {\r\n             VRT_acl_log(sp, &quot;MATCH foo &quot; &quot;127.0.0.2&quot;);\r\n             return (1);\r\n            }\r\n           }\r\n           if ((a[2] &amp;amp;amp; 0xe0) == 0) {\r\n            VRT_acl_log(sp, &quot;MATCH foo &quot; &quot;127.0.0.0&quot; &quot;\/19&quot; );\r\n            return (1);\r\n           }\r\n          }\r\n         }\r\n        }\r\n        VRT_acl_log(sp, &quot;NO_MATCH foo&quot;);\r\n        return (0);\r\n}\r\n\n<\/pre>\n<p>\u5f71\u97ff\u3092\u53d7\u3051\u308b\u304b\u306e\u78ba\u8a8d\u306fVCL\u3092C\u3067\u51fa\u3057\u3066\u307f\u3066<br \/>\n\u8a72\u5f53\u306eACL\u30de\u30c3\u30c1\u95a2\u6570(match_acl_named_[ACL\u540d])\u3092\u898b\u305f\u307b\u3046\u304c\u826f\u3044\u304b\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>\u25a0<b>ESI\u5229\u7528\u6642\u306b\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u304c\u7121\u52b9\u306agzip\u3092\u9001\u4fe1\u3057\u305f\u5834\u5408\u306b\u304a\u3044\u3066\u30a8\u30e9\u30fc\u3092\u8d77\u3053\u3059\u53ef\u80fd\u6027\u304c\u3042\u3063\u305f<\/b><br \/>\n<a href=\"https:\/\/www.varnish-cache.org\/trac\/ticket\/1184\">#1184<\/a><\/p>\n<p>\u25a0<b>\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u540d\u304c\u9577\u3044\u3068Assert\u3067\u5b50\u30d7\u30ed\u30bb\u30b9\u304c\u843d\u3061\u308b<\/b><br \/>\n<a href=\"https:\/\/www.varnish-cache.org\/trac\/ticket\/1224\">#1224<\/a><\/p>\n<p>\u30d0\u30b0\u4fee\u6b63\u306f\u4ed6\u306b\u3082\u3042\u308a\u307e\u3059\u304c\u500b\u4eba\u7684\u306b\u6c17\u306b\u306a\u3063\u305f\u306e\u3092\u30d4\u30c3\u30af\u30a2\u30c3\u30d7\u3057\u307e\u3057\u305f<\/p>\n<h3>\u30c4\u30fc\u30eb\u6539\u5584<\/h3>\n<p>\u25a0<b>varnishncsa\u306e\u30d5\u30a9\u30fc\u30de\u30c3\u30c8\u3067%D,%T\u3092\u30b5\u30dd\u30fc\u30c8\u3057\u307e\u3057\u305f<\/b><br \/>\n\u25a0<b>varnishadm\u3067tab\u3092\u6253\u3064\u3068\u5019\u88dc\u304c\u51fa\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3057\u305f<\/b><\/p>\n<h3>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u7cfb<\/h3>\n<p>\u25a0<b>TCP_NODELAY\u3092\u6709\u52b9\u306b\u3057\u307e\u3057\u305f(Nagle\u3092Off\u306b\u3057\u305f)<\/b><br \/>\nchunk\u306e\u6642\u52b9\u3044\u3066\u304d\u305d\u3046\u3067\u3059\u3002<\/p>\n<h3>\u305d\u306e\u4ed6<\/h3>\n<p>\u25a0<b>\u8907\u6570\u306eHost\u30d8\u30c3\u30c0\u3092\u9001\u3089\u308c\u3066\u304d\u305f\u5834\u5408\u306f\u30a8\u30e9\u30fc\u3068\u3059\u308b<\/b><br \/>\n\u5373\u5207\u65ad\u3055\u308c\u307e\u3059\u306e\u3067vcl_recv\u306f\u547c\u3070\u308c\u307e\u305b\u3093(\u58ca\u308c\u305f\u30bb\u30c3\u30b7\u30e7\u30f3\u6271\u3044\u3067\u3059)<\/p>\n<pre class=\"brush: plain; \">\n\r\nTrying 127.0.0.1...\r\nConnected to localhost.\r\nEscape character is &#039;^]&#039;.\r\nGET \/test HTTP\/1.0\r\nHost: exmple.jp\r\nHost: exmple.jp\r\n\r\nConnection closed by foreign host.\r\n\r\nvarnishncsa\u30ed\u30b0\r\n\u2605\u30db\u30b9\u30c8\u30d8\u30c3\u30c01\u3064\r\n127.0.0.1 - - [18\/Jun\/2013:22:42:40 +0900] &quot;GET http:\/\/exmple.jp\/test HTTP\/1.0&quot; 404 287 &quot;-&quot; &quot;-&quot;\r\n\u2605\u30db\u30b9\u30c8\u30d8\u30c3\u30c0\u8907\u6570\r\n127.0.0.1 - - [18\/Jun\/2013:22:42:44 +0900] &quot;GET http:\/\/exmple.jp\/test HTTP\/1.0&quot;  - &quot;-&quot; &quot;-&quot;\r\n\n<\/pre>\n<p>\u25a0<b>\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u304c\u6539\u5584\u3055\u308c\u307e\u3057\u305f<\/b><br \/>\n\u25a0<b>ABI\u5909\u308f\u3063\u3066\u308b\u306e\u3067vmod\u306e\u30ea\u30b3\u30f3\u30d1\u30a4\u30eb\u304c\u5fc5\u8981<\/b><\/p>\n<p>#vug7\u306e\u8a18\u4e8b\u66f8\u304f\u524d\u306b\u3053\u3063\u3061\u306e\u8a18\u4e8b\u3092\u66f8\u304f\u3053\u3068\u306b\u306a\u308b\u3068\u306f\u30fb\u30fb\u30fb\uff08\u4e0b\u66f8\u304d\u306b\u306f\u3042\u308b\u3093\u3067\u3059\u304c\u306d\uff09<\/p>\n<div class='wp_social_bookmarking_light'>        <div class=\"wsbl_hatena\"><a href='\/\/b.hatena.ne.jp\/add?mode=confirm&url=https%3A%2F%2Fblog.xcir.net%2F%3Fp%3D1415&title=Varnish3.0.4%E3%81%8C%E5%85%AC%E9%96%8B%E3%81%95%E3%82%8C%E3%81%BE%E3%81%97%E3%81%9F' title='\u3053\u306e\u30a8\u30f3\u30c8\u30ea\u30fc\u3092\u306f\u3066\u306a\u30d6\u30c3\u30af\u30de\u30fc\u30af\u306b\u8ffd\u52a0' rel=nofollow class='wp_social_bookmarking_light_a' target=_blank><img src='https:\/\/blog.xcir.net\/wp-content\/plugins\/wp-social-bookmarking-light\/public\/images\/hatena.gif' alt='\u3053\u306e\u30a8\u30f3\u30c8\u30ea\u30fc\u3092\u306f\u3066\u306a\u30d6\u30c3\u30af\u30de\u30fc\u30af\u306b\u8ffd\u52a0' title='\u3053\u306e\u30a8\u30f3\u30c8\u30ea\u30fc\u3092\u306f\u3066\u306a\u30d6\u30c3\u30af\u30de\u30fc\u30af\u306b\u8ffd\u52a0' width='16' height='12' class='wp_social_bookmarking_light_img' \/><\/a><\/div>        <div class=\"wsbl_hatena_users\"><a href='\/\/b.hatena.ne.jp\/entry\/https:\/\/blog.xcir.net\/?p=1415' title='\u306f\u3066\u306a\u30d6\u30c3\u30af\u30de\u30fc\u30af - Varnish3.0.4\u304c\u516c\u958b\u3055\u308c\u307e\u3057\u305f' rel=nofollow class='wp_social_bookmarking_light_a' target=_blank><img src='\/\/b.hatena.ne.jp\/entry\/image\/https:\/\/blog.xcir.net\/?p=1415' alt='\u306f\u3066\u306a\u30d6\u30c3\u30af\u30de\u30fc\u30af - Varnish3.0.4\u304c\u516c\u958b\u3055\u308c\u307e\u3057\u305f' title='\u306f\u3066\u306a\u30d6\u30c3\u30af\u30de\u30fc\u30af - Varnish3.0.4\u304c\u516c\u958b\u3055\u308c\u307e\u3057\u305f'   class='wp_social_bookmarking_light_img' \/><\/a><\/div>        <div class=\"wsbl_facebook\"><a href='http:\/\/www.facebook.com\/share.php?u=https%3A%2F%2Fblog.xcir.net%2F%3Fp%3D1415&t=Varnish3.0.4%E3%81%8C%E5%85%AC%E9%96%8B%E3%81%95%E3%82%8C%E3%81%BE%E3%81%97%E3%81%9F' title='Facebook \u306b\u30b7\u30a7\u30a2' rel=nofollow class='wp_social_bookmarking_light_a' target=_blank><img src='https:\/\/blog.xcir.net\/wp-content\/plugins\/wp-social-bookmarking-light\/public\/images\/facebook.png' alt='Facebook \u306b\u30b7\u30a7\u30a2' title='Facebook \u306b\u30b7\u30a7\u30a2' width='16' height='16' class='wp_social_bookmarking_light_img' \/><\/a><\/div>        <div class=\"wsbl_linkedin\"><a href='\/\/www.linkedin.com\/shareArticle?mini=true&url=https%3A%2F%2Fblog.xcir.net%2F%3Fp%3D1415&title=Varnish3.0.4%E3%81%8C%E5%85%AC%E9%96%8B%E3%81%95%E3%82%8C%E3%81%BE%E3%81%97%E3%81%9F' title='LinkedIn \u306b\u30b7\u30a7\u30a2' rel=nofollow class='wp_social_bookmarking_light_a' target=_blank><img src='https:\/\/blog.xcir.net\/wp-content\/plugins\/wp-social-bookmarking-light\/public\/images\/linkedin.png' alt='LinkedIn \u306b\u30b7\u30a7\u30a2' title='LinkedIn \u306b\u30b7\u30a7\u30a2' width='16' height='16' class='wp_social_bookmarking_light_img' \/><\/a><\/div>        <div class=\"wsbl_twitter\"><a href=\"https:\/\/twitter.com\/share\" class=\"twitter-share-button\" data-url=\"https:\/\/blog.xcir.net\/?p=1415\" data-text=\"Varnish3.0.4\u304c\u516c\u958b\u3055\u308c\u307e\u3057\u305f\" data-lang=\"ja\">Tweet<\/a><\/div><\/div>\n<br class='wp_social_bookmarking_light_clear' \/>\n","protected":false},"excerpt":{"rendered":"<p>Varnish3.0.4\u304c\u516c\u958b\u3055\u308c\u307e\u3057\u305f\u3002 \u4eca\u56de\u306f\u307b\u3068\u3093\u3069BugFix\u3067\u3059\u304c\u3001\u3044\u304f\u3064\u304b\u306e\u6a5f\u80fd\u6539\u5584\u304c\u3042\u308a\u307e\u3059\u3002 \u516c\u5f0f\u30ea\u30ea\u30fc\u30b9\u30ce\u30fc\u30c8(3.0.4) \u30d0\u30b0\u30d5\u30a3\u30c3\u30af\u30b9 \u25a0CVE-2013-4090 \u7279\u5b9a\u6761\u4ef6\u3067ACL\u3067\u60f3\u5b9a\u5916\u306e\u30de\u30c3 <a href='https:\/\/blog.xcir.net\/?p=1415' class='excerpt-more'>[&#8230;]<\/a><\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[3],"tags":[5,47,32],"class_list":["post-1415","post","type-post","status-publish","format-standard","hentry","category-3","tag-varnish","tag-varnish3-0-4","tag-32","category-3-id","post-seq-1","post-parity-odd","meta-position-corners","fix"],"_links":{"self":[{"href":"https:\/\/blog.xcir.net\/index.php?rest_route=\/wp\/v2\/posts\/1415","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.xcir.net\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.xcir.net\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.xcir.net\/index.php?rest_route=\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.xcir.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1415"}],"version-history":[{"count":26,"href":"https:\/\/blog.xcir.net\/index.php?rest_route=\/wp\/v2\/posts\/1415\/revisions"}],"predecessor-version":[{"id":1442,"href":"https:\/\/blog.xcir.net\/index.php?rest_route=\/wp\/v2\/posts\/1415\/revisions\/1442"}],"wp:attachment":[{"href":"https:\/\/blog.xcir.net\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1415"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.xcir.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1415"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.xcir.net\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1415"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}