{"id":34715,"date":"2023-02-10T02:04:08","date_gmt":"2023-12-08T20:30:26","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/"},"modified":"2024-04-29T13:56:44","modified_gmt":"2024-04-29T05:56:44","slug":"%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/","title":{"rendered":"\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\u8c03\u4f18\uff1f"},"content":{"rendered":"<h1>\u57fa\u7840\u77e5\u8bc6\u7f16 &#8211; Paraphrase in Chinese:<\/h1>\n<p>\u5165\u95e8\u77e5\u8bc6\u7f16\u8f91<\/p>\n<p>\u5728Web\u7cfb\u7edf\u5f00\u53d1\u4e2d\uff0c\u7406\u89e3\u548c\u8bbe\u8ba1\u7f13\u5b58\u662f\u975e\u5e38\u91cd\u8981\u7684\u3002<\/p>\n<p>\u7f13\u5b58\u53ef\u4ee5\u51cf\u8f7b\u670d\u52a1\u5668\u7684\u8d1f\u62c5\u5e76\u5927\u5e45\u7f29\u77ed\u54cd\u5e94\u65f6\u95f4\u3002\u901a\u8fc7\u6682\u65f6\u5b58\u50a8\u7ecf\u5e38\u8bbf\u95ee\u7684\u6570\u636e\u548c\u8ba1\u7b97\u7ed3\u679c\uff0c\u907f\u514d\u91cd\u65b0\u8ba1\u7b97\u6216\u91cd\u65b0\u83b7\u53d6\u76f8\u540c\u7684\u8bf7\u6c42\u3002<\/p>\n<p>\u5728\u524d\u534a\u7684&#8221;\u57fa\u790e\u77e5\u8b58\u7de8&#8221;\u4e2d\uff0c\u4e3b\u8981\u603b\u7ed3\u4e86\u7f13\u5b58\u7b56\u7565\u548cAWS\u63d0\u4f9b\u7684\u5185\u5b58\u7f13\u5b58\u670d\u52a1\uff0c\u5e76\u5728\u6587\u7ae0\u540e\u534a\u90e8\u5206\u7684&#8221;\u5b9e\u8df5\u6307\u5357&#8221;\u4e2d\uff0c\u6211\u4eec\u5c06\u5b9e\u8df5\u4f7f\u7528&#8221;MemCached&#8221;\u8fdb\u884c\u67e5\u8be2\u4f18\u5316\u3002<\/p>\n<h2>\u7f13\u5b58\u7b56\u7565\u7c7b\u578b<\/h2>\n<p>\u7f13\u5b58\u7b56\u7565\u9009\u62e9\u975e\u5e38\u91cd\u8981\uff0c\u5fc5\u987b\u6839\u636e\u7cfb\u7edf\u7684\u76ee\u6807\u3001\u67b6\u6784\u548c\u8d1f\u8f7d\u7279\u6027\u8fdb\u884c\u9009\u62e9\u3002\u4e3b\u8981\u901a\u8fc7\u201c\u672c\u5730\u6216\u8fdc\u7a0b\u201d\u3001\u201c\u8bfb\u53d6\u6216\u5199\u5165\u201d\u3001\u201c\u5185\u8054\u6216\u65c1\u8def\u201d\u8fd9\u4e09\u4e2a\u7ef4\u5ea6\u6765\u5206\u7c7b\u7b56\u7565\u3002\u5728\u6bcf\u4e2a\u7ef4\u5ea6\u4e0a\u7684\u9009\u62e9\u90fd\u4f1a\u5bf9\u6027\u80fd\u548c\u4e00\u81f4\u6027\u4ea7\u751f\u91cd\u5927\u5f71\u54cd\u3002<\/p>\n<h3>\u672c\u5730\u6216\u8fdc\u7a0b<\/h3>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d1ed437434c4406c1782b\/7-1.png\" alt=\"\u540d\u79f0\u672a\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb-\u30d8\u309a\u30fc\u30b7\u30991\u306e\u30b3\u30d2\u309a\u30fc (1).png\" \/><\/div>\n<h3>\u9886\u5bfc\u6216\u8005\u4e3b\u5e2d<\/h3>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d1ed437434c4406c1782b\/9-1.png\" alt=\"\u540d\u79f0\u672a\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb-\u30e9\u30a4\u30c8.png\" \/><\/div>\n<h3>\u5185\u5d4c\u6216\u4fa7\u8fb9<\/h3>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d1ed437434c4406c1782b\/11-1.png\" alt=\"\u540d\u79f0\u672a\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb-\u30a2\u30b5\u30a4\u30c8\u3099.png\" \/><\/div>\n<p>&nbsp;<\/p>\n<h3>MemCached<br \/>\n\u5185\u5efa\u7f13\u5b58<\/h3>\n<p>MemCache\u662fAWS Elastic Cache\u652f\u6301\u7684\u7f13\u5b58\u5f15\u64ce\u4e4b\u4e00\uff0c\u4f5c\u4e3a\u7b80\u5355\u7684\u952e\u503c\u5b58\u50a8\u8fd0\u884c\u3002\u5b83\u8fd8\u652f\u6301\u591a\u7ebf\u7a0b\uff0c\u53ef\u4ee5\u5145\u5206\u5229\u7528\u591a\u6838\u5904\u7406\u5668\u7684\u80fd\u529b\u3002\u5b83\u9002\u7528\u4e8e\u5177\u6709\u7b80\u5355\u6570\u636e\u7ed3\u6784\u6216\u5c0f\u89c4\u6a21\u6570\u636e\u96c6\uff0c\u5177\u6709\u975e\u5e38\u9ad8\u7684\u5185\u5b58\u6548\u7387\u3002<\/p>\n<p>&nbsp;<\/p>\n<h3>Redis\u662f\u4e00\u79cd\u5f00\u6e90\u7684\u5185\u5b58\u6570\u636e\u7ed3\u6784\u5b58\u50a8\u7cfb\u7edf\u3002<\/h3>\n<p>Redis\u662fAWS Elastic Cache\u7684\u652f\u6301\u5f15\u64ce\uff0c\u652f\u6301\u66f4\u9ad8\u7ea7\u7684\u6570\u636e\u7ed3\u6784\u548c\u4e8b\u52a1\uff0c\u5e76\u4e14\u8fd8\u652f\u6301\u4e30\u5bcc\u7684\u6570\u636e\u7c7b\u578b\uff0c\u5982\u5217\u8868\/\u54c8\u5e0c\/\u96c6\u5408\/\u6709\u5e8f\u96c6\u5408\u7b49\u3002\u7136\u800c\uff0c\u7531\u4e8eRedis\u91c7\u7528\u5355\u7ebf\u7a0b\u8bbe\u8ba1\uff0c\u6240\u4ee5\u6709\u4e00\u6b21\u53ea\u80fd\u6267\u884c\u4e00\u4e2a\u547d\u4ee4\u7684\u9650\u5236\u3002\u9002\u7528\u4e8e\u5177\u6709\u5927\u89c4\u6a21\u590d\u6742\u6570\u636e\u7ed3\u6784\u6216\u5bf9\u6027\u80fd\u8981\u6c42\u8f83\u9ad8\u7684\u5e94\u7528\u3002<\/p>\n<p>&nbsp;<\/p>\n<h1>\u5b9e\u8df5\u5b66\u4e60\u7bc7<\/h1>\n<p>\u6211\u5011\u63a5\u4e0b\u4f86\u5c07\u4f7f\u7528\u5be6\u969b\u7684\u4ee3\u78bc\u9032\u884c\u4f7f\u7528\u5feb\u53d6\u9032\u884c\u6027\u80fd\u8abf\u6574\u7684\u6f14\u793a\u3002<\/p>\n<p>\u672c\u6587\u5c06\u4ecb\u7ecd\u5982\u4f55\u5728\u672c\u5730\u73af\u5883\u4e2d\u4f7f\u7528Docker\u8fdb\u884c\u64cd\u4f5c\u9a8c\u8bc1\u3002\u6211\u4eec\u5c06\u4f7f\u7528memcached\u4f5c\u4e3a\u7f13\u5b58\u670d\u52a1\u5668\u3002<\/p>\n<p>\u53e6\u5916\uff0c\u8fd9\u6b21\u5047\u8bbe\u4f7f\u7528\u4e86\u5f15\u5bfc\u548c\u65c1\u89c2\u7b56\u7565\u7684\u60c5\u51b5\u3002\u4e5f\u5c31\u662f\u8bf4\uff0c\u5728\u7b2c\u4e00\u6b21\u9605\u8bfb\u65f6\uff08\u5982\u679c\u7f13\u5b58\u672a\u547d\u4e2d\uff09\uff0c\u4ece\u6570\u636e\u5e93\u83b7\u53d6\u6570\u636e\uff0c\u800c\u5728\u4e4b\u540e\u7684\u8bf7\u6c42\u4e2d\uff0c\u4ece\u7f13\u5b58\u83b7\u53d6\u3002\u56fe\u793a\u5982\u4e0b\u6240\u793a\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d1ed437434c4406c1782b\/23-0.png\" alt=\"\u540d\u79f0\u672a\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb-\u30ea\u30fc\u30c8\u3099\u30fb\u30a2\u30b5\u30a4\u30c8\u3099.png\" \/><\/div>\n<div>\n<div class=\"post-table\">\u9805\u76ee\u5185\u5bb9PCM1 MacBook Pro\uff0814\u30a4\u30f3\u30c1\u30012021\uff09OSMacOS MontereyIDE\uff08\u7d71\u5408\u958b\u767a\u74b0\u5883\uff09GoLand<\/div>\n<\/div>\n<h2>\u6837\u4f8bAPI\u6982\u89c8<\/h2>\n<div>\u5728\u8fd9\u4e2a\u6559\u7a0b\u4e2d\uff0c\u6211\u4eec\u5047\u8bbe\u4e00\u4e2a\u4f7f\u7528\u7f13\u5b58\u6765\u6539\u5584\u6027\u80fd\u7684\u6848\u4f8b\uff0c\u8be5\u6848\u4f8b\u6d89\u53ca\u53d1\u51fa\u975e\u5e38\u6162\u7684\u67e5\u8be2API\u3002<\/div>\n<p>\u5728\u8fd9\u91cc\uff0c\u6211\u4eec\u5c06\u4f7f\u7528\u7528Go\u7f16\u5199\u7684API\uff08\u4f7f\u7528Gin\u6846\u67b6\uff09\u4f5c\u4e3a\u6837\u4f8b\u3002\u540c\u65f6\uff0c\u8fd9\u4e2a\u5e94\u7528\u7a0b\u5e8f\u63d0\u4f9b\u4e86\u4e24\u4e2a\u7aef\u70b9\u3002<\/p>\n<p>\uff081\uff09\u6162\u67e5\u8be2API\uff08\u8def\u5f84\uff1a\/db\/1\uff09<\/p>\n<p>\u7b2c\u4e00\u4e2a\u9009\u9879\u662f\uff0c\u5f53\u8bf7\u6c42\u53d1\u751f\u65f6\uff0c\u5411\u6570\u636e\u5e93\uff08MySQL\uff09\u53d1\u9001\u67e5\u8be2\u3002\u7136\u800c\uff0c\u6839\u636e\u4ee5\u4e0b\u67e5\u8be2\u8bed\u53e5\uff1aSELECT id, value, SLEEP(10) FROM customers WHERE id = ?\uff0c\u8fd9\u4e2a\u67e5\u8be2\u975e\u5e38\u7f13\u6162\uff0c\u9700\u8981\u7b49\u5f8510\u79d2\u949f\u624d\u80fd\u5b8c\u6210\u3002<\/p>\n<details>\u4ee5\u4e0b\u662f\u539f\u59cb\u4ee3\u7801\u7684\u4e2d\u6587\u7ffb\u8bd1\uff1amain.go<br \/>\n\/\/ \u4f8b\u5982\uff1ahttp:\/\/localhost:8080\/db\/1<\/p>\n<p>r.GET(&#8220;\/db\/:id&#8221;, func(c *gin.Context) {<br \/>\nparamId := c.Param(&#8220;id&#8221;)<br \/>\nvar result Customer<br \/>\n\/\/ \u6267\u884c\u4e00\u4e2a\u5ef6\u8fdf10\u79d2\u7684\u67e5\u8be2<br \/>\nerr := db.QueryRow(&#8220;SELECT id, value, SLEEP(10) FROM customers WHERE id = ?&#8221;, paramId).Scan(&amp;result.ID, &amp;result.Value, &amp;result.SleepResult)<br \/>\nif err != nil {<br \/>\nc.JSON(http.StatusInternalServerError, gin.H{&#8220;error&#8221;: err.Error()})<br \/>\nreturn<br \/>\n}<\/p>\n<p>c.JSON(http.StatusOK, result)<br \/>\n})<\/p>\n<\/details>\n<p>\uff082\uff09\u5229\u7528\u7f13\u5b58\u7684API\uff08\u8def\u5f84\uff1a\/cache\/1\uff09<\/p>\n<p>\u7b2c\u4e8c\u4e2a\u9009\u9879\u662f\uff0c\u5f53\u6709\u8bf7\u6c42\u65f6\uff0c\u9996\u5148\u68c0\u67e5\u7f13\u5b58\u670d\u52a1\u5668\u4e2d\u7684\u503c\uff0c\u5982\u679c\u4e0d\u5b58\u5728\uff0c\u5219\u4ece\u6570\u636e\u5e93\u4e2d\u83b7\u53d6\u503c\u5e76\u4fdd\u5b58\u5230\u7f13\u5b58\u670d\u52a1\u5668\u4e0a\uff0c\u7136\u540e\u8fd4\u56de\u7ed3\u679c\u3002\u5bf9\u4e8e\u4e4b\u540e\u7684\u7b2c\u4e8c\u6b21\u8bf7\u6c42\uff0c\u5c06\u4ece\u7f13\u5b58\u670d\u52a1\u5668\u4e2d\u83b7\u53d6\u503c\u3002<\/p>\n<details>\u8be6\u7ec6\u4ee3\u7801\u8bf7\u70b9\u51fb\u8fd9\u91cc(main.go)main.go<br \/>\n\/\/ \u4f8b\u5982\uff1ahttp:\/\/localhost:8080\/cache\/1<\/p>\n<p>r.GET(&#8220;\/cache\/:id&#8221;, func(c *gin.Context) {<br \/>\nparamId := c.Param(&#8220;id&#8221;)<br \/>\n\/\/ \u4ece\u7f13\u5b58\u4e2d\u83b7\u53d6<br \/>\nitem, err := mc.Get(paramId)<br \/>\n\/\/ \u5982\u679c\u7f13\u5b58\u4e0d\u5b58\u5728<br \/>\nif err == memcache.ErrCacheMiss {<br \/>\nvar result Customer<br \/>\n\/\/ \u6267\u884c\u5ef6\u8fdf10\u79d2\u7684\u67e5\u8be2<br \/>\nerr := db.QueryRow(&#8220;SELECT id, value, SLEEP(10) FROM customers WHERE id = ?&#8221;, paramId).Scan(&amp;result.ID, &amp;result.Value, &amp;result.SleepResult)<br \/>\nif err != nil {<br \/>\nc.JSON(http.StatusInternalServerError, gin.H{&#8220;error&#8221;: err.Error()})<br \/>\nreturn<br \/>\n}<br \/>\n\/\/ \u6ce8\u518c\u7f13\u5b58<br \/>\nresultBytes, err := json.Marshal(result)<br \/>\nif err != nil {<br \/>\nc.JSON(http.StatusInternalServerError, gin.H{&#8220;error&#8221;: err.Error()})<br \/>\nreturn<br \/>\n}<br \/>\nitem = &amp;memcache.Item{<br \/>\nKey: paramId,<br \/>\nValue: resultBytes,<br \/>\n}<br \/>\nif err := mc.Set(item); err != nil {<br \/>\nc.JSON(http.StatusInternalServerError, gin.H{&#8220;error&#8221;: err.Error()})<br \/>\nreturn<br \/>\n}<br \/>\nc.JSON(http.StatusOK, result)<br \/>\nreturn<br \/>\n}<\/p>\n<p>if err != nil {<br \/>\nc.JSON(http.StatusInternalServerError, gin.H{&#8220;error&#8221;: err.Error()})<br \/>\nreturn<br \/>\n}<\/p>\n<p>\/\/ \u5c06\u7f13\u5b58\u7ed3\u679c\u5904\u7406\u4e3a\u54cd\u5e94\u683c\u5f0f<br \/>\nresult := Customer{}<br \/>\nif err = json.Unmarshal(item.Value, &amp;result); err != nil {<br \/>\nc.JSON(http.StatusInternalServerError, gin.H{&#8220;error&#8221;: err.Error()})<br \/>\nreturn<br \/>\n}<br \/>\nc.JSON(http.StatusOK, result)<br \/>\n})<\/p>\n<\/details>\n<h2>\u672c\u5730\u7248<\/h2>\n<p>\u4ee5\u4e0b\u662f\u57fa\u7840\u8bbe\u65bd\u6784\u6210\u56fe\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d1ed437434c4406c1782b\/36-0.png\" alt=\"\u30ed\u30fc\u30ab\u30eb\u74b0\u5883.png\" \/><\/div>\n<p>\u8ba9\u6211\u4eec\u4ece\u672c\u5730\u673a\u5668\u4e0a\u5b9e\u9645\u4f53\u9a8c\u4f7f\u7528\u7f13\u5b58\u8fdb\u884c\u67e5\u8be2\u4f18\u5316\u3002\u9996\u5148\uff0c\u8bf7\u514b\u9686\u4ee5\u4e0b\u5b58\u50a8\u5e93\u3002\u7136\u540e\uff0c\u8bf7\u53c2\u8003README.md\u6765\u8fdb\u884c\u73af\u5883\u8bbe\u7f6e\u3002<\/p>\n<p>&nbsp;<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u30af\u30ed\u30fc\u30f3<\/span>\r\n<span class=\"nv\">$ <\/span>git clone git@github.com:WebEngrChild\/go-rds-memcached.git\r\n\r\n<span class=\"c\"># Docker\u8d77\u52d5<\/span>\r\n<span class=\"nv\">$ <\/span>docker compose up <span class=\"nt\">-d<\/span>\r\n\r\n<span class=\"c\"># API\u8d77\u52d5<\/span>\r\n<span class=\"nv\">$ <\/span>docker compose <span class=\"nb\">exec <\/span>app go run main.go\r\n<\/code><\/pre>\n<h3>\u6d4b\u91cf\u6162\u67e5\u8be2API<\/h3>\n<p>\u5373\u4f7f\u5728\u4f7f\u7528\u7f13\u5b58\u670d\u52a1\u5668\u8fdb\u884c\u6027\u80fd\u8c03\u4f18\u65f6\uff0c&#8221;\u73b0\u72b6\u5206\u6790&#8221;\u4e5f\u662f\u5fc5\u4e0d\u53ef\u5c11\u7684\u3002\u901a\u8fc7\u5b9a\u91cf\u6d4b\u91cf\u5728\u5b9e\u65bd\u524d\u540e\u53ef\u4ee5\u5b9e\u73b0\u54ea\u4e9b\u6539\u8fdb\uff0c\u53ef\u4ee5\u6210\u4e3a\u4e00\u4e2a\u5f88\u597d\u7684\u8861\u91cf\u653f\u7b56\u6210\u8d25\u7684\u6807\u51c6\u6765\u8fdb\u884c\u56de\u987e\u3002<\/p>\n<p>\u90a3\u4e48\uff0c\u6211\u4eec\u5c1d\u8bd5\u5411\u4e0a\u8ff0\u7684\u7b2c\u4e00\u4e2a\u6162\u67e5\u8be2API\u53d1\u9001\u8bf7\u6c42\u3002\u5728\u6536\u5230\u54cd\u5e94\u4e4b\u524d\uff0c\u9884\u8ba1\u4f1a\u6709\u5927\u7ea610\u79d2\u949f\u7684\u5ef6\u8fdf\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"o\">&gt;<\/span> which ab\r\n\/usr\/sbin\/ab\r\n\r\n<span class=\"o\">&gt;<\/span> curl http:\/\/localhost:8080\/db\/1\r\n<span class=\"o\">{<\/span><span class=\"s2\">\"id\"<\/span>:1,<span class=\"s2\">\"value\"<\/span>:<span class=\"s2\">\"Initial Value\"<\/span>,<span class=\"s2\">\"sleepResult\"<\/span>:0<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<p>\u4f7f\u7528Apache Bench\u8fdb\u884c\u8d1f\u8f7d\u6d4b\u8bd5<\/p>\n<p>\u4e0b\u4e00\u6b65\uff0c\u6211\u4eec\u5c06\u4f7f\u7528Apache Bench\u6765\u6d4b\u91cfAPI\u7684\u6027\u80fd\u3002\u9700\u8981\u6ce8\u610f\u7684\u662f\uff0c\u5982\u679c\u4f7f\u7528Mac\uff0c\u6b64\u5de5\u5177\u5df2\u7ecf\u9ed8\u8ba4\u5b89\u88c5\u3002\u60a8\u53ef\u4ee5\u53c2\u8003\u4e0b\u9762\u7684\u6587\u7ae0\u6765\u4e86\u89e3\u8be5\u5de5\u5177\u7684\u8be6\u7ec6\u4fe1\u606f\u3002<\/p>\n<p>&nbsp;<\/p>\n<pre class=\"post-pre\"><code><span class=\"o\">&gt;<\/span> ab <span class=\"nt\">-n<\/span> 30 <span class=\"nt\">-c<\/span> 30 http:\/\/localhost:8080\/db\/1\r\n\r\nBenchmarking localhost <span class=\"o\">(<\/span>be patient<span class=\"o\">)<\/span>...\r\n\r\n<span class=\"c\"># \u4e00\u90e8\u5272\u611b<\/span>\r\n<span class=\"c\"># \u30ec\u30a4\u30c6\u30f3\u30b7\u306e\u5206\u5e03(\u30d1\u30fc\u30bb\u30f3\u30bf\u30a4\u30eb\u60c5\u5831)<\/span>\r\nPercentage of the requests served within a certain <span class=\"nb\">time<\/span> <span class=\"o\">(<\/span>ms<span class=\"o\">)<\/span>\r\n  50%  10079\r\n  66%  10083\r\n  75%  10085\r\n  80%  10087\r\n  90%  10088\r\n  95%  10089\r\n  98%  10089\r\n  99%  10089\r\n 100%  10089 <span class=\"o\">(<\/span>longest request<span class=\"o\">)<\/span>\r\n<\/code><\/pre>\n<p>\u5728\u8fd9\u91cc\uff0c-n\u9009\u9879\u6307\u5b9a\u4e86\u603b\u8bf7\u6c42\u6570\uff0c-c\u9009\u9879\u6307\u5b9a\u4e86\u5e76\u884c\u8bf7\u6c42\u6570\u3002\u5728\u8fd9\u4e2a\u4f8b\u5b50\u4e2d\uff0c\u6211\u4eec\u4f7f\u752830\u4e2a\u5e76\u884c\u8bf7\u6c42\u6267\u884c\u4e8630\u6b21\u8bf7\u6c42\u3002\u4ece\u6267\u884c\u7ed3\u679c\u6765\u770b\uff0c\u6211\u4eec\u53ef\u4ee5\u770b\u51fa\u5ef6\u8fdf\u5728\u5206\u5e03\u7684\u6bcf\u4e2a\u767e\u5206\u4f4d\u70b9\u4e0a\u90fd\u6709\u5927\u7ea610\u79d2\u7684\u5ef6\u8fdf\u3002<\/p>\n<p>\u786e\u8ba4\u6162\u67e5\u8be2<\/p>\n<p>\u5728\u672c\u5730\u73af\u5883\u4e2d\u4f7f\u7528\u7684MySQL\u955c\u50cf\u9ed8\u8ba4\u4f1a\u8f93\u51fa\u6162\u67e5\u8be2\u65e5\u5fd7\u3002\u6b64\u5916\uff0c\u5728docker-compose.yml\u4e2d\u5c06\u6162\u67e5\u8be2\u6620\u5c04\u5230\u672c\u5730\u673a\u5668\u4e0a\u3002<\/p>\n<details>\u9019\u88e1\u53ef\u4ee5\u67e5\u770b\u4ee3\u78bc\u7684\u8a73\u7d30\u5167\u5bb9\uff08docker-compose.yml\uff09docker-compose.yml<br \/>\nmysql:<br \/>\ncontainer_name: mysql<br \/>\nbuild: .docker\/mysql\/<br \/>\nvolumes:<br \/>\n&#8211; .docker\/mysql\/init:\/docker-entrypoint-initdb.d<br \/>\n&#8211; .docker\/mysql\/my.cnf:\/etc\/mysql\/conf.d\/my.cnf<br \/>\n&#8211; .docker\/mysql\/log:\/var\/log\/mysql # \u5728\u9019\u88e1\u5c07\u65e5\u8a8c\u6620\u5c04<br \/>\nenvironment:<br \/>\n&#8211; MYSQL_ROOT_PASSWORD=${DB_PASS}<br \/>\nports:<br \/>\n&#8211; &#8220;3306:3306&#8221;<br \/>\nnetworks:<br \/>\nsample_go_network:<\/p>\n<\/details>\n<p>\u67e5\u770b\u65e5\u5fd7\u540e\uff0c\u6211\u4eec\u53ef\u4ee5\u786e\u8ba4\u6709\u4e00\u4e9b\u8f93\u51fa\u3002\u901a\u8fc7Query_time\uff0c\u6211\u4eec\u53ef\u4ee5\u77e5\u9053\u67e5\u8be2\u5927\u7ea6\u9700\u898110\u79d2\u949f\u3002<\/p>\n<pre class=\"post-pre\"><code># Time: 2023-07-22T02:32:36.702832Z\r\n# User@Host: root[root] @  [192.168.192.4]  Id:    24\r\n# Query_time: 10.007020  Lock_time: 0.000000 Rows_sent: 1  Rows_examined: 1\r\nSET timestamp=1689993146;\r\nSELECT id, value, SLEEP(10) FROM customers WHERE id = '1';\r\n<\/code><\/pre>\n<h3>\u4f7f\u7528\u7f13\u5b58\u8fdb\u884c\u8c03\u4f18\u540e\u7684\u6d4b\u91cf<\/h3>\n<pre class=\"post-pre\"><code><span class=\"c\"># 1\u56de\u76ee\u306f\u540c\u3058\u304f10\u79d2\u7a0b\u5ea6\u304b\u304b\u308b<\/span>\r\n<span class=\"o\">&gt;<\/span> curl http:\/\/localhost:8080\/cache\/1\r\n<span class=\"o\">{<\/span><span class=\"s2\">\"id\"<\/span>:1,<span class=\"s2\">\"value\"<\/span>:<span class=\"s2\">\"Initial Value\"<\/span>,<span class=\"s2\">\"sleepResult\"<\/span>:0<span class=\"o\">}<\/span>\r\n\r\n<span class=\"c\"># 2\u56de\u76ee\u4ee5\u964d\u306f\u9045\u5ef6\u306e\u767a\u751f\u306f\u3057\u306a\u3044<\/span>\r\n<span class=\"o\">&gt;<\/span> curl http:\/\/localhost:8080\/cache\/1\r\n<span class=\"o\">{<\/span><span class=\"s2\">\"id\"<\/span>:1,<span class=\"s2\">\"value\"<\/span>:<span class=\"s2\">\"Initial Value\"<\/span>,<span class=\"s2\">\"sleepResult\"<\/span>:0<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<p>\u7b2c\u4e00\u6b21\u8bf7\u6c42\u7531\u4e8e\u5728\u5b58\u50a8\u5728MemCached\u4e2d\u4e4b\u524d\uff0c\u4e5f\u4f1a\u51fa\u73b0\u5927\u7ea610\u79d2\u7684\u5ef6\u8fdf\u3002\u4f46\u662f\uff0c\u4ece\u7b2c\u4e8c\u6b21\u8bf7\u6c42\u5f00\u59cb\uff0c\u7531\u4e8e\u4f7f\u7528\u4e86\u5df2\u4fdd\u5b58\u7684\u6570\u636e\uff0c\u6240\u4ee5\u4e0d\u4f1a\u6709\u54cd\u5e94\u5ef6\u8fdf\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"o\">&gt;<\/span> ab <span class=\"nt\">-n<\/span> 30 <span class=\"nt\">-c<\/span> 30 http:\/\/localhost:8080\/cache\/1\r\n\r\nBenchmarking localhost <span class=\"o\">(<\/span>be patient<span class=\"o\">)<\/span>...\r\n\r\n<span class=\"c\"># \u4e00\u90e8\u5272\u611b<\/span>\r\n<span class=\"c\"># \u30ec\u30a4\u30c6\u30f3\u30b7\u306e\u5206\u5e03(\u30d1\u30fc\u30bb\u30f3\u30bf\u30a4\u30eb\u60c5\u5831)<\/span>\r\nPercentage of the requests served within a certain <span class=\"nb\">time<\/span> <span class=\"o\">(<\/span>ms<span class=\"o\">)<\/span>\r\n  50%     22\r\n  66%     22\r\n  75%     24\r\n  80%     25\r\n  90%     26\r\n  95%     26\r\n  98%  10047\r\n  99%  10047\r\n 100%  10047 <span class=\"o\">(<\/span>longest request<span class=\"o\">)<\/span>\r\n<\/code><\/pre>\n<p>\u5728Apache Bench\u4e2d\u53ef\u4ee5\u786e\u8ba4\u5230\u54cd\u5e94\u5ef6\u8fdf\u663e\u8457\u6539\u5584\u3002\u53e6\u5916\uff0c\u53ef\u4ee5\u770b\u51fa\u9664\u4e86\u9996\u6b21\u67e5\u8be2\u4e4b\u5916\uff0c\u5e76\u6ca1\u6709\u8f93\u51fa\u6162\u67e5\u8be2\u3002<\/p>\n<h2>\u4e9a\u9a6c\u900a\u4e91\u670d\u52a1\u7f16\u7a0b<\/h2>\n<h3>\u57fa\u7840\u8bbe\u65bd\u67b6\u6784\u56fe<\/h3>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d1ed437434c4406c1782b\/61-0.png\" alt=\"\u540d\u79f0\u672a\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb-AWS\u7de8.png\" \/><\/div>\n<div>\u8bf7\u6ce8\u610f<br \/>\n\u4f7f\u7528AWS\u7684\u5404\u79cd\u8d44\u6e90\u90fd\u4f1a\u4ea7\u751f\u8d39\u7528\uff0c\u5176\u4e2d\u5305\u62ec\u5f88\u591a\u9700\u8981\u4ed8\u8d39\u7684\u9879\u76ee\u3002\u4e2a\u4eba\u7528\u6237\u5c24\u5176\u9700\u8981\u6ce8\u610f\u3002\u5bf9\u4e8e\u4ea7\u751f\u7684\u8d39\u7528\u6211\u4eec\u65e0\u6cd5\u627f\u62c5\u4efb\u4f55\u8d23\u4efb\u3002<\/div>\n<h3>\u9884\u5148\u8bbe\u5b9a<\/h3>\n<p>\u5728\u672c\u6587\u4e2d\uff0c\u5982\u679c\u60a8\u5df2\u7ecf\u5b8c\u6210\u4e86\u8bbe\u7f6e\uff0c\u5219\u65e0\u9700\u64cd\u4f5c\u3002\u4f46\u662f\uff0c\u672c\u6587\u9700\u8981\u51c6\u5907\u4e0eIAM\u7528\u6237\u3001\u63a5\u8fd1\u6839\u76ee\u5f55\u7684AWS CLI\u5b89\u88c5\u76f8\u5173\u7684\u5185\u5bb9\u3002\u7531\u4e8eTerraform\u5728Docker\u4e0a\u8fd0\u884c\uff0c\u56e0\u6b64\u65e0\u9700\u5355\u72ec\u5b89\u88c5\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">AWS CLI\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">root\u306b\u8fd1\u3044\u6a29\u9650\u3092\u6301\u3064IAM\u30e6\u30fc\u30b6\u30fc\u306e\u4f5c\u6210<\/ul>\n<p>&nbsp;<\/p>\n<p>\u8bf7\u4ece\u4ee5\u4e0b\u5b58\u50a8\u5e93\u514b\u9686\uff0c\u8bf7\u53c2\u8003README.md\u6587\u4ef6\u8fdb\u884c\u73af\u5883\u8bbe\u7f6e\u3002<\/p>\n<p>&nbsp;<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u30af\u30ed\u30fc\u30f3<\/span>\r\n<span class=\"nv\">$ <\/span>git clone git@github.com:WebEngrChild\/go-rds-memcached.git\r\n\r\n<span class=\"c\"># Docker\u8d77\u52d5<\/span>\r\n<span class=\"nv\">$ <\/span>docker compose up <span class=\"nt\">-d<\/span>\r\n\r\n<span class=\"c\"># API\u8d77\u52d5<\/span>\r\n<span class=\"nv\">$ <\/span>docker compose <span class=\"nb\">exec <\/span>app go run main.go\r\n<\/code><\/pre>\n<h3>\u5f15\u7528\u4e0b\u9762\u7684\u4e2d\u6587\u91ca\u4e49\uff0c\u53ea\u9700\u8981\u4e00\u79cd\u9009\u9879\uff1a<\/h3>\n<p>\u4ecb\u7ecdTerraform\u4ee3\u7801\u3002<\/p>\n<p>\u672c\u6587\u4f7f\u7528Terraform\u6765\u6784\u5efaAWS\u8d44\u6e90\u3002\u6211\u5c06\u7701\u7565\u8be6\u7ec6\u8bf4\u660e\uff0c\u4f46\u4e3a\u53c2\u8003\uff0c\u5c06\u63d0\u4f9b\u4ee3\u7801\u3002<\/p>\n<details>(1) main.tf\uff1aaws\u63d0\u4f9b\u8005\u5b9a\u4e49main.tf<br \/>\nprovider &#8220;aws&#8221; {<br \/>\nregion = &#8220;ap-northeast-1&#8221;<br \/>\n}<\/p>\n<\/details>\n<details>variables.tf\uff1a\u5b9a\u4e49\u9879\u76ee\u540d\u79f0\u7b49\u53d8\u91cfvariables.tf<br \/>\nvariable &#8220;project&#8221; {<br \/>\ntype = string<br \/>\ndefault = &#8220;go-api&#8221;<br \/>\n}<\/p>\n<p>variable &#8220;environment&#8221; {<br \/>\ntype = string<br \/>\ndefault = &#8220;dev&#8221;<br \/>\n}<\/p>\n<p>variable &#8220;cidr_blocks&#8221; {<br \/>\ndescription = &#8220;CIDR\u5757\u5217\u8868&#8221;<br \/>\ntype = list(string)<br \/>\ndefault = [&#8220;&lt;\u8bf7\u8bbe\u7f6e\u60a8\u7684\u5168\u5c40IP\u5730\u5740&gt;\/32&#8221;]<br \/>\n}<\/p>\n<\/details>\n<details>\uff083\uff09\u6570\u636e.tf\uff1a\u83b7\u53d6\u73b0\u6709\u8d44\u6e90\uff0c\u5305\u62ecECR\uff0cSSM\uff0cAMI\u7b49\u3002\u6570\u636e.tf<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u73b0\u6709\u7684ECR<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\ndata &#8220;aws_ecr_repository&#8221; &#8220;existing&#8221; {<br \/>\nname = &#8220;go-dev-repo&#8221;<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u73b0\u6709\u7684SSM\u53c2\u6570\u5b58\u50a8<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\ndata &#8220;aws_ssm_parameter&#8221; &#8220;existing&#8221; {<br \/>\nname = &#8220;\/env&#8221;<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u73b0\u6709\u7684ECR<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\ndata &#8220;aws_ecr_repository&#8221; &#8220;existing&#8221; {<br \/>\nname = &#8220;go-dev-repo&#8221;<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u73b0\u6709\u7684SSM\u53c2\u6570\u5b58\u50a8<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\ndata &#8220;aws_ssm_parameter&#8221; &#8220;existing&#8221; {<br \/>\nname = &#8220;\/env&#8221;<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u6700\u65b0\u7684EC2 AMI<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\ndata &#8220;aws_ssm_parameter&#8221; &#8220;ami&#8221; {<br \/>\nname = &#8220;\/aws\/service\/ami-amazon-linux-latest\/al2023-ami-kernel-6.1-x86_64&#8221;<br \/>\n}<\/p>\n<\/details>\n<pre class=\"post-pre\"><code><span class=\"c1\"># \u6700\u65b0\u306eAMI\u30a4\u30e1\u30fc\u30b8\u3092\u53d6\u5f97<\/span>\r\n<span class=\"k\">data<\/span> <span class=\"s2\">\"aws_ssm_parameter\"<\/span> <span class=\"s2\">\"ami\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">name<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"\/aws\/service\/ami-amazon-linux-latest\/al2023-ami-kernel-6.1-x86_64\"<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>&nbsp;<\/p>\n<details>vpc.tf\uff1aVPC\u3001\u5b50\u7f51\u7b49\u7f51\u7edc\u5efa\u8bbevpc.tf<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u672c\u5730\u53d8\u91cf<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nlocals {<br \/>\nzones = [&#8220;1a&#8221;, &#8220;1c&#8221;, &#8220;1d&#8221;]<br \/>\npublic_cidrs = [&#8220;10.0.1.0\/24&#8221;, &#8220;10.0.2.0\/24&#8221;, &#8220;10.0.3.0\/24&#8221;]<br \/>\nprivate_cidrs = [&#8220;10.0.10.0\/24&#8221;, &#8220;10.0.20.0\/24&#8221;, &#8220;10.0.30.0\/24&#8221;]<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# VPC<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_vpc&#8221; &#8220;main&#8221; {<br \/>\ncidr_block = &#8220;10.0.0.0\/16&#8221;<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws_vpc&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u516c\u5171\u5b50\u7f51<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_subnet&#8221; &#8220;public&#8221; {<br \/>\nfor_each = toset(local.zones)<\/p>\n<p>vpc_id = aws_vpc.main.id<br \/>\navailability_zone = &#8220;ap-northeast-${each.value}&#8221;<br \/>\ncidr_block = local.public_cidrs[index(local.zones, each.value)]<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-public-%s&#8221;, var.environment, var.project, each.value)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u79c1\u6709\u5b50\u7f51<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_subnet&#8221; &#8220;private&#8221; {<br \/>\nfor_each = toset(local.zones)<\/p>\n<p>vpc_id = aws_vpc.main.id<br \/>\navailability_zone = &#8220;ap-northeast-${each.value}&#8221;<br \/>\ncidr_block = local.private_cidrs[index(local.zones, each.value)]<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-private-%s&#8221;, var.environment, var.project, each.value)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u4e92\u8054\u7f51\u7f51\u5173<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_internet_gateway&#8221; &#8220;main&#8221; {<br \/>\nvpc_id = aws_vpc.main.id<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws_internet_gateway&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u5f39\u6027IP<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_eip&#8221; &#8220;nat&#8221; {<br \/>\nfor_each = toset(local.zones)<\/p>\n<p>domain = &#8220;vpc&#8221;<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws_eip-nat_%s&#8221;, var.environment, var.project, each.value)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# NAT\u7f51\u5173<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_nat_gateway&#8221; &#8220;nat&#8221; {<br \/>\nfor_each = toset(local.zones)<\/p>\n<p>subnet_id = aws_subnet.public[each.value].id<br \/>\nallocation_id = aws_eip.nat[each.value].id<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-nat_%s&#8221;, var.environment, var.project, each.value)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u516c\u5171\u8def\u7531\u8868<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_route_table&#8221; &#8220;public&#8221; {<br \/>\nvpc_id = aws_vpc.main.id<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws_route_table-public&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u516c\u5171\u8def\u7531<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_route&#8221; &#8220;public&#8221; {<br \/>\ndestination_cidr_block = &#8220;0.0.0.0\/0&#8221;<br \/>\nroute_table_id = aws_route_table.public.id<br \/>\ngateway_id = aws_internet_gateway.main.id<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u5173\u8054\u516c\u5171\u8def\u7531\u8868<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_route_table_association&#8221; &#8220;public&#8221; {<br \/>\nfor_each = toset(local.zones)<\/p>\n<p>subnet_id = aws_subnet.public[each.value].id<br \/>\nroute_table_id = aws_route_table.public.id<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u79c1\u6709\u8def\u7531\u8868<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_route_table&#8221; &#8220;private&#8221; {<br \/>\nfor_each = toset(local.zones)<\/p>\n<p>vpc_id = aws_vpc.main.id<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-private_%s&#8221;, var.environment, var.project, each.value)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u79c1\u6709\u8def\u7531<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_route&#8221; &#8220;private&#8221; {<br \/>\nfor_each = toset(local.zones)<\/p>\n<p>destination_cidr_block = &#8220;0.0.0.0\/0&#8221;<br \/>\nroute_table_id = aws_route_table.private[each.value].id<br \/>\nnat_gateway_id = aws_nat_gateway.nat[each.value].id<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u5173\u8054\u79c1\u6709\u8def\u7531\u8868<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_route_table_association&#8221; &#8220;private&#8221; {<br \/>\nfor_each = toset(local.zones)<\/p>\n<p>subnet_id = aws_subnet.private[each.value].id<br \/>\nroute_table_id = aws_route_table.private[each.value].id<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u5b89\u5168\u7ec4ALB<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_security_group&#8221; &#8220;alb&#8221; {<br \/>\nname = var.project<br \/>\ndescription = var.project<br \/>\nvpc_id = aws_vpc.main.id<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws_security_group-alb&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u5b89\u5168\u7ec4\u89c4\u5219<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_security_group_rule&#8221; &#8220;alb_egress&#8221; {<br \/>\nsecurity_group_id = aws_security_group.alb.id<\/p>\n<p>type = &#8220;egress&#8221;<br \/>\nfrom_port = 0<br \/>\nto_port = 0<br \/>\nprotocol = &#8220;-1&#8221;<br \/>\ncidr_blocks = [&#8220;0.0.0.0\/0&#8221;]<br \/>\n}<\/p>\n<p>resource &#8220;aws_security_group_rule&#8221; &#8220;alb_ingress&#8221; {<br \/>\nsecurity_group_id = aws_security_group.alb.id<\/p>\n<p>type = &#8220;ingress&#8221;<br \/>\nfrom_port = 80<br \/>\nto_port = 80<br \/>\nprotocol = &#8220;tcp&#8221;<br \/>\ncidr_blocks = [&#8220;0.0.0.0\/0&#8221;]<br \/>\n}<\/p>\n<\/details>\n<p>\u4f60\u53ef\u4ee5\u5728\u672c\u5730\u5b9a\u4e49\u6587\u4ef6\u4e2d\u53ef\u7528\u7684\u53d8\u91cf\u3002\u5728\u8fd9\u91cc\uff0c\u6211\u4eec\u4f7f\u7528 `for_each` \u5faa\u73af\u5b9a\u4e49\u4e86\u53ef\u7528\u533a\u548c\u5b50\u7f51\u7684\u521b\u5efa\u3002<\/p>\n<p>\u540c\u65f6\uff0c\u4f7f\u7528format()\u51fd\u6570\u4ee5\u4efb\u610f\u7684\u683c\u5f0f\u8f93\u51fa\u6bcf\u4e2a\u53d8\u91cf\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\"># ------------------------------------------------------------#<\/span>\r\n<span class=\"c1\"># local variables<\/span>\r\n<span class=\"c1\"># ------------------------------------------------------------#<\/span>\r\n<span class=\"nx\">locals<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">zones<\/span>         <span class=\"p\">=<\/span> <span class=\"p\">[<\/span><span class=\"s2\">\"1a\"<\/span><span class=\"p\">,<\/span> <span class=\"s2\">\"1c\"<\/span><span class=\"p\">,<\/span> <span class=\"s2\">\"1d\"<\/span><span class=\"p\">]<\/span>\r\n  <span class=\"nx\">public_cidrs<\/span>  <span class=\"p\">=<\/span> <span class=\"p\">[<\/span><span class=\"s2\">\"10.0.1.0\/24\"<\/span><span class=\"p\">,<\/span> <span class=\"s2\">\"10.0.2.0\/24\"<\/span><span class=\"p\">,<\/span> <span class=\"s2\">\"10.0.3.0\/24\"<\/span><span class=\"p\">]<\/span>\r\n  <span class=\"nx\">private_cidrs<\/span> <span class=\"p\">=<\/span> <span class=\"p\">[<\/span><span class=\"s2\">\"10.0.10.0\/24\"<\/span><span class=\"p\">,<\/span> <span class=\"s2\">\"10.0.20.0\/24\"<\/span><span class=\"p\">,<\/span> <span class=\"s2\">\"10.0.30.0\/24\"<\/span><span class=\"p\">]<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\">## \u7701\u7565... <\/span>\r\n\r\n<span class=\"c1\"># ------------------------------------------------------------#<\/span>\r\n<span class=\"c1\"># Subnet Public<\/span>\r\n<span class=\"c1\"># ------------------------------------------------------------#<\/span>\r\n<span class=\"k\">resource<\/span> <span class=\"s2\">\"aws_subnet\"<\/span> <span class=\"s2\">\"public\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">for_each<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">toset<\/span><span class=\"p\">(<\/span><span class=\"kd\">local<\/span><span class=\"p\">.<\/span><span class=\"nx\">zones<\/span><span class=\"p\">)<\/span>\r\n\r\n  <span class=\"nx\">vpc_id<\/span>            <span class=\"p\">=<\/span> <span class=\"nx\">aws_vpc<\/span><span class=\"p\">.<\/span><span class=\"nx\">main<\/span><span class=\"p\">.<\/span><span class=\"nx\">id<\/span>\r\n  <span class=\"nx\">availability_zone<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"ap-northeast-<\/span><span class=\"k\">${<\/span><span class=\"nx\">each<\/span><span class=\"p\">.<\/span><span class=\"nx\">value<\/span><span class=\"k\">}<\/span><span class=\"s2\">\"<\/span>\r\n  <span class=\"nx\">cidr_block<\/span>        <span class=\"p\">=<\/span> <span class=\"kd\">local<\/span><span class=\"p\">.<\/span><span class=\"nx\">public_cidrs<\/span><span class=\"p\">[<\/span><span class=\"nx\">index<\/span><span class=\"p\">(<\/span><span class=\"kd\">local<\/span><span class=\"p\">.<\/span><span class=\"nx\">zones<\/span><span class=\"p\">,<\/span> <span class=\"nx\">each<\/span><span class=\"p\">.<\/span><span class=\"nx\">value<\/span><span class=\"p\">)]<\/span>\r\n\r\n  <span class=\"nx\">tags<\/span> <span class=\"p\">=<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">Name<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">format<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"%s-%s-public-%s\"<\/span><span class=\"p\">,<\/span> <span class=\"kd\">var<\/span><span class=\"p\">.<\/span><span class=\"nx\">environment<\/span><span class=\"p\">,<\/span> <span class=\"kd\">var<\/span><span class=\"p\">.<\/span><span class=\"nx\">project<\/span><span class=\"p\">,<\/span> <span class=\"nx\">each<\/span><span class=\"p\">.<\/span><span class=\"nx\">value<\/span><span class=\"p\">)<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\">## \u7701\u7565... <\/span>\r\n<\/code><\/pre>\n<details>ecs.tf\uff1aECS, ALB \u69cb\u5efa<br \/>\necs.tf<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u8ca0\u8f09\u5747\u8861\u5668<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_lb&#8221; &#8220;main&#8221; {<br \/>\nload_balancer_type = &#8220;application&#8221;<br \/>\nname = var.projectsecurity_groups = [aws_security_group.alb.id]<br \/>\nsubnets = values(aws_subnet.public)[*].id<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u8ca0\u8f09\u5747\u8861\u5668\u76e3\u807d\u5668<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_lb_listener&#8221; &#8220;main&#8221; {<br \/>\nport = 80<br \/>\nprotocol = &#8220;HTTP&#8221;<br \/>\nload_balancer_arn = aws_lb.main.arn<\/p>\n<p>default_action {<br \/>\ntype = &#8220;fixed-response&#8221;<\/p>\n<p>fixed_response {<br \/>\ncontent_type = &#8220;text\/plain&#8221;<br \/>\nstatus_code = &#8220;200&#8221;<br \/>\nmessage_body = &#8220;ok&#8221;<br \/>\n}<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u4efb\u52d9\u5b9a\u7fa9<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_ecs_task_definition&#8221; &#8220;main&#8221; {<br \/>\nfamily = var.project<br \/>\nrequires_compatibilities = [&#8220;FARGATE&#8221;]<br \/>\ncpu = &#8220;256&#8221;<br \/>\nmemory = &#8220;512&#8221;<br \/>\nnetwork_mode = &#8220;awsvpc&#8221;<br \/>\ncontainer_definitions = &lt; .env &amp;&amp; .\/main&#8221;],<br \/>\n&#8220;logConfiguration&#8221;: {<br \/>\n&#8220;logDriver&#8221;: &#8220;awslogs&#8221;,<br \/>\n&#8220;options&#8221;: {<br \/>\n&#8220;awslogs-group&#8221; : &#8220;${aws_cloudwatch_log_group.ecs_logs.name}&#8221;,<br \/>\n&#8220;awslogs-region&#8221;: &#8220;ap-northeast-1&#8221;,<br \/>\n&#8220;awslogs-stream-prefix&#8221;: &#8220;ecs&#8221;<br \/>\n}<br \/>\n},<br \/>\n&#8220;healthCheck&#8221;: {<br \/>\n&#8220;command&#8221;: [&#8220;CMD-SHELL&#8221;, &#8220;curl -f http:\/\/localhost:8080\/ || exit 1&#8221;],<br \/>\n&#8220;interval&#8221;: 30,<br \/>\n&#8220;timeout&#8221;: 5,<br \/>\n&#8220;retries&#8221;: 3,<br \/>\n&#8220;startPeriod&#8221;: 10<br \/>\n}<br \/>\n}<br \/>\n]<br \/>\nEOL<\/p>\n<p>execution_role_arn = aws_iam_role.ecs_task_execution_role.arn<br \/>\ntask_role_arn = aws_iam_role.task_role.arn<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# ECS \u96c6\u7fa4<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_ecs_cluster&#8221; &#8220;main&#8221; {<br \/>\nname = var.project<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# ELB \u76ee\u6a19\u7d44<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_lb_target_group&#8221; &#8220;main&#8221; {<br \/>\nname = var.project<br \/>\nvpc_id = aws_vpc.main.id<br \/>\nport = 8080<br \/>\nprotocol = &#8220;HTTP&#8221;<br \/>\ntarget_type = &#8220;ip&#8221;<\/p>\n<p>health_check {<br \/>\nport = 8080<br \/>\npath = &#8220;\/&#8221;<br \/>\nprotocol = &#8220;HTTP&#8221;<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# ALB \u76e3\u807d\u5668\u898f\u5247<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_lb_listener_rule&#8221; &#8220;main&#8221; {<br \/>\nlistener_arn = aws_lb_listener.main.arn<\/p>\n<p>action {<br \/>\ntype = &#8220;forward&#8221;<br \/>\ntarget_group_arn = aws_lb_target_group.main.arn<br \/>\n}<\/p>\n<p>condition {<br \/>\npath_pattern {<br \/>\nvalues = [&#8220;*&#8221;]<br \/>\n}<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# ECS \u5b89\u5168\u7fa4\u7d44<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_security_group&#8221; &#8220;ecs&#8221; {<br \/>\nname = format(&#8220;%s-ecs&#8221;, var.project)<br \/>\ndescription = format(&#8220;%s-ecs&#8221;, var.project)<br \/>\nvpc_id = aws_vpc.main.id<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-ecs&#8221;, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# ECS \u5b89\u5168\u7fa4\u7d44\u51fa\u7ad9\u898f\u5247<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_security_group_rule&#8221; &#8220;ecs_egress&#8221; {<br \/>\nsecurity_group_id = aws_security_group.ecs.id<br \/>\ntype = &#8220;egress&#8221;<\/p>\n<p>from_port = 0<br \/>\nto_port = 0<br \/>\nprotocol = &#8220;-1&#8221;<br \/>\ncidr_blocks = [&#8220;0.0.0.0\/0&#8221;]<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# ECS \u5b89\u5168\u7fa4\u7d44\u5165\u7ad9\u898f\u5247<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_security_group_rule&#8221; &#8220;ecs_ingress&#8221; {<br \/>\nsecurity_group_id = aws_security_group.ecs.id<br \/>\ntype = &#8220;ingress&#8221;<br \/>\nfrom_port = 8080<br \/>\nto_port = 8080<br \/>\nprotocol = &#8220;tcp&#8221;<br \/>\ncidr_blocks = [&#8220;10.0.0.0\/16&#8221;]<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# ECS \u670d\u52d9<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_ecs_service&#8221; &#8220;main&#8221; {<br \/>\nname = var.project<br \/>\ndepends_on = [aws_lb_listener_rule.main]<br \/>\ncluster = aws_ecs_cluster.main.name<br \/>\nlaunch_type = &#8220;FARGATE&#8221;<br \/>\ndesired_count = 1<br \/>\ntask_definition = aws_ecs_task_definition.main.arn<\/p>\n<p>network_configuration {<br \/>\nsubnets = values(aws_subnet.private)[*].id<br \/>\nsecurity_groups = [aws_security_group.ecs.id]<br \/>\n}<\/p>\n<p>load_balancer {<br \/>\ntarget_group_arn = aws_lb_target_group.main.arn<br \/>\ncontainer_name = &#8220;go&#8221;<br \/>\ncontainer_port = 8080<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u4efb\u52d9\u57f7\u884c\u89d2\u8272<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_iam_role&#8221; &#8220;ecs_task_execution_role&#8221; {<br \/>\nname = format(&#8220;%s-%s-ecs_task_execution_role&#8221;, var.environment, var.project)<\/p>\n<p>assume_role_policy = &lt;&lt;EOF<br \/>\n{<br \/>\n&#8220;Version&#8221;: &#8220;2012-10-17&#8221;,<br \/>\n&#8220;Statement&#8221;: [<br \/>\n{<br \/>\n&#8220;Action&#8221;: &#8220;sts:AssumeRole&#8221;,<br \/>\n&#8220;Principal&#8221;: {<br \/>\n&#8220;Service&#8221;: &#8220;ecs-tasks.amazonaws.com&#8221;<br \/>\n},<br \/>\n&#8220;Effect&#8221;: &#8220;Allow&#8221;,<br \/>\n&#8220;Sid&#8221;: &#8220;&#8221;<br \/>\n}<br \/>\n]<br \/>\n}<br \/>\nEOF<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u806f\u7e6bPrivate<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_iam_policy&#8221; &#8220;ecs_task_execution_policy&#8221; {<br \/>\nname = format(&#8220;%s-%s-ecs_task_execution_policy&#8221;, var.environment, var.project)<br \/>\npath = &#8220;\/&#8221;<br \/>\ndescription = format(&#8220;%s-ecs-task-execution-policy&#8221;, var.project)<\/p>\n<p>policy = &lt;&lt;EOF<br \/>\n{<br \/>\n&#8220;Version&#8221;: &#8220;2012-10-17&#8221;,<br \/>\n&#8220;Statement&#8221;: [<br \/>\n{<br \/>\n&#8220;Effect&#8221;: &#8220;Allow&#8221;,<br \/>\n&#8220;Action&#8221;: [<br \/>\n&#8220;ecs:StartTask&#8221;,<br \/>\n&#8220;ecs:StopTask&#8221;,<br \/>\n&#8220;ecs:DescribeTasks&#8221;,<br \/>\n&#8220;ecs:ListTasks&#8221;,<br \/>\n&#8220;ecr:GetAuthorizationToken&#8221;,<br \/>\n&#8220;ecr:BatchCheckLayerAvailability&#8221;,<br \/>\n&#8220;ecr:GetDownloadUrlForLayer&#8221;,<br \/>\n&#8220;ecr:BatchGetImage&#8221;,<br \/>\n&#8220;logs:CreateLogStream&#8221;,<br \/>\n&#8220;logs:PutLogEvents&#8221;,<br \/>\n&#8220;ssm:GetParameters&#8221;<br \/>\n],<br \/>\n&#8220;Resource&#8221;: &#8220;*&#8221;<br \/>\n}<br \/>\n]<br \/>\n}<br \/>\nEOF<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u4efb\u52d9\u89d2\u8272\u7b56\u7565\u95dc\u806f<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_iam_role_policy_attachment&#8221; &#8220;ecs_task_execution_role_policy_attach&#8221; {<br \/>\nrole = aws_iam_role.ecs_task_execution_role.name<br \/>\npolicy_arn = aws_iam_policy.ecs_task_execution_policy.arn<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u4efb\u52d9\u89d2\u8272<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_iam_role&#8221; &#8220;task_role&#8221; {<br \/>\nname = var.project<\/p>\n<p>assume_role_policy = &lt;&lt;EOF<br \/>\n{<br \/>\n&#8220;Version&#8221;: &#8220;2012-10-17&#8221;,<br \/>\n&#8220;Statement&#8221;: [<br \/>\n{<br \/>\n&#8220;Action&#8221;: &#8220;sts:AssumeRole&#8221;,<br \/>\n&#8220;Principal&#8221;: {<br \/>\n&#8220;Service&#8221;: &#8220;ecs-tasks.amazonaws.com&#8221;<br \/>\n},<br \/>\n&#8220;Effect&#8221;: &#8220;Allow&#8221;,<br \/>\n&#8220;Sid&#8221;: &#8220;&#8221;<br \/>\n}<br \/>\n]<br \/>\n}<br \/>\nEOF<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# SSM\u53c3\u6578\u5b58\u5132\u7b56\u7565<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_iam_policy&#8221; &#8220;ssm_parameter_store_policy&#8221; {<br \/>\nname = var.project<br \/>\ndescription = &#8220;\u5141\u8a31\u8a2a\u554fSSM\u53c3\u6578\u5b58\u5132&#8221;<\/p>\n<p>policy = &lt;&lt;EOF<br \/>\n{<br \/>\n&#8220;Version&#8221;: &#8220;2012-10-17&#8221;,<br \/>\n&#8220;Statement&#8221;: [<br \/>\n{<br \/>\n&#8220;Effect&#8221;: &#8220;Allow&#8221;,<br \/>\n&#8220;Action&#8221;: &#8220;ssm:GetParameters&#8221;,<br \/>\n&#8220;Resource&#8221;: &#8220;*&#8221;<br \/>\n}<br \/>\n]<br \/>\n}<br \/>\nEOF<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# SSM\u53c3\u6578\u5b58\u5132\u7b56\u7565\u95dc\u806f<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_iam_role_policy_attachment&#8221; &#8220;ssm_policy_attach&#8221; {<br \/>\nrole = aws_iam_role.task_role.name<br \/>\npolicy_arn = aws_iam_policy.ssm_parameter_store_policy.arn<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# CloudWatch\u65e5\u8a8c\u7d44<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_cloudwatch_log_group&#8221; &#8220;ecs_logs&#8221; {<br \/>\nname = &#8220;\/ecs\/handson&#8221;<br \/>\nretention_in_days = 14<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u8f38\u51fa<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\noutput &#8220;alb_dns&#8221; {<br \/>\nvalue = aws_lb.main.dns_name<br \/>\ndescription = &#8220;DNS\u540d\u7a31&#8221;<br \/>\n}<\/p>\n<\/details>\n<p>\u53ef\u4ee5\u901a\u8fc7\u5728\u4efb\u52a1\u5b9a\u4e49\u4e2d\u6309\u4ee5\u4e0b\u65b9\u5f0f\u63cf\u8ff0\uff0c\u9664\u4e86ALB\u7684\u5065\u5eb7\u68c0\u67e5\u4e4b\u5916\uff0c\u8fd8\u53ef\u4ee5\u63cf\u8ff0\u5bb9\u5668\u7684\u542f\u52a8\u68c0\u67e5\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\"># ------------------------------------------------------------#<\/span>\r\n<span class=\"c1\"># Task Definition<\/span>\r\n<span class=\"c1\"># ------------------------------------------------------------#<\/span>\r\n<span class=\"k\">resource<\/span> <span class=\"s2\">\"aws_ecs_task_definition\"<\/span> <span class=\"s2\">\"main\"<\/span> <span class=\"p\">{<\/span>\r\n\r\n<span class=\"c1\">## \u7701\u7565...<\/span>\r\n\r\n    <span class=\"s2\">\"healthCheck\"<\/span><span class=\"err\">:<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"s2\">\"command\"<\/span><span class=\"err\">:<\/span> <span class=\"p\">[<\/span><span class=\"s2\">\"CMD-SHELL\"<\/span><span class=\"p\">,<\/span> <span class=\"s2\">\"curl -f http:\/\/localhost:8080\/ || exit 1\"<\/span><span class=\"p\">],<\/span>\r\n      <span class=\"s2\">\"interval\"<\/span><span class=\"err\">:<\/span> <span class=\"mi\">30<\/span><span class=\"p\">,<\/span>\r\n      <span class=\"s2\">\"timeout\"<\/span><span class=\"err\">:<\/span> <span class=\"mi\">5<\/span><span class=\"p\">,<\/span>\r\n      <span class=\"s2\">\"retries\"<\/span><span class=\"err\">:<\/span> <span class=\"mi\">3<\/span><span class=\"p\">,<\/span>\r\n      <span class=\"s2\">\"startPeriod\"<\/span><span class=\"err\">:<\/span> <span class=\"mi\">10<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>&nbsp;<\/p>\n<details>rds.tf:<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# RDS\u6784\u5efa<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_db_parameter_group&#8221; &#8220;main&#8221; {<br \/>\nname = var.project<br \/>\nfamily = &#8220;mysql8.0&#8243;parameter {<br \/>\nname = &#8220;character_set_database&#8221;<br \/>\nvalue = &#8220;utf8mb4&#8221;<br \/>\n}<\/p>\n<p>parameter {<br \/>\nname = &#8220;character_set_server&#8221;<br \/>\nvalue = &#8220;utf8mb4&#8221;<br \/>\n}<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws-db-parameter-group&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# RDS\u9009\u9879\u7ec4<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_db_option_group&#8221; &#8220;main&#8221; {<br \/>\nname = var.project<br \/>\noption_group_description = var.project<br \/>\nengine_name = &#8220;mysql&#8221;<br \/>\nmajor_engine_version = &#8220;8.0&#8221;<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws-db-option-group&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# RDS\u5b50\u7f51\u7ec4<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_db_subnet_group&#8221; &#8220;main&#8221; {<br \/>\nname = var.project<br \/>\nsubnet_ids = [<br \/>\naws_subnet.private[&#8220;1c&#8221;].id,<br \/>\naws_subnet.private[&#8220;1d&#8221;].id,<br \/>\n]<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws-db-subnet-group&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# RDS\u5b89\u5168\u7ec4<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_security_group&#8221; &#8220;rds&#8221; {<br \/>\nname = format(&#8220;%s-%s-aws-security-group-rds&#8221;, var.environment, var.project)<br \/>\ndescription = &#8220;\u5141\u8bb83306\u7aef\u53e3\u7684\u5165\u7ad9\u6d41\u91cf&#8221;<br \/>\nvpc_id = aws_vpc.main.id<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws-security-group&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p>resource &#8220;aws_security_group_rule&#8221; &#8220;allow_ecs_mysql&#8221; {<br \/>\nsecurity_group_id = aws_security_group.rds.id<br \/>\ntype = &#8220;ingress&#8221;<br \/>\nfrom_port = 3306<br \/>\nto_port = 3306<br \/>\nprotocol = &#8220;tcp&#8221;<br \/>\nsource_security_group_id = aws_security_group.ecs.id<br \/>\n}<\/p>\n<p>resource &#8220;aws_security_group_rule&#8221; &#8220;allow_ec2_mysql&#8221; {<br \/>\nsecurity_group_id = aws_security_group.rds.id<br \/>\ntype = &#8220;ingress&#8221;<br \/>\nfrom_port = 3306<br \/>\nto_port = 3306<br \/>\nprotocol = &#8220;tcp&#8221;<br \/>\nsource_security_group_id = aws_security_group.ssm.id<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# RDS\u5b9e\u4f8b<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;random_string&#8221; &#8220;db_password&#8221; {<br \/>\nlength = 16<br \/>\nspecial = false<br \/>\n}<\/p>\n<p>resource &#8220;aws_db_instance&#8221; &#8220;main&#8221; {<br \/>\nengine = &#8220;mysql&#8221;<br \/>\nengine_version = &#8220;8.0&#8221;<\/p>\n<p>identifier = var.project<\/p>\n<p>username = &#8220;admin&#8221;<br \/>\npassword = random_string.db_password.result<\/p>\n<p>skip_final_snapshot = true<\/p>\n<p>instance_class = &#8220;db.t3.medium&#8221;<\/p>\n<p>storage_type = &#8220;gp2&#8221;<br \/>\nallocated_storage = 20<br \/>\nstorage_encrypted = false<\/p>\n<p>multi_az = false<br \/>\navailability_zone = &#8220;ap-northeast-1d&#8221;<br \/>\ndb_subnet_group_name = aws_db_subnet_group.main.name<br \/>\nvpc_security_group_ids = [aws_security_group.rds.id]<br \/>\npublicly_accessible = false<br \/>\nport = 3306<\/p>\n<p>parameter_group_name = aws_db_parameter_group.main.name<br \/>\noption_group_name = aws_db_option_group.main.name<\/p>\n<p>apply_immediately = true<\/p>\n<p>performance_insights_enabled = true<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws-db-instance&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u5821\u5792\u673aEC2<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_security_group&#8221; &#8220;ssm&#8221; {<br \/>\nname = format(&#8220;%s-%s-aws-security-group-ssm&#8221;, var.environment, var.project)<br \/>\ndescription = &#8220;\u7528\u4e8eSSM EC2\u5b9e\u4f8b\u7684\u5b89\u5168\u7ec4&#8221;<br \/>\nvpc_id = aws_vpc.main.id<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws-security-group-ssm&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p>resource &#8220;aws_security_group_rule&#8221; &#8220;ssm_egress&#8221; {<br \/>\ntype = &#8220;egress&#8221;<br \/>\nfrom_port = 0<br \/>\nto_port = 0<br \/>\nprotocol = &#8220;-1&#8221;<br \/>\ncidr_blocks = [&#8220;0.0.0.0\/0&#8221;]<br \/>\nsecurity_group_id = aws_security_group.ssm.id<br \/>\n}<\/p>\n<p>resource &#8220;aws_security_group_rule&#8221; &#8220;ssm_ingress_ssh&#8221; {<br \/>\ntype = &#8220;ingress&#8221;<br \/>\nfrom_port = 22<br \/>\nto_port = 22<br \/>\nprotocol = &#8220;tcp&#8221;<br \/>\ncidr_blocks = var.cidr_blocks<br \/>\nsecurity_group_id = aws_security_group.ssm.id<br \/>\n}<\/p>\n<p>resource &#8220;aws_security_group_rule&#8221; &#8220;ssm_ingress_mysql&#8221; {<br \/>\ntype = &#8220;ingress&#8221;<br \/>\nfrom_port = 3306<br \/>\nto_port = 3306<br \/>\nprotocol = &#8220;tcp&#8221;<br \/>\ncidr_blocks = var.cidr_blocks<br \/>\nsecurity_group_id = aws_security_group.ssm.id<br \/>\n}<\/p>\n<p>resource &#8220;aws_iam_role&#8221; &#8220;rds_access&#8221; {<br \/>\nname = format(&#8220;%s-%s-aws_iam_role-rds_access&#8221;, var.environment, var.project)<\/p>\n<p>assume_role_policy = jsonencode({<br \/>\nVersion = &#8220;2012-10-17&#8221;<br \/>\nStatement = [<br \/>\n{<br \/>\nEffect = &#8220;Allow&#8221;<br \/>\nPrincipal = {<br \/>\nService = &#8220;ec2.amazonaws.com&#8221;<br \/>\n}<br \/>\nAction = &#8220;sts:AssumeRole&#8221;<br \/>\n}<br \/>\n]<br \/>\n})<br \/>\n}<\/p>\n<p>resource &#8220;aws_iam_role_policy&#8221; &#8220;rds_access&#8221; {<br \/>\nname = &#8220;RDSPolicy&#8221;<br \/>\nrole = aws_iam_role.rds_access.id<\/p>\n<p>policy = jsonencode({<br \/>\nVersion = &#8220;2012-10-17&#8221;<br \/>\nStatement = [<br \/>\n{<br \/>\nEffect = &#8220;Allow&#8221;<br \/>\nAction = [<br \/>\n&#8220;rds:*&#8221;,<br \/>\n]<br \/>\nResource = [&#8220;*&#8221;]<br \/>\n}<br \/>\n]<br \/>\n})<br \/>\n}<\/p>\n<p>resource &#8220;aws_iam_role_policy_attachment&#8221; &#8220;ssm_managed_policy_attach&#8221; {<br \/>\nrole = aws_iam_role.rds_access.name<br \/>\npolicy_arn = &#8220;arn:aws:iam::aws:policy\/AmazonSSMManagedInstanceCore&#8221;<br \/>\n}<\/p>\n<p>resource &#8220;aws_iam_instance_profile&#8221; &#8220;rds_access&#8221; {<br \/>\nname = &#8220;RDSAccessProfile&#8221;<br \/>\nrole = aws_iam_role.rds_access.name<br \/>\n}<\/p>\n<p>resource &#8220;aws_instance&#8221; &#8220;ssm&#8221; {<br \/>\nami = &#8220;ami-0947c48ae0aaf6781&#8221;<br \/>\ninstance_type = &#8220;t2.micro&#8221;<br \/>\niam_instance_profile = aws_iam_instance_profile.rds_access.name<br \/>\nsubnet_id = aws_subnet.public[&#8220;1d&#8221;].id<br \/>\nvpc_security_group_ids = [aws_security_group.ssm.id]<br \/>\nassociate_public_ip_address = true<br \/>\nkey_name = &#8220;access_db&#8221;<br \/>\nuser_data = &lt;&lt;-EOF<br \/>\n#!\/bin\/bash<br \/>\nsudo systemctl enable amazon-ssm-agent<br \/>\nsudo systemctl start amazon-ssm-agent<br \/>\nEOF<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws-ssm-ec2-instance&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u8f93\u51fa<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\noutput &#8220;DB_USER&#8221; {<br \/>\nvalue = &#8220;admin&#8221;<br \/>\ndescription = &#8220;\u6570\u636e\u5e93\u7528\u6237\u540d&#8221;<br \/>\n}<\/p>\n<p>output &#8220;DB_PASS&#8221; {<br \/>\nvalue = random_string.db_password.result<br \/>\ndescription = &#8220;\u6570\u636e\u5e93\u5bc6\u7801&#8221;<br \/>\n}<\/p>\n<p>output &#8220;DB_HOST&#8221; {<br \/>\nvalue = aws_db_instance.main.address<br \/>\ndescription = &#8220;\u6570\u636e\u5e93\u7aef\u70b9&#8221;<br \/>\n}<\/p>\n<p>output &#8220;DB_NAME&#8221; {<br \/>\nvalue = &#8220;golang&#8221;<br \/>\ndescription = &#8220;\u6570\u636e\u5e93\u540d\u79f0&#8221;<br \/>\n}<\/p>\n<p>output &#8220;DB_PORT&#8221; {<br \/>\nvalue = aws_db_instance.main.port<br \/>\ndescription = &#8220;\u6570\u636e\u5e93\u7aef\u53e3&#8221;<br \/>\n}<\/p>\n<p>output &#8220;bastion_ec2_id&#8221; {<br \/>\nvalue = aws_instance.ssm.id<br \/>\ndescription = &#8220;\u5821\u5792\u673aEC2\u5b9e\u4f8bID&#8221;<br \/>\n}<\/p>\n<\/details>\n<p>\u6700\u65b0\u7684EC2\u7684AMI\u5df2\u7ecf\u9884\u88c5\u4e86ssm agent\uff0c\u4f46\u5c1a\u672a\u542f\u52a8\u3002\u56e0\u6b64\uff0c\u60a8\u53ef\u4ee5\u901a\u8fc7\u5728user_data\u4e2d\u8bb0\u5f55\u547d\u4ee4\u6765\u5728EC2\u542f\u52a8\u65f6\u6267\u884c\u5b83\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">resource<\/span> <span class=\"s2\">\"aws_instance\"<\/span> <span class=\"s2\">\"ssm\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">ami<\/span>                         <span class=\"p\">=<\/span> <span class=\"k\">data<\/span><span class=\"p\">.<\/span><span class=\"nx\">aws_ssm_parameter<\/span><span class=\"p\">.<\/span><span class=\"nx\">ami<\/span><span class=\"p\">.<\/span><span class=\"nx\">value<\/span>\r\n  <span class=\"nx\">instance_type<\/span>               <span class=\"p\">=<\/span> <span class=\"s2\">\"t2.micro\"<\/span>\r\n  <span class=\"nx\">iam_instance_profile<\/span>        <span class=\"p\">=<\/span> <span class=\"nx\">aws_iam_instance_profile<\/span><span class=\"p\">.<\/span><span class=\"nx\">rds_access<\/span><span class=\"p\">.<\/span><span class=\"nx\">name<\/span>\r\n  <span class=\"nx\">subnet_id<\/span>                   <span class=\"p\">=<\/span> <span class=\"nx\">aws_subnet<\/span><span class=\"p\">.<\/span><span class=\"nx\">public<\/span><span class=\"p\">[<\/span><span class=\"s2\">\"1d\"<\/span><span class=\"p\">].<\/span><span class=\"nx\">id<\/span>\r\n  <span class=\"nx\">vpc_security_group_ids<\/span>      <span class=\"p\">=<\/span> <span class=\"p\">[<\/span><span class=\"nx\">aws_security_group<\/span><span class=\"p\">.<\/span><span class=\"nx\">ssm<\/span><span class=\"p\">.<\/span><span class=\"nx\">id<\/span><span class=\"p\">]<\/span>\r\n  <span class=\"nx\">associate_public_ip_address<\/span> <span class=\"p\">=<\/span> <span class=\"kc\">true<\/span>\r\n  <span class=\"nx\">key_name<\/span>                    <span class=\"p\">=<\/span> <span class=\"s2\">\"access_db\"<\/span>\r\n  <span class=\"nx\">user_data<\/span>                   <span class=\"p\">=<\/span> <span class=\"o\">&lt;&lt;-<\/span><span class=\"no\">EOF<\/span><span class=\"sh\">\r\n            #!\/bin\/bash\r\n            sudo systemctl enable amazon-ssm-agent\r\n            sudo systemctl start amazon-ssm-agent\r\n<\/span><span class=\"no\">            EOF\r\n\r\n<\/span>  <span class=\"nx\">tags<\/span> <span class=\"p\">=<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">Name<\/span> <span class=\"p\">=<\/span> <span class=\"nx\">format<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"%s-%s-aws-ssm-ec2-instance\"<\/span><span class=\"p\">,<\/span> <span class=\"kd\">var<\/span><span class=\"p\">.<\/span><span class=\"nx\">environment<\/span><span class=\"p\">,<\/span> <span class=\"kd\">var<\/span><span class=\"p\">.<\/span><span class=\"nx\">project<\/span><span class=\"p\">)<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<\/code><\/pre>\n<details>memcached.tf\uff1a\u6784\u5efaElasticCache(Memcached)memcached.tf<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# Memcached\u5b89\u5168\u7ec4<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_security_group&#8221; &#8220;memcached&#8221; {<br \/>\nname = format(&#8220;%s-%s-aws-security-group&#8221;, var.environment, var.project)<br \/>\ndescription = &#8220;\u5141\u8bb811211\u7aef\u53e3\u7684\u5165\u7ad9\u6d41\u91cf&#8221;<br \/>\nvpc_id = aws_vpc.main.id<\/p>\n<p>tags = {<br \/>\nName = format(&#8220;%s-%s-aws-security-group&#8221;, var.environment, var.project)<br \/>\n}<br \/>\n}<\/p>\n<p>resource &#8220;aws_security_group_rule&#8221; &#8220;memcached&#8221; {<br \/>\nsecurity_group_id = aws_security_group.memcached.id<br \/>\ntype = &#8220;ingress&#8221;<br \/>\nfrom_port = 11211<br \/>\nto_port = 11211<br \/>\nprotocol = &#8220;tcp&#8221;<br \/>\nsource_security_group_id = aws_security_group.ecs.id<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# Memcached\u5b50\u7f51\u7ec4<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_elasticache_subnet_group&#8221; &#8220;memcached&#8221; {<br \/>\nname = format(&#8220;%s-%s-memcached-subnet-group&#8221;, var.environment, var.project)<br \/>\nsubnet_ids = [<br \/>\naws_subnet.private[&#8220;1c&#8221;].id,<br \/>\naws_subnet.private[&#8220;1d&#8221;].id,<br \/>\n]<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# Memcached\u96c6\u7fa4<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\nresource &#8220;aws_elasticache_cluster&#8221; &#8220;memcached&#8221; {<br \/>\ncluster_id = format(&#8220;%s-%s-memcached-cluster&#8221;, var.environment, var.project)<br \/>\nengine = &#8220;memcached&#8221;<br \/>\nnode_type = &#8220;cache.t3.micro&#8221;<br \/>\nnum_cache_nodes = 2<br \/>\nparameter_group_name = &#8220;default.memcached1.6&#8221;<br \/>\nsubnet_group_name = aws_elasticache_subnet_group.memcached.name<br \/>\nsecurity_group_ids = [aws_security_group.memcached.id]<br \/>\n}<\/p>\n<p># &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\n# \u8f93\u51fa<br \/>\n# &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;#<br \/>\noutput &#8220;CACHE_HOST1&#8221; {<br \/>\nvalue = &#8220;${aws_elasticache_cluster.memcached.cache_nodes.0.address}:11211&#8221;<br \/>\ndescription = &#8220;\u7f13\u5b58\u96c6\u7fa4\u8282\u70b91\u7684\u7aef\u70b9&#8221;<br \/>\n}<\/p>\n<p>output &#8220;CACHE_HOST2&#8221; {<br \/>\nvalue = &#8220;${aws_elasticache_cluster.memcached.cache_nodes.1.address}:11211&#8221;<br \/>\ndescription = &#8220;\u7f13\u5b58\u96c6\u7fa4\u8282\u70b92\u7684\u7aef\u70b9&#8221;<br \/>\n}<\/p>\n<\/details>\n<h3>\u5efa\u8bbe ECR<\/h3>\n<p>\u9996\u5148\u662f\u521b\u5efa ECR\u3002ECR \u662f\u4f7f\u7528 AWS CLI \u6765\u6784\u5efa\u8d44\u6e90\u3002\u8bf7\u5728 \u4e2d\u8f93\u5165\u60a8\u81ea\u5df1\u7684 AWS \u8d26\u6237 ID\u3002\u6b64\u5916\uff0c\u9664\u4e86 #\u6784\u5efa\u955c\u50cf \u547d\u4ee4\u4e4b\u5916\uff0c\u60a8\u8fd8\u53ef\u4ee5\u5728\u4ee5\u4e0b\u627e\u5230\u5176\u4ed6\u547d\u4ee4\u7684\u786e\u8ba4\u3002<\/p>\n<ul class=\"post-ul\">\u30de\u30cd\u30fc\u30b8\u30e1\u30f3\u30c8\u30b3\u30f3\u30bd\u30fc\u30eb &gt; Amazon ECR &gt; \u30ea\u30dd\u30b8\u30c8\u30ea &gt; go-dev-repo &gt; \u30d7\u30c3\u30b7\u30e5\u30b3\u30de\u30f3\u30c9\u306e\u8868\u793a<\/ul>\n<pre class=\"post-pre\"><code><span class=\"c\"># ECR\u4f5c\u6210<\/span>\r\naws ecr create-repository <span class=\"nt\">--repository-name<\/span> go-dev-repo\r\n\r\n<span class=\"c\"># \u30ed\u30b0\u30a4\u30f3<\/span>\r\naws ecr get-login-password <span class=\"nt\">--region<\/span> ap-northeast-1 | docker login <span class=\"nt\">--username<\/span> AWS <span class=\"nt\">--password-stdin<\/span> &lt;account_id&gt;.dkr.ecr.ap-northeast-1.amazonaws.com\r\n\r\n<span class=\"c\"># \u30a4\u30e1\u30fc\u30b8\u30d3\u30eb\u30c9<\/span>\r\ndocker build <span class=\"nt\">--no-cache<\/span> <span class=\"nt\">--target<\/span> runner <span class=\"nt\">-t<\/span> go-dev-repo <span class=\"nt\">--platform<\/span> linux\/amd64 <span class=\"nt\">-f<\/span> .\/.docker\/go\/Dockerfile <span class=\"nb\">.<\/span>\r\n\r\n<span class=\"c\"># \u30bf\u30b0\u4ed8\u3051<\/span>\r\ndocker tag go-dev-repo:latest &lt;account_id&gt;.dkr.ecr.ap-northeast-1.amazonaws.com\/go-dev-repo:latest\r\n\r\n<span class=\"c\"># \u30d7\u30c3\u30b7\u30e5<\/span>\r\ndocker push &lt;account_id&gt;.dkr.ecr.ap-northeast-1.amazonaws.com\/go-dev-repo:latest\r\n<\/code><\/pre>\n<h3>\u7cfb\u7edf\u7ba1\u7406\u5668\u53c2\u6570\u7684\u521d\u59cb\u503c\u8bbe\u5b9a<\/h3>\n<p>\u63a5\u4e0b\u6765\uff0c\u6211\u4eec\u5c06\u521b\u5efa\u4e00\u4e2a\u53c2\u6570\u5b58\u50a8\u6765\u5b58\u50a8\u5728ECS\u4efb\u52a1\u4e0a\u8fd0\u884c\u7684\u5e94\u7528\u7a0b\u5e8f\u6240\u4f7f\u7528\u7684\u73af\u5883\u53d8\u91cf\u3002\u5177\u4f53\u7684\u503c\u5c06\u5728\u540e\u7eed\u7684\u5de5\u4f5c\u4e2d\u8fdb\u884c\u8bbe\u7f6e\uff0c\u6240\u4ee5\u5728\u8fd9\u91cc\u6211\u4eec\u53ea\u6682\u65f6\u8bbe\u7f6e\u4e00\u4e2a\u521d\u59cb\u503c\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \/env\u3068\u3044\u3046\u30d1\u30b9\u306b\u521d\u671f\u5024\u3092\u4eee\u7f6e\u304d<\/span>\r\naws ssm put-parameter <span class=\"se\">\\<\/span>\r\n    <span class=\"nt\">--name<\/span> <span class=\"s2\">\"\/env\"<\/span> <span class=\"se\">\\<\/span>\r\n    <span class=\"nt\">--value<\/span> <span class=\"s2\">\"init\"<\/span> <span class=\"se\">\\<\/span>\r\n    <span class=\"nt\">--type<\/span> SecureString\r\n<\/code><\/pre>\n<h3>\u6267\u884cTerraform<\/h3>\n<p>\u4e3a\u4e86\u786e\u4fdd\u6700\u4f4e\u9650\u5ea6\u7684\u5b89\u5168\u6027\uff0c\u672c\u793a\u4f8b\u5e94\u7528\u5c06\u5bf9\u5176\u53ef\u4ee5\u8bbf\u95ee\u7684\u8d44\u6e90\u8fdb\u884cIP\u9650\u5236\u3002\u8bf7\u53c2\u8003\u4ee5\u4e0b\u7f51\u7ad9\u7b49\u83b7\u53d6\u5168\u7403IP\u5730\u5740\uff0c\u7136\u540e\u5c06\u5176\u8f6c\u5f55\u5230variables.tf\u6587\u4ef6\u4e2d\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">variable<\/span> <span class=\"s2\">\"cidr_blocks\"<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">description<\/span> <span class=\"p\">=<\/span> <span class=\"s2\">\"List of CIDR blocks\"<\/span>\r\n  <span class=\"nx\">type<\/span>        <span class=\"p\">=<\/span> <span class=\"nx\">list<\/span><span class=\"p\">(<\/span><span class=\"nx\">string<\/span><span class=\"p\">)<\/span>\r\n  <span class=\"nx\">default<\/span>     <span class=\"p\">=<\/span> <span class=\"p\">[<\/span><span class=\"s2\">\"&lt;\u3054\u81ea\u8eab\u306e\u30b0\u30ed\u30fc\u30d0\u30ebIP\u3092\u8a2d\u5b9a\u3057\u3066\u304f\u3060\u3055\u3044&gt;\/32\"<\/span><span class=\"p\">]<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>\u672c\u6587\u4ecb\u7ecd\u4e86\u4e00\u79cd\u65b9\u6cd5\uff0c\u5373\u4f7f\u7528Docker\u6765\u542f\u52a8HashiCorp\u5b98\u65b9\u63d0\u4f9b\u7684Terraform\u955c\u50cf\uff08\u7248\u672c1.5\uff09\uff0c\u800c\u4e0d\u662f\u76f4\u63a5\u5728\u672c\u5730\u8ba1\u7b97\u673a\u4e0a\u5b89\u88c5Terraform\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u30ed\u30fc\u30ab\u30eb\u30de\u30b7\u30f3\u306eAWS\u8a8d\u8a3c\u30ad\u30fc\u683c\u7d0d\u5148\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3068\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u3092\u30de\u30a6\u30f3\u30c8\u3057\u3066\u30b3\u30f3\u30c6\u30ca\u8d77\u52d5<\/span>\r\ndocker run <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">-v<\/span> ~\/.aws:\/root\/.aws <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">-v<\/span> <span class=\"si\">$(<\/span><span class=\"nb\">pwd<\/span><span class=\"si\">)<\/span>\/.infrastructure:\/terraform <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">-w<\/span> \/terraform <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">-it<\/span> <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">--entrypoint<\/span><span class=\"o\">=<\/span>ash <span class=\"se\">\\<\/span>\r\n  hashicorp\/terraform:1.5\r\n\r\n<span class=\"c\"># \u521d\u671f\u5316<\/span>\r\nterraform init\r\n\r\n<span class=\"c\"># \u5dee\u5206\u691c\u51fa<\/span>\r\nterraform plan\r\n\r\n<span class=\"c\"># \u30b3\u30fc\u30c9\u3092\u9069\u7528\u3059\u308b<\/span>\r\nterraform apply <span class=\"nt\">-auto-approve<\/span>\r\n\r\n<span class=\"o\">&gt;<\/span> aws_elasticache_cluster.memcached: Creation <span class=\"nb\">complete <\/span>after 7m15s <span class=\"o\">[<\/span><span class=\"nb\">id<\/span><span class=\"o\">=<\/span>dev-go-api-memcached-cluster]\r\n\r\n<span class=\"o\">&gt;<\/span> Apply <span class=\"nb\">complete<\/span><span class=\"o\">!<\/span> Resources: 69 added, 0 changed, 0 destroyed.\r\n\r\n<span class=\"o\">&gt;<\/span> Outputs:\r\n\r\n<span class=\"c\"># \u3053\u3053\u306bParameter Store\u306b\u767b\u9332\u3059\u308b\u74b0\u5883\u5909\u6570\u306e\u5024\u304c\u8868\u793a\u3055\u308c\u308b<\/span>\r\n<\/code><\/pre>\n<p>\u8bf7\u5728\u6267\u884c\u540e\u5c06\u663e\u793a\u7684\u8f93\u51fa\u7ed3\u679c\u8fdb\u884c\u5907\u5fd8\uff0c\u6216\u8005\u4fdd\u6301\u7ec8\u7aef\u6807\u7b7e\u9875\u7684\u6253\u5f00\u72b6\u6001\u3002<\/p>\n<h3>\u4f7f\u7528\u7cfb\u7edf\u7ba1\u7406\u5668\u7aef\u53e3\u8f6c\u53d1\u529f\u80fd\u8fde\u63a5\u5230RDS\u6570\u636e\u5e93\u3002<\/h3>\n<p>\u4f7f\u7528Session Manager\u540e\uff0c\u4e0d\u518d\u9700\u8981\u4e3a\u8df3\u677fEC2\u5b9e\u4f8b\u5206\u914d\u516c\u5171IP\u5730\u5740\u6216\u5141\u8bb8\u5165\u7ad9SSH\u8fde\u63a5\u3002\u6b64\u5916\uff0c\u65e0\u9700\u751f\u6210\u548c\u7ba1\u7406\u79c1\u94a5\uff0c\u53ef\u4ee5\u901a\u8fc7IAM\u7b56\u7565\u8fdb\u884c\u8bbf\u95ee\u7ba1\u7406\uff0c\u56e0\u6b64\u66f4\u52a0\u5b89\u5168\u3002<\/p>\n<p>\u4ee5\u524d\uff0c\u4f7f\u7528SSM\u7684\u65b9\u6cd5\u53ea\u80fd\u8f6c\u53d1EC2\u5b9e\u4f8b\u5185\u6b63\u5728\u76d1\u542c\u7684\u7aef\u53e3\uff0c<br \/>\n\u4f46\u662f\u901a\u8fc7\u6b64\u6b21\u66f4\u65b0\uff0c\u73b0\u5728\u4e5f\u53ef\u4ee5\u8f6c\u53d1\u8fdc\u7a0b\u4e3b\u673a\u7684\u7aef\u53e3\u3002<\/p>\n<p>&nbsp;<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u30bb\u30c3\u30b7\u30e7\u30f3\u958b\u59cb<\/span>\r\naws ssm start-session <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">--target<\/span> <span class=\"s2\">\"&lt;terraform\u30b3\u30de\u30f3\u30c9\u3067\u5b9f\u884c\u5f8c\u306b\u51fa\u529b\u3055\u308c\u308bbastion_ec2_id\u3092\u8ee2\u8a18&gt;\"<\/span> <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">--document-name<\/span> AWS-StartPortForwardingSessionToRemoteHost <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">--parameters<\/span> <span class=\"se\">\\<\/span>\r\n<span class=\"s1\">'{\r\n  \"host\": [\"&lt;terraform\u30b3\u30de\u30f3\u30c9\u3067\u5b9f\u884c\u5f8c\u306b\u51fa\u529b\u3055\u308c\u308bDB_HOST\u3092\u8ee2\u8a18&gt;\"],\r\n  \"portNumber\": [\"3306\"],\r\n  \"localPortNumber\":[\"3306\"]\r\n}'<\/span>\r\n\r\n<span class=\"c\"># \u4ee5\u4e0b\u304c\u8868\u793a\u3055\u308c\u305f\u3089\u30bf\u30d6\u306f\u958b\u3044\u305f\u307e\u307e\u306b\u3059\u308b<\/span>\r\n<span class=\"o\">&gt;<\/span> Waiting <span class=\"k\">for <\/span>connections...\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u5225\u30bf\u30d6\u3067Docker\u8d77\u52d5Docker\u8d77\u52d5<\/span>\r\ndocker run <span class=\"nt\">--name<\/span> mysql-client <span class=\"nt\">--rm<\/span> <span class=\"nt\">-it<\/span> mysql:8.0 \/bin\/bash\r\n\r\n<span class=\"c\"># MySQL\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u3067\u63a5\u7d9a<\/span>\r\nmysql <span class=\"nt\">-h<\/span> host.docker.internal <span class=\"nt\">-P<\/span> 3306 <span class=\"nt\">-u<\/span> admin <span class=\"nt\">-p<\/span>\r\n\r\n<span class=\"c\"># \u30d1\u30b9\u30ef\u30fc\u30c9\u5165\u529b<\/span>\r\nEnter password: &lt;terraform\u30b3\u30de\u30f3\u30c9\u3067\u5b9f\u884c\u5f8c\u306b\u51fa\u529b\u3055\u308c\u308bDB_PASS\u3092\u8ee2\u8a18&gt;\r\n\r\n<span class=\"c\"># \u521d\u671f\u30af\u30a8\u30ea<\/span>\r\nmysql&gt; &lt;.docker\/mysql\/init\/1_create.sql\u306e\u5185\u5bb9\u3092\u305d\u306e\u307e\u307e\u8ee2\u8a18\u3057\u3066\u5b9f\u884c&gt;\r\n<\/code><\/pre>\n<h3>\u5c06\u73af\u5883\u53d8\u91cf\u5b58\u50a8\u5728\u7cfb\u7edf\u7ba1\u7406\u5668\u53c2\u6570\u4e2d<\/h3>\n<p>\u8bf7\u5c06\u4ee5\u4e0b\u503c\u76f4\u63a5\u5b58\u50a8\u5728\u952e\u540d\u4e3a\u201cenv\u201d\u7684\u73af\u5883\u53d8\u91cf\u4e2d\uff0c\u800c\u4e0d\u662f\u5206\u522b\u5c06\u5176\u4ee5\u952e\u548c\u503c\u7684\u5f62\u5f0f\u5b58\u50a8\u4e3a\u952e\u503c\u5bf9\u3002<br \/>\n\u5728ecs.tf\u7684\u4efb\u52a1\u5b9a\u4e49\u6587\u4ef6\u4e2d\uff0c\u5c06\u4eceParameter\u4e2d\u5b58\u50a8\u7684\u503c\u4f20\u9012\u5230.env\u6587\u4ef6\u4e2d\uff0c\u65b9\u5f0f\u5982\u4e0b\u6240\u793a\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u7701\u7565<\/span>\r\n\r\n    <span class=\"s2\">\"secrets\"<\/span>: <span class=\"o\">[<\/span>\r\n      <span class=\"o\">{<\/span>\r\n        <span class=\"s2\">\"name\"<\/span>: <span class=\"s2\">\"ENV_FILE\"<\/span>,\r\n        <span class=\"s2\">\"valueFrom\"<\/span>: <span class=\"s2\">\"<\/span><span class=\"k\">${<\/span><span class=\"nv\">data<\/span><span class=\"p\">.aws_ssm_parameter.existing.arn<\/span><span class=\"k\">}<\/span><span class=\"s2\">\"<\/span>\r\n      <span class=\"o\">}<\/span>\r\n    <span class=\"o\">]<\/span>,\r\n    <span class=\"s2\">\"command\"<\/span>: <span class=\"o\">[<\/span><span class=\"s2\">\"\/bin\/sh\"<\/span>, <span class=\"s2\">\"-c\"<\/span>, <span class=\"s2\">\"printenv ENV_FILE &gt; .env &amp;&amp; .\/main\"<\/span><span class=\"o\">]<\/span>,\r\n\r\n<span class=\"c\"># \u7701\u7565<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"c\"># Terraform\u3067\u30ea\u30bd\u30fc\u30b9\u4f5c\u6210\u304c\u5b8c\u4e86\u3059\u308b\u3068\u51fa\u529b\u3055\u308c\u308b<\/span>\r\nApply <span class=\"nb\">complete<\/span><span class=\"o\">!<\/span> Resources: 69 added, 0 changed, 0 destroyed.\r\n\r\nOutputs:\r\nCACHE_HOST1 <span class=\"o\">=<\/span> <span class=\"s2\">\"dev-go-api-memcached-cluster.xxxx.0001.apne1.cache.amazonaws.com:11211\"<\/span>\r\nCACHE_HOST2 <span class=\"o\">=<\/span> <span class=\"s2\">\"dev-go-api-memcached-cluster.xxxx.0002.apne1.cache.amazonaws.com:11211\"<\/span>\r\nDB_HOST <span class=\"o\">=<\/span> <span class=\"s2\">\"go-api.xxxxx.ap-northeast-1.rds.amazonaws.com\"<\/span>\r\nDB_NAME <span class=\"o\">=<\/span> <span class=\"s2\">\"golang\"<\/span>\r\nDB_PASS <span class=\"o\">=<\/span> <span class=\"s2\">\"xxxxxx\"<\/span>\r\nDB_PORT <span class=\"o\">=<\/span> 3306\r\nDB_USER <span class=\"o\">=<\/span> <span class=\"s2\">\"admin\"<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"c\"># terraform\u30b3\u30de\u30f3\u30c9\u3067\u5b9f\u884c\u5f8c\u306b\u51fa\u529b\u3055\u308c\u308b\u5185\u5bb9\u3092\u4ee5\u4e0b\u306e\u5f62\u306b\u4fee\u6b63\u3057\u3066`env`\u306b\u305d\u306e\u307e\u307e\u306e\u5f62\u3067\u8ee2\u8a18<\/span>\r\n<span class=\"c\"># \u30c0\u30d6\u30eb\u30b3\u30ed\u30f3\"\"\u306f\u4e0d\u8981\u306a\u306e\u3067\u6ce8\u610f\u3059\u308b\u3053\u3068<\/span>\r\n\r\n<span class=\"nv\">DB_USER<\/span><span class=\"o\">=<\/span>admin\r\n<span class=\"nv\">DB_PASS<\/span><span class=\"o\">=<\/span>xxxxxxx\r\n<span class=\"nv\">DB_HOST<\/span><span class=\"o\">=<\/span>go-api.xxxxxxx.ap-northeast-1.rds.amazonaws.com\r\n<span class=\"nv\">DB_NAME<\/span><span class=\"o\">=<\/span>golang\r\n<span class=\"nv\">DB_PORT<\/span><span class=\"o\">=<\/span>3306\r\n<span class=\"nv\">CACHE_HOST1<\/span><span class=\"o\">=<\/span>go-api-dev-memcached-cluster.xxxxxxx.0001.apne1.cache.amazonaws.com:11211\r\n<span class=\"nv\">CACHE_HOST2<\/span><span class=\"o\">=<\/span>go-api-dev-memcached-cluster.xxxxxxx.0002.apne1.cache.amazonaws.com:11211\r\n<\/code><\/pre>\n<h3>\u90e8\u7f72<\/h3>\n<p>\u4f7f\u7528AWS CLI\u7684update-service\u547d\u4ee4\u8fdb\u884c\u90e8\u7f72\u3002\u6267\u884c\u547d\u4ee4\u540e\uff0c\u82e5#\u5728\u72b6\u6001\u68c0\u67e5\u4e2d\u663e\u793a\u4e3aACTIVE\uff0c\u5219\u8868\u793a\u90e8\u7f72\u5b8c\u6210\u3002\u5927\u7ea6\u9700\u89813\u5206\u949f\u7684\u65f6\u95f4\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u30c7\u30d7\u30ed\u30a4<\/span>\r\naws ecs update-service <span class=\"nt\">--cluster<\/span> go-api <span class=\"nt\">--service<\/span> go-api <span class=\"nt\">--task-definition<\/span> go-api <span class=\"nt\">--force-new-deployment<\/span>\r\n\r\n<span class=\"c\"># \u30b9\u30c6\u30fc\u30bf\u30b9\u78ba\u8a8d<\/span>\r\naws ecs describe-services <span class=\"nt\">--cluster<\/span> go-api <span class=\"nt\">--services<\/span> go-api <span class=\"nt\">--query<\/span> <span class=\"s1\">'services[*].status'<\/span> <span class=\"nt\">--output<\/span> text\r\n\r\n<span class=\"o\">&gt;<\/span> ACTIVE\r\n<\/code><\/pre>\n<h3>\u786e\u8ba4\u52a8\u4f5c<\/h3>\n<p>\u4f7f\u7528Terraform\u521b\u5efa\u5b8c\u6210\u540e\u8f93\u51fa\u7684alb_dns\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u30b9\u30ed\u30fc\u30af\u30a8\u30ea<\/span>\r\n curl http:\/\/go-api-xxxxxx.ap-northeast-1.elb.amazonaws.com\/db\/1\r\n<span class=\"o\">&gt;<\/span> <span class=\"o\">{<\/span><span class=\"s2\">\"id\"<\/span>:1,<span class=\"s2\">\"value\"<\/span>:<span class=\"s2\">\"Initial Value\"<\/span>,<span class=\"s2\">\"sleepResult\"<\/span>:0<span class=\"o\">}<\/span>%\r\n\r\n<span class=\"c\"># \u30ad\u30e3\u30c3\u30b7\u30e5<\/span>\r\n curl http:\/\/go-api-xxxxxx.ap-northeast-1.elb.amazonaws.com\/cache\/1\r\n<span class=\"o\">&gt;<\/span> <span class=\"o\">{<\/span><span class=\"s2\">\"id\"<\/span>:1,<span class=\"s2\">\"value\"<\/span>:<span class=\"s2\">\"Initial Value\"<\/span>,<span class=\"s2\">\"sleepResult\"<\/span>:0<span class=\"o\">}<\/span>%\r\n\r\n<\/code><\/pre>\n<h2>\u4f7f\u7528RDS Performance Insight\u8fdb\u884c\u6027\u80fd\u68c0\u67e5\u3002<\/h2>\n<p>RDS\u6027\u80fd\u6d1e\u5bdf\u662fAWS\u63d0\u4f9b\u7684\u4e00\u9879\u529f\u80fd\uff0c\u7528\u4e8e\u53ef\u89c6\u5316\u548c\u8bca\u65ad\u6570\u636e\u5e93\u7684\u6027\u80fd\u95ee\u9898\u3002\u5b83\u4f1a\u5206\u6790SQL\u67e5\u8be2\u7684\u8d1f\u8f7d\u5206\u5e03\uff0c\u4ee5\u4fbf\u786e\u5b9a\u6027\u80fd\u74f6\u9888\u3002<\/p>\n<p>\u5728\u8fd9\u91cc\uff0c\u6211\u4eec\u5c06\u786e\u8ba4db.SQL.Queries.avg\u548cdb.SQL.Com_select.avg\u3002<\/p>\n<pre class=\"post-pre\"><code>\r\n<span class=\"c\"># \u30b9\u30ed\u30fc\u30af\u30a8\u30ea<\/span>\r\nab <span class=\"nt\">-n<\/span> 30 <span class=\"nt\">-c<\/span> 30 http:\/\/go-api-xxxxxx.ap-northeast-1.elb.amazonaws.com\/db\/1\r\n\r\n<span class=\"o\">&gt;<\/span> Benchmarking go-api-xxxxxx.ap-northeast-1.elb.amazonaws.com <span class=\"o\">(<\/span>be patient<span class=\"o\">)<\/span>.....done\r\n\r\n<span class=\"c\"># \u30ad\u30e3\u30c3\u30b7\u30e5<\/span>\r\nab <span class=\"nt\">-n<\/span> 30 <span class=\"nt\">-c<\/span> 30 http:\/\/go-api-xxxxxx.ap-northeast-1.elb.amazonaws.com\/cache\/1\r\n\r\n<span class=\"o\">&gt;<\/span> Benchmarking go-api-xxxxxx.ap-northeast-1.elb.amazonaws.com <span class=\"o\">(<\/span>be patient<span class=\"o\">)<\/span>.....done\r\n\r\n<\/code><\/pre>\n<p>\u7ba1\u7406\u63a7\u5236\u53f0 &gt; RDS &gt; \u6570\u636e\u5e93 &gt; go-api &gt; \u76d1\u63a7 &gt; \u5207\u6362\u5230\u65b0\u7684\u76d1\u63a7\u89c6\u56fe &gt; \u6307\u6807<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d1ed437434c4406c1782b\/125-1.png\" alt=\"undefined\" \/><\/div>\n<p>\u5f53\u6267\u884c\u6162\u67e5\u8be2API\u65f6\u53ef\u4ee5\u786e\u8ba4\u6307\u6807\u90fd\u5728\u4e0a\u5347\u3002\u7136\u540e\u6267\u884c\u7f13\u5b58API\u65f6\u6307\u6807\u51cf\u5c11\u4e86\u3002<\/p>\n<h2>\u5220\u9664\u8d44\u6e90<\/h2>\n<p>\u8bf7\u786e\u4fdd\u5728\u5b8c\u6210\u672c\u7bc7\u6587\u7ae0\u7684\u5b9e\u8df5\u4e4b\u540e\uff0c\u52a1\u5fc5\u8fdb\u884c\u8d44\u6e90\u6e05\u7406\u3002\u5982\u679c\u9700\u8981\u7684\u8bdd\uff0c\u8bf7\u5220\u9664 ECR \u548c SSM Parameter\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u30b3\u30f3\u30c6\u30ca\u3092\u7acb\u3061\u4e0a\u3052\u308b<\/span>\r\ndocker run <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">-v<\/span> ~\/.aws:\/root\/.aws <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">-v<\/span> <span class=\"si\">$(<\/span><span class=\"nb\">pwd<\/span><span class=\"si\">)<\/span>\/.infrastructure:\/terraform <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">-w<\/span> \/terraform <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">-it<\/span> <span class=\"se\">\\<\/span>\r\n  <span class=\"nt\">--entrypoint<\/span><span class=\"o\">=<\/span>ash <span class=\"se\">\\<\/span>\r\n  hashicorp\/terraform:1.5\r\n\r\n<span class=\"c\"># \u524a\u9664<\/span>\r\nterraform destroy\r\n\r\n<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>\u57fa\u7840\u77e5\u8bc6\u7f16 &#8211; Paraphrase in Chinese: \u5165\u95e8\u77e5\u8bc6\u7f16\u8f91 \u5728Web\u7cfb\u7edf\u5f00\u53d1\u4e2d\uff0c\u7406 [&hellip;]<\/p>\n","protected":false},"author":11,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-34715","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\u8c03\u4f18\uff1f - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\u8c03\u4f18\uff1f\" \/>\n<meta property=\"og:description\" content=\"\u57fa\u7840\u77e5\u8bc6\u7f16 &#8211; Paraphrase in Chinese: \u5165\u95e8\u77e5\u8bc6\u7f16\u8f91 \u5728Web\u7cfb\u7edf\u5f00\u53d1\u4e2d\uff0c\u7406 [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-12-08T20:30:26+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-29T05:56:44+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d1ed437434c4406c1782b\/7-1.png\" \/>\n<meta name=\"author\" content=\"\u65b0, \u97f5\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u65b0, \u97f5\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"16 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/\",\"name\":\"\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\u8c03\u4f18\uff1f - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-12-08T20:30:26+00:00\",\"dateModified\":\"2024-04-29T05:56:44+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\u8c03\u4f18\uff1f\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9\",\"name\":\"\u65b0, \u97f5\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g\",\"caption\":\"\u65b0, \u97f5\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/yunxin\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\u8c03\u4f18\uff1f - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\/","og_locale":"zh_CN","og_type":"article","og_title":"\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\u8c03\u4f18\uff1f","og_description":"\u57fa\u7840\u77e5\u8bc6\u7f16 &#8211; Paraphrase in Chinese: \u5165\u95e8\u77e5\u8bc6\u7f16\u8f91 \u5728Web\u7cfb\u7edf\u5f00\u53d1\u4e2d\uff0c\u7406 [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-12-08T20:30:26+00:00","article_modified_time":"2024-04-29T05:56:44+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d1ed437434c4406c1782b\/7-1.png"}],"author":"\u65b0, \u97f5","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u65b0, \u97f5","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"16 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/","name":"\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\u8c03\u4f18\uff1f - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-12-08T20:30:26+00:00","dateModified":"2024-04-29T05:56:44+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u3010\u56fe\u89e3\u3011\u4ec0\u4e48\u662f\u7f13\u5b58\u7b56\u7565\uff1f\u4ec0\u4e48\u662f\u57fa\u4e8e\u7f13\u5b58\u7684\u67e5\u8be2\u8c03\u4f18\uff1f"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/4ba4019495123db3038fd0809e6959c9","name":"\u65b0, \u97f5","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/d484b6c6e4ae82e8a9efea989e1d2af46d9b6ef128101e63b18f559fca0ae627?s=96&d=mm&r=g","caption":"\u65b0, \u97f5"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/yunxin\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e5%9b%be%e8%a7%a3%e3%80%91%e4%bb%80%e4%b9%88%e6%98%af%e7%bc%93%e5%ad%98%e7%ad%96%e7%95%a5%ef%bc%9f%e4%bb%80%e4%b9%88%e6%98%af%e5%9f%ba%e4%ba%8e%e7%bc%93%e5%ad%98%e7%9a%84%e6%9f%a5%e8%af%a2\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/34715","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/11"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=34715"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/34715\/revisions"}],"predecessor-version":[{"id":85682,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/34715\/revisions\/85682"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=34715"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=34715"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=34715"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}