{"id":1668,"date":"2019-07-22T17:00:26","date_gmt":"2019-07-22T08:00:26","guid":{"rendered":"http:\/\/idealive.jp\/blog\/?p=1668"},"modified":"2019-07-18T16:47:58","modified_gmt":"2019-07-18T07:47:58","slug":"laravel-amazon-cloud-watch-logs","status":"publish","type":"post","link":"https:\/\/idealive.jp\/blog\/2019\/07\/22\/laravel-amazon-cloud-watch-logs\/","title":{"rendered":"Laravel &amp; Amazon CloudWatch Logs"},"content":{"rendered":"<p>\u3069\u3046\u3082\u3053\u3093\u306b\u3061\u306f<\/p>\n<p>Laravel\u304b\u3089\u51fa\u529b\u3055\u308c\u308b\u30ed\u30b0\u3092\u3001<br \/>\n\u30d5\u30a1\u30a4\u30eb\u3082\u4f5c\u3089\u305aAmazon CouldWatch Logs\u306b\u6295\u3052\u3064\u3051\u308b\u65b9\u6cd5\u306a\u3044\u304b\u306a\u30fc\u3001<br \/>\n\u3068\u601d\u3063\u3066\u3044\u305f\u3089\u3001\u5148\u4eba\u305f\u3061\u306f\u3084\u3063\u3066\u3044\u308b\u3082\u306e\u3067\u3059\u306d\u3001\u3042\u308a\u307e\u3057\u305f\u3002<\/p>\n<blockquote><p>\u3053\u3061\u3089\u3092\u53c2\u8003\u306b\uff08\u307b\u307c\u30d1\u30af\u30ea\uff09\u5b9f\u88c5\u3057\u307e\u3057\u305f\u3002<\/p>\n<p><a href=\"https:\/\/stackoverflow.com\/questions\/50814388\/laravel-5-6-aws-cloudwatch-log\" target=\"_blank\" rel=\"noopener\">https:\/\/stackoverflow.com\/questions\/50814388\/laravel-5-6-aws-cloudwatch-log<\/a><\/p><\/blockquote>\n<p>\u304a\u6c7a\u307e\u308a\u306e\u3088\u3046\u3067\u3059\u304c\u3001\u4eca\u56de\u3082 Laravel 5.8 \u3067\u304a\u9001\u308a\u3057\u307e\u3059\u3002<\/p>\n<hr \/>\n<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_82_2 counter-hierarchy ez-toc-counter ez-toc-grey ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\">\n<p class=\"ez-toc-title\" style=\"cursor:inherit\">\u76ee\u6b21<\/p>\n<span class=\"ez-toc-title-toggle\"><\/span><\/div>\n<nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-5'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/idealive.jp\/blog\/2019\/07\/22\/laravel-amazon-cloud-watch-logs\/#%E4%BA%8B%E5%89%8D%E6%BA%96%E5%82%99\" >\u4e8b\u524d\u6e96\u5099<\/a><ul class='ez-toc-list-level-6' ><li class='ez-toc-heading-level-6'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/idealive.jp\/blog\/2019\/07\/22\/laravel-amazon-cloud-watch-logs\/#IAM%E3%83%A6%E3%83%BC%E3%82%B6\" >IAM\u30e6\u30fc\u30b6<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-6'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/idealive.jp\/blog\/2019\/07\/22\/laravel-amazon-cloud-watch-logs\/#%E3%83%A9%E3%82%A4%E3%83%96%E3%83%A9%E3%83%AA%E3%82%A4%E3%83%B3%E3%82%B9%E3%83%88%E3%83%BC%E3%83%AB\" >\u30e9\u30a4\u30d6\u30e9\u30ea\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-5'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/idealive.jp\/blog\/2019\/07\/22\/laravel-amazon-cloud-watch-logs\/#%E5%AE%9F%E8%A3%85\" >\u5b9f\u88c5<\/a><ul class='ez-toc-list-level-6' ><li class='ez-toc-heading-level-6'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/idealive.jp\/blog\/2019\/07\/22\/laravel-amazon-cloud-watch-logs\/#%E3%83%AD%E3%82%AC%E3%83%BC%E3%82%AF%E3%83%A9%E3%82%B9\" >\u30ed\u30ac\u30fc\u30af\u30e9\u30b9<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-6'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/idealive.jp\/blog\/2019\/07\/22\/laravel-amazon-cloud-watch-logs\/#configloggingphp\" >config\/logging.php<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-6'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/idealive.jp\/blog\/2019\/07\/22\/laravel-amazon-cloud-watch-logs\/#env\" >.env<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-5'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/idealive.jp\/blog\/2019\/07\/22\/laravel-amazon-cloud-watch-logs\/#%E5%AE%9F%E8%A1%8C%E3%81%97%E3%81%A6%E3%81%BF%E3%82%8B\" >\u5b9f\u884c\u3057\u3066\u307f\u308b<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-5'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/idealive.jp\/blog\/2019\/07\/22\/laravel-amazon-cloud-watch-logs\/#%E3%81%BE%E3%81%A8%E3%82%81\" >\u307e\u3068\u3081<\/a><\/li><\/ul><\/nav><\/div>\n<h5><span class=\"ez-toc-section\" id=\"%E4%BA%8B%E5%89%8D%E6%BA%96%E5%82%99\"><\/span>\u4e8b\u524d\u6e96\u5099<span class=\"ez-toc-section-end\"><\/span><\/h5>\n<h6><span class=\"ez-toc-section\" id=\"IAM%E3%83%A6%E3%83%BC%E3%82%B6\"><\/span>IAM\u30e6\u30fc\u30b6<span class=\"ez-toc-section-end\"><\/span><\/h6>\n<p>Amazon CloudWatch Logs \u3092\u4f7f\u3046\u306e\u3067\u3001\u5f53\u7136\u306e\u3088\u3046\u306bIAM\u30e6\u30fc\u30b6\u3092\u7528\u610f\u3057\u307e\u3059\u3002<br \/>\n<code>CloudWatchFullAccess<\/code>\u6a29\u9650\u3092\u6301\u3063\u3066\u3044\u308bIAM\u30e6\u30fc\u30b6\u3092\u4f5c\u6210\u3057\u3001<br \/>\n\u30a2\u30af\u30bb\u30b9\u30ad\u30fc\u3068\u30b7\u30fc\u30af\u30ec\u30c3\u30c8\u30a2\u30af\u30bb\u30b9\u30ad\u30fc\u3092\u53d6\u5f97\u3057\u3066\u304a\u304d\u307e\u3057\u3087\u3046\u3002<br \/>\n\u3082\u3057\u304b\u3057\u305f\u3089\u3001<code>CloudWatchLogsFullAccess<\/code>\u3067\u3082\u3088\u304b\u3063\u305f\u306e\u304b\u3057\u3089\u3002\u3002\u3002<\/p>\n<h6><span class=\"ez-toc-section\" id=\"%E3%83%A9%E3%82%A4%E3%83%96%E3%83%A9%E3%83%AA%E3%82%A4%E3%83%B3%E3%82%B9%E3%83%88%E3%83%BC%E3%83%AB\"><\/span>\u30e9\u30a4\u30d6\u30e9\u30ea\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<span class=\"ez-toc-section-end\"><\/span><\/h6>\n<p>composer\u7d4c\u7531\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3059\u3002<br \/>\n<code>composer require maxbanton\/cwh<\/code><br \/>\n\u3053\u308c\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u3068\u3001\u4f9d\u5b58\u95a2\u4fc2\u3067<br \/>\naws\/aws-sdk-php<br \/>\nmonolog\/monolog<br \/>\n\u3082\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u308c\u307e\u3059\uff08monolog\/monolog\u306b\u3064\u3044\u3066\u306f\u3001laravel\u306e\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u306e\u6642\u70b9\u3067\u5165\u3063\u3066\u307e\u3059\u304c\uff09\u3002<\/p>\n<hr \/>\n<h5><span class=\"ez-toc-section\" id=\"%E5%AE%9F%E8%A3%85\"><\/span>\u5b9f\u88c5<span class=\"ez-toc-section-end\"><\/span><\/h5>\n<h6><span class=\"ez-toc-section\" id=\"%E3%83%AD%E3%82%AC%E3%83%BC%E3%82%AF%E3%83%A9%E3%82%B9\"><\/span>\u30ed\u30ac\u30fc\u30af\u30e9\u30b9<span class=\"ez-toc-section-end\"><\/span><\/h6>\n<p>\u307e\u305a\u306f\u3053\u306e\u30af\u30e9\u30b9\u3092\u4f5c\u308a\u307e\u3059\u3002<br \/>\n\u4fdd\u5b58\u5148\u306f\u3069\u3053\u3067\u3082\u3088\u3044\u306e\u3060\u3068\u601d\u3046\u306e\u3067\u3059\u304c\u3001\u4eca\u56de\u306fApp\\Logger\\CloudWatchLogger.php\u3067\u3059\u3002<\/p>\n<pre class=\"lang:default decode:true\">&lt;?php\r\n\r\nnamespace App\\Logging;\r\n\r\nuse Aws\\CloudWatchLogs\\CloudWatchLogsClient;\r\nuse Maxbanton\\Cwh\\Handler\\CloudWatch;\r\nuse Monolog\\Logger;\r\n\r\nclass CloudWatchLogger\r\n{\r\n    \/**\r\n     * Create a custom Monolog instance.\r\n     *\r\n     * @param  array  $config\r\n     * @return \\Monolog\\Logger\r\n     *\/\r\n    public function __invoke(array $config)\r\n    {\r\n        $sdkParams = $config[\"sdk\"];\r\n        $tags = $config[\"tags\"] ?? [ ];\r\n        $name = $config[\"name\"] ?? 'cloudwatch';\r\n\r\n        \/\/ Instantiate AWS SDK CloudWatch Logs Client\r\n        $client = new CloudWatchLogsClient($sdkParams);\r\n\r\n        \/\/ Log group name, will be created if none\r\n        $groupName = config('app.name') . '-' . config('app.env');\r\n\r\n        \/\/ Log stream name, will be created if none\r\n        try {\r\n            $instance_id = file_get_contents(\"http:\/\/169.254.169.254\/latest\/meta-data\/instance-id\"); \/\/ &lt;- \u203b\uff11\r\n        } catch (\\Exception $e) {\r\n            $instance_id = null;\r\n        }\r\n        $streamName = $instance_id ?? config('app.hostname', 'localhost'); \/\/ &lt;- \u203b\uff12\r\n\r\n        \/\/ Days to keep logs, 14 by default. Set to `null` to allow indefinite retention.\r\n        $retentionDays = $config[\"retention\"];\r\n\r\n        \/\/ Instantiate handler (tags are optional)\r\n        $handler = new CloudWatch($client, $groupName, $streamName, $retentionDays, 10000, $tags);\r\n\r\n        \/\/ Create a log channel\r\n        $logger = new Logger($name);\r\n        \/\/ Set handler\r\n        $logger-&gt;pushHandler($handler);\r\n\r\n        return $logger;\r\n    }\r\n\r\n}<\/pre>\n<p>\u203b\uff11<br \/>\n\u4eca\u56de\u306f\u3001\u30b9\u30c8\u30ea\u30fc\u30e0\u540d\u306bEC2\u306e\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9ID\u3092\u4f7f\u3044\u305f\u304b\u3063\u305f\u306e\u3067\u3001\u3053\u3093\u306a\u5f62\u306b\u3057\u3066\u3044\u307e\u3059\u3002<br \/>\nEC2\u304b\u3089\u30a2\u30af\u30bb\u30b9\u3057\u306a\u3044\u5834\u5408\uff08\u30ed\u30fc\u30ab\u30eb\u306e\u958b\u767a\u74b0\u5883\u3068\u304b\uff09\u306f\u3001\u3053\u3053\u3067\u30a8\u30e9\u30fc\u306b\u306a\u3063\u3061\u3083\u3046\u306e\u3067<br \/>\ntry-catch\u3067\u56f2\u3063\u3066\u307e\u3059\u3002<\/p>\n<p>\u203b\uff12<br \/>\n\u53c2\u8003\u30b5\u30a4\u30c8\u306b\u306f\u3001config\u304b\u3089\u8fd4\u5374\u3059\u308b\u30c7\u30d5\u30a9\u30eb\u30c8\u5024\u306f\u8a2d\u5b9a\u3057\u3066\u307e\u305b\u3093\u3002<br \/>\n\u4f55\u3082\u8003\u3048\u305a\u306b\u3084\u3063\u3066\u3044\u308b\u3068\u3001app.hostname\u3068\u3044\u3046\u8a2d\u5b9a\u5024\u306f\u3069\u3053\u306b\u3082\u306a\u3044\u306e\u3067<br \/>\nCloudWatch\u5074\u3067\u30b9\u30c8\u30ea\u30fc\u30e0\u304c\u4f5c\u3089\u308c\u306a\u304f\u3066\u5c0f\u4e00\u6642\u9593\u56f0\u3063\u3066\u307e\u3057\u305f\u3002<br \/>\n\u306a\u306e\u3067\u3001\u5c11\u306a\u304f\u3068\u3082localhost\u304c\u8fd4\u3063\u3066\u304f\u308b\u3088\u3046\u306b\u3057\u307e\u3057\u305f\u3002<\/p>\n<h6><span class=\"ez-toc-section\" id=\"configloggingphp\"><\/span>config\/logging.php<span class=\"ez-toc-section-end\"><\/span><\/h6>\n<p>\u30c1\u30e3\u30cd\u30eb\u3092\u4f5c\u308a\u307e\u3059\u3002config\/logging.php \u306e channels \u306b\u3001\u4ee5\u4e0b\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<br \/>\n\u30ed\u30ac\u30fc\u30af\u30e9\u30b9\u306e\u53c2\u7167\u5148\u306f\u3001\u9069\u5b9c\u3002<\/p>\n<pre class=\"lang:default decode:true \">        'cloudwatch' =&gt; [\r\n            'driver' =&gt; 'custom',\r\n            'via' =&gt; \\App\\Logging\\CloudWatchLogger::class, \/\/ &lt;- \u4e0a\u3067\u4f5c\u6210\u3057\u305f\u30ed\u30ac\u30fc\u30af\u30e9\u30b9\r\n            'sdk' =&gt; [\r\n                'region' =&gt; env('AWS_DEFAULT_REGION', 'us-east-1'),\r\n                'version' =&gt; 'latest',\r\n                'credentials' =&gt; [\r\n                    'key' =&gt; env('AWS_ACCESS_KEY_ID'),\r\n                    'secret' =&gt; env('AWS_SECRET_ACCESS_KEY')\r\n                ]\r\n            ],\r\n            'retention' =&gt; env('CLOUDWATCH_LOG_RETENTION', 7), \/\/ &lt;- \u30ed\u30b0\u4fdd\u5b58\u671f\u9593\uff08null \u306e\u5834\u5408\u306f\u7121\u5236\u9650\uff09\r\n        ],\r\n<\/pre>\n<h6><span class=\"ez-toc-section\" id=\"env\"><\/span>.env<span class=\"ez-toc-section-end\"><\/span><\/h6>\n<p>.env\u30d5\u30a1\u30a4\u30eb\u3092\u66f8\u304d\u63db\u3048\u307e\u3059\u3002<br \/>\n\u74b0\u5883\u3054\u3068\u306b\u4f5c\u6210\u3057\u3066\u3044\u308b\u5834\u5408\u306f\u3001\u9069\u5b9c\u8aad\u307f\u66ff\u3048\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<pre class=\"lang:default decode:true\">LOG_CHANNEL=cloudwatch # \u30c7\u30d5\u30a9\u30eb\u30c8\u3092CloudWatch Logs\u306b\u3059\u308b\u5834\u5408\u306f\u3001\u3053\u3061\u3089\u3092\u8a2d\u5b9a\r\n\r\nAWS_ACCESS_KEY_ID=XXXXXXXXXXXXXXXXXXXXX # IAM\u30e6\u30fc\u30b6\u306e\u30a2\u30af\u30bb\u30b9\u30ad\u30fc\r\nAWS_SECRET_ACCESS_KEY=XXXXXXXXXXXXXXXXXXXXX # IAM\u30e6\u30fc\u30b6\u306e\u30b7\u30fc\u30af\u30ec\u30c3\u30c8\u30a2\u30af\u30bb\u30b9\u30ad\u30fc\r\nAWS_DEFAULT_REGION=ap-northeast-1 # CloudWatch Logs\u306e\u30ea\u30fc\u30b8\u30e7\u30f3 ap-northeast-1 \u306f\u6771\u4eac\r\n<\/pre>\n<hr \/>\n<h5><span class=\"ez-toc-section\" id=\"%E5%AE%9F%E8%A1%8C%E3%81%97%E3%81%A6%E3%81%BF%E3%82%8B\"><\/span>\u5b9f\u884c\u3057\u3066\u307f\u308b<span class=\"ez-toc-section-end\"><\/span><\/h5>\n<p>\u4e0b\u306e\u3088\u3046\u306a\u611f\u3058\u3067\u30ed\u30b0\u3092\u51fa\u529b\u3059\u308b\u3068\u3001<br \/>\n\u3042\u3089\u4e0d\u601d\u8b70\u3001CloudWatch Logs\u306b\u51fa\u529b\u3055\u308c\u3066\u3044\u307e\u3059\u3002<br \/>\n\u203bAWS\u30b3\u30f3\u30bd\u30fc\u30eb\u306e\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8\u306f\u3054\u52d8\u5f01\u3092\u3002<\/p>\n<pre class=\"lang:default decode:true\">use Illuminate\\Support\\Facades\\Log;\r\n\r\npublic function outputLogs()\r\n{\r\n    Log::debug('debug message!');\r\n    Log::info('info message!');\r\n    Log::warning('warning message!');\r\n    Log::error('error message!');\r\n    Log::emergency('emergency message!');\r\n}\r\n<\/pre>\n<p>&nbsp;<\/p>\n<hr \/>\n<h5><span class=\"ez-toc-section\" id=\"%E3%81%BE%E3%81%A8%E3%82%81\"><\/span>\u307e\u3068\u3081<span class=\"ez-toc-section-end\"><\/span><\/h5>\n<p>\u3042\u3068\u306f\u3001\u30ed\u30b0\u3092S3\u306b\u5b9a\u671f\u7684\u306b\u79fb\u3057\u3066\u3042\u3052\u305f\u308a\u3001\u306a\u3093\u3060\u3063\u305f\u308a\u3002<br \/>\nEC2\u306b\u4f59\u8a08\u306a\u30d5\u30a1\u30a4\u30eb\u3092\u5897\u3084\u3057\u305f\u304f\u306a\u3044\u4e00\u5fc3\u3060\u3063\u305f\u306e\u3067\u3001<br \/>\n\u76ee\u7684\u306f\u9054\u6210\u3067\u3059\u3002<\/p>\n<p>r.tanaka\u304c\u304a\u5c4a\u3051\u3057\u307e\u3057\u305f\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u3069\u3046\u3082\u3053\u3093\u306b\u3061\u306f Laravel\u304b\u3089\u51fa\u529b\u3055\u308c\u308b\u30ed\u30b0\u3092\u3001 \u30d5\u30a1\u30a4\u30eb\u3082\u4f5c\u3089\u305aAmazon CouldWatch Logs\u306b\u6295\u3052\u3064\u3051\u308b\u65b9\u6cd5\u306a\u3044\u304b\u306a\u30fc\u3001 \u3068\u601d\u3063\u3066\u3044\u305f\u3089\u3001\u5148\u4eba\u305f\u3061\u306f\u3084\u3063\u3066\u3044\u308b\u3082\u306e\u3067\u3059\u306d\u3001\u3042\u308a\u307e\u3057\u305f\u3002 \u3053\u3061\u3089\u3092\u53c2\u8003&#8230;<a class=\"read-more-link button\" href=\"https:\/\/idealive.jp\/blog\/2019\/07\/22\/laravel-amazon-cloud-watch-logs\/\">\u7d9a\u304d\u3092\u8aad\u3080<\/a><\/p>\n","protected":false},"author":4,"featured_media":685,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[20,19],"tags":[],"class_list":["post-1668","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-laravel","category-php"],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/posts\/1668"}],"collection":[{"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/users\/4"}],"replies":[{"embeddable":true,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/comments?post=1668"}],"version-history":[{"count":7,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/posts\/1668\/revisions"}],"predecessor-version":[{"id":1675,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/posts\/1668\/revisions\/1675"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/media\/685"}],"wp:attachment":[{"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/media?parent=1668"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/categories?post=1668"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/idealive.jp\/blog\/wp-json\/wp\/v2\/tags?post=1668"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}