{"id":650,"date":"2019-08-22T02:29:07","date_gmt":"2019-08-21T17:29:07","guid":{"rendered":"https:\/\/took.jp\/?p=650"},"modified":"2020-06-15T15:39:56","modified_gmt":"2020-06-15T06:39:56","slug":"post-650","status":"publish","type":"post","link":"https:\/\/took.jp\/tech-blog\/post-650\/","title":{"rendered":"\u3042\u306a\u305f\u306e\u30b5\u30a4\u30c8\u306f\u5927\u4e08\u592b\uff1fRedis\u306e\u901f\u5ea6\u9762\u306e\u5411\u4e0a\u3092\u8003\u3048\u308b"},"content":{"rendered":"<h2>\u4f7f\u7528\u3059\u308b\u74b0\u5883<\/h2>\n<p>Redis 5.0.5<\/p>\n<p>\u8a00\u8a9e PHP 5.5.18<\/p>\n<p>phpredis\u30e2\u30b8\u30e5\u30fc\u30eb\u3092\u4f7f\u7528<\/p>\n<p>CentOS 7.6.1810<\/p>\n<p>VirtualBox 4.3.12<\/p>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<h2>\u8907\u6570\u307e\u3068\u3081\u3066\u767b\u9332(mset)\u3057\u305f\u307b\u3046\u304c\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u304c\u826f\u3044\u3089\u3057\u3044<\/h2>\n<p>\u5b9f\u969b\u306b\u691c\u8a3c\u3057\u3066\u307f\u308b\u3002<\/p>\n<p>\u307e\u305a\u306f\u30011\u4ef6\u305a\u3064\u306e\u30bb\u30c3\u30c8\u3067\u3059\u3002<\/p>\n<p>\u300c1\u4ef6\u305a\u3064\u306e\u30c7\u30fc\u30bf\u30bb\u30c3\u30c8\u30921\u4e07\u56de\u7e70\u308a\u8fd4\u3059\u300d\u3000\u3068\u3044\u3046\u52d5\u4f5c\u3092100\u56de\u7e70\u308a\u8fd4\u3057\u305d\u306e\u5e73\u5747\u30bf\u30a4\u30e0\u3092\u51fa\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<pre class=\"line-numbers\"><code class=\"language-php\">$times = 100;\r\nfor($count=1;$count&lt;=$times;$count++){\r\n    $time_start = microtime(true);\r\n            $host = '127.0.0.1';\r\n            $port = 6379;\r\n            $r = new Redis();\r\n            $r-&gt;connect($host, $port);\r\n            for($i=1;$i&lt;=10000;$i++){\r\n            $r-&gt;set('key'.$i,'value'.$i);\r\n            }\r\n    $sum += microtime(true) - $time_start;\r\n}\r\n$ave = $sum \/ $times;\r\necho $ave;<\/code><\/pre>\n<p>&nbsp;<\/p>\n<p>\u4eca\u5ea6\u306f\u3001\u8907\u6570\u306e\u30bb\u30c3\u30c8\u3067\u3059\u3002<\/p>\n<p>\u3053\u3053\u3067\u306f\u3001\u4f5c\u6210\u3057\u305fKV\u3092\u4e00\u5ea6\u914d\u5217\u306b\u307e\u3068\u3081\u3001<\/p>\n<p>\u305d\u308c\u3092\u307e\u3068\u3081\u3066Redis\u306b\u767b\u9332\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<pre class=\"line-numbers\"><code class=\"language-php\">$times = 100;\r\nfor($count=1;$count&lt;=$times;$count++){\r\n    $time_start = microtime(true);\r\n            $host = '127.0.0.1';\r\n            $port = 6379;\r\n            $r = new Redis();\r\n            $r-&gt;connect($host, $port);\r\n            $regist = '';\r\n            for($i=1;$i&lt;=10000;$i++){\r\n                $regist['key'.$i] = 'value'.$i;\r\n            }\r\n            $r-&gt;mSet($regist);\r\n        $sum += microtime(true) - $time_start;\r\n    }\r\n    $ave = $sum \/ $times;\r\n    echo $ave;<\/code><\/pre>\n<p>&nbsp;<\/p>\n<p>\u8a08\u6e2c\u7d50\u679c\u306f\u3001<\/p>\n<p><strong>1\u3064\u305a\u3064\u30bb\u30c3\u30c8<\/strong><\/p>\n<p>0.39885906934738\uff08\u79d2\uff09<\/p>\n<p><strong>\u8907\u6570\u540c\u6642\u306b\u30bb\u30c3\u30c8<\/strong><\/p>\n<p>0.029414405822754\uff08\u79d2\uff09<\/p>\n<p>&nbsp;<\/p>\n<p>\u7d50\u679c\u306f\u3001\u660e\u3089\u304b\u3067\u3059\u306d\u7b11<\/p>\n<p>\u8907\u6570\u540c\u6642\u30bb\u30c3\u30c8\u306e\u65b9\u304c10\u500d\u4ee5\u4e0a\u901f\u3044\u3067\u3059\u3002<\/p>\n<p>Redis\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u751f\u304b\u3059\u306b\u306f\u3001<strong>mset\u3092\u5229\u7528\u3059\u308b\u65b9\u304c\u65ad\u7136\u826f\u3044<\/strong>\u3088\u3046\u3067\u3059\u3002<\/p>\n<p>\u3057\u304b\u3057\u3001mset\u3092\u4f7f\u7528\u3059\u308b\u306b\u306f\u554f\u984c\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u305d\u308c\u306f\u3001\u6709\u52b9\u671f\u9650\u3067\u3059\u3002<\/p>\n<p>Redis\u306b\u767b\u9332\u3059\u308b\u30c7\u30fc\u30bf\u306f\u3042\u304f\u307e\u3067\u4e00\u6642\u7684\u306a\u3082\u306e\u3002<\/p>\n<p>\u57fa\u672c\u7684\u306b\u306f\u3001\u6709\u52b9\u671f\u9650\u3092\u8a2d\u5b9a\u3059\u308b\u5fc5\u8981\u304c\u3042\u308b\u304b\u3089\u3067\u3059\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>\u3082\u3057\u30011\u3064\u305a\u3064\u5024\u3092\u30bb\u30c3\u30c8\u3059\u308b\u306e\u306a\u3089\u3001\u6709\u52b9\u671f\u9650\u3092\u6c7a\u3081\u3066\u30bb\u30c3\u30c8\u3059\u308bsetex\u30b3\u30de\u30f3\u30c9\u3068\u3044\u3046\u3082\u306e\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u3057\u304b\u3057\u3001\u6709\u52b9\u671f\u9650\u3092\u6c7a\u3081\u3066\u3001\u8907\u6570\u306e\u30c7\u30fc\u30bf\u3092\u767b\u9332\u3059\u308b\u30b3\u30de\u30f3\u30c9\uff08msetex\uff09\u306f\u3042\u308a\u307e\u305b\u3093\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>\u305d\u306e\u305f\u3081\u3001\u6709\u52b9\u671f\u9650\u3092\u6c7a\u3081\u3066\u30bb\u30c3\u30c8\u3059\u308b\u5834\u5408\u306b\u306f\u3001<\/p>\n<p>\u30fbsetex\u30671\u3064\u305a\u3064\u30c7\u30fc\u30bf\u3092\u767b\u9332\u3059\u308b\u304b<\/p>\n<p>\u30fbmset\u3067\u307e\u3068\u3081\u3066\u767b\u9332\u3057\u305f\u5f8c\u3001expire\u3067\u6709\u52b9\u671f\u9650\u3092\u8a2d\u5b9a\u3059\u308b\u304b<\/p>\n<p>\u3068\u3044\u3046\u65b9\u6cd5\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>\u3057\u304b\u3057\u3001\u3053\u308c\u3067\u306f\u901f\u5ea6\u306f\u3042\u307e\u308a\u5909\u308f\u308a\u305d\u3046\u306b\u3042\u308a\u307e\u305b\u3093\u3002<\/p>\n<p>\u5ff5\u306e\u305f\u3081\u3001\u3069\u3061\u3089\u3067\u306e\u767b\u9332\u304c\u9ad8\u901f\u304b\u3001\u5148\u307b\u3069\u3068\u540c\u3058\u65b9\u6cd5\u3067\u8a08\u6e2c\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<p>\u6709\u52b9\u671f\u9650\u4ed8\u304d\u3067\u3001\u4e00\u3064\u305a\u3064\u767b\u9332\u3059\u308b\u3002<\/p>\n<pre class=\"line-numbers\"><code class=\"language-php\">$times = 100;\r\nfor($count=1;$count&lt;=$times;$count++){\r\n    $time_start = microtime(true);\r\n            $host = '127.0.0.1';\r\n            $port = 6379;\r\n            $r = new Redis();\r\n            $r-&gt;connect($host, $port);\r\n            for($i=1;$i&lt;=10000;$i++){\r\n             $r-&gt;setex('key'.$i,10,'value'.$i);\r\n            }\r\n    $sum += microtime(true) - $time_start;\r\n}\r\n$ave = $sum \/ $times;\r\necho $ave;<\/code><\/pre>\n<p>&nbsp;<\/p>\n<p>\u307e\u3068\u3081\u3066\u767b\u9332\u3057\u305f\u5f8c\u3001\u4e00\u3064\u305a\u3064\u6709\u52b9\u671f\u9650\u3092\u8a2d\u5b9a\u3059\u308b<\/p>\n<pre class=\"line-numbers\"><code class=\"language-php\">$times = 100;\r\nfor($count=1;$count&lt;=$times;$count++){\r\n    $time_start = microtime(true);\r\n            $host = '127.0.0.1';\r\n            $port = 6379;\r\n            $r = new Redis();\r\n            $r-&gt;connect($host, $port);\r\n            $regist = '';\r\n            for($i=1;$i&lt;=10000;$i++){\r\n                $regist['key'.$i] = 'value'.$i;\r\n            }\r\n            $r-&gt;mSet($regist);\r\n            for($i=1;$i&lt;=10000;$i++){\r\n                $r-&gt;expire('key'.$i, 10);\r\n            }\r\n        $sum += microtime(true) - $time_start;\r\n    }\r\n    $ave = $sum \/ $times;\r\n    echo $ave;<\/code><\/pre>\n<p>&nbsp;<\/p>\n<p>\u8a08\u6e2c\u7d50\u679c\u306f\u3001<\/p>\n<p><strong>\u6709\u52b9\u671f\u9650\u4ed8\u304d\u3067\u3001\u4e00\u3064\u305a\u3064\u767b\u9332\u3059\u308b<\/strong><\/p>\n<p>0.41783607721329\uff08\u79d2<\/p>\n<p><strong>\u307e\u3068\u3081\u3066\u767b\u9332\u3057\u305f\u5f8c\u3001\u4e00\u3064\u305a\u3064\u6709\u52b9\u671f\u9650\u3092\u8a2d\u5b9a\u3059\u308b<\/strong><br \/>\n0.43793610334396\uff08\u79d2\uff09<\/p>\n<p>\u3068\u3044\u3046\u7d50\u679c\u3067\u3057\u305f\u3002<\/p>\n<p>\u307b\u3068\u3093\u3069\u5909\u308f\u3089\u306a\u3044\u3067\u3059\u304c\u3001\u6709\u52b9\u671f\u9650\u4ed8\u304d\u3067\u4e00\u3064\u305a\u308b\u767b\u9332\u3057\u305f\u307b\u3046\u304c\u308f\u305a\u304b\u306b\u901f\u3044\u3088\u3046\u3067\u3059\u3002<\/p>\n<p>\u3046\u30fc\u3093\u3001\u3053\u308c\u3058\u3083\u3042\u3001\u305b\u3063\u304b\u304f\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u304c\u751f\u304b\u305b\u306a\u3044\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>\u7d50\u8ad6<\/h2>\n<p>\u307e\u3068\u3081\u3066\u30bb\u30c3\u30c8\u3057\u305f\u307b\u3046\u304c\u901f\u5ea6\u306f\u65ad\u7136\u65e9\u3044\u3051\u308c\u3069\u3001\u305d\u306e\u901f\u5ea6\u3092\u4fdd\u3063\u305f\u307e\u307e\u6709\u52b9\u671f\u9650\u3092\u8a2d\u5b9a\u3059\u308b\u65b9\u6cd5\u304c\u5b58\u5728\u3057\u306a\u3044\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>\u6539\u5584\u6848<\/h2>\n<p>1 . hSet\u3092\u4f7f\u7528\u3057\u3001\u8907\u6570\u30c7\u30fc\u30bf\u3092\u4e00\u3064\u306b\u307e\u3068\u3081\u3001\u305d\u308c\u3089\u5168\u3066\u3092\u540c\u3058\u6709\u52b9\u671f\u9650\u3067\u7ba1\u7406\u3059\u308b\u3002<\/p>\n<p>2 . lua script\u3092\u4f7f\u7528\u3057\u3001\u9ad8\u901f\u306b\u51e6\u7406\u3067\u304d\u308bmsetex\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u88c5\u3059\u308b\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>1\u306e\u65b9\u306f\u3001\u3084\u3063\u3066\u307f\u307e\u3057\u305f\u304c\u3001\u30c7\u30fc\u30bf\u306e\u6271\u3044\u304c\u96e3\u3057\u304f\u3001\u591a\u6b21\u5143\u914d\u5217\u3092\u4f7f\u7528\u3057\u3066\u3044\u305f\u3053\u3068\u3082\u3042\u308a\u3001<\/p>\n<p>\u5f8c\u304b\u3089\u30c7\u30fc\u30bf\u3092\u8ffd\u52a0\u3059\u308b\u5834\u5408\u306b\u306f\u3001\u30b5\u30d6\u30ad\u30fc\u3067\u5024\u3092\u4e0a\u66f8\u304d\u3057\u306a\u3044\u3088\u3046\u306b\u3001<\/p>\n<p>value\u306e\u307f\u3092JSON\u3067\u30a8\u30f3\u30b3\u30fc\u30c9\u3057\u3001\u767b\u9332\u3059\u308b\u3068\u3044\u3046\u52d5\u4f5c\u3092\u3057\u3066\u3044\u305f\u305f\u3081\u306b\u3001<\/p>\n<p>\u305d\u306e\u305f\u3081\u306b\u4f7f\u7528\u3057\u3066\u3044\u305fforeach\u306e\u51e6\u7406\u3067\u3001\u7d50\u679c\u3068\u3057\u3066\u51e6\u7406\u901f\u5ea6\u304c\u843d\u3061\u3066\u3057\u307e\u3063\u305f\u305f\u3081\u3001\u65ad\u5ff5\u3057\u307e\u3057\u305f\u3002<\/p>\n<p>\u305d\u3082\u305d\u3082\u3001\u8907\u96d1\u306a\u30c7\u30fc\u30bf\u3092Redis\u306b\u767b\u9332\u3057\u3088\u3046\u3063\u3066\u3044\u3046\u8003\u3048\u304c\u9593\u9055\u3063\u3066\u3044\u308b\u3068\u306f\u601d\u3046\u306e\u3060\u3051\u3069\u3002<\/p>\n<p>\u4eca\u5ea6\u6642\u9593\u304c\u3042\u308b\u3068\u304d\u306b\u30012\u306e\u30d1\u30bf\u30fc\u30f3\u3082\u8a66\u3057\u3066\u307f\u3088\u3046\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>&nbsp;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u4f7f\u7528\u3059\u308b\u74b0\u5883 Redis 5.0.5 \u8a00\u8a9e PHP 5.5.18 phpredis\u30e2\u30b8\u30e5\u30fc\u30eb\u3092\u4f7f\u7528 CentOS 7.6.1810 VirtualBox 4.3.12 &nbsp; &nbsp; \u8907\u6570\u307e\u3068\u3081\u3066\u767b\u9332(mset)\u3057\u305f\u307b\u3046\u304c\u30d1\u30d5\u30a9\u2026<\/p>\n","protected":false},"author":3,"featured_media":1948,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-650","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-1"],"_links":{"self":[{"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/posts\/650","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/comments?post=650"}],"version-history":[{"count":0,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/posts\/650\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/media\/1948"}],"wp:attachment":[{"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/media?parent=650"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/categories?post=650"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/tags?post=650"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}