{"id":41057,"date":"2023-09-21T13:59:49","date_gmt":"2023-09-29T04:20:50","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/"},"modified":"2024-05-04T00:53:43","modified_gmt":"2024-05-03T16:53:43","slug":"%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/","title":{"rendered":"\u901a\u8fc7Kibana4\u5bf9Rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528EC2 Amazon Linux\u4f5c\u4e3a\u670d\u52a1\u5668"},"content":{"rendered":"<p>\u7531\u4e8eRails\u548cKibana\u4e2d\u7684\u65b0\u4fe1\u606f\u5c1a\u672a\u6574\u7406\u597d\uff0c\u6240\u4ee5\u6211\u505a\u4e86\u603b\u7ed3\u3002<\/p>\n<h2>\u80fd\u591f\u51fa\u6765\u7684\u4e8b\u60c5 de<\/h2>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Rails log\u306e\u53ef\u8996\u5316<\/ul>\n<\/li>\n<\/ul>\n<p>\u30a2\u30d7\u30ea\u306e\u901f\u5ea6\u306e\u5206\u6790\u3001\u9ad8\u901f\u5316\u306a\u3069\u306b\u4f7f\u3048\u308b<\/p>\n<p>\u30c7\u30d7\u30ed\u30a4\u6642\u306b\u3001\u5404\u7a2e\u6570\u5024\u5909\u5316\u3092\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u3067\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3067\u304d\u308b\uff08\u5207\u308a\u623b\u3057\u306e\u5224\u65ad\uff09<\/p>\n<p>\u30b9\u30c6\u30fc\u30bf\u30b9\u30b3\u30fc\u30c9\u306e\u5272\u5408<br \/>\n\u51e6\u7406\u6642\u9593\u306e\u5206\u5e03<\/p>\n<p>\u30af\u30ed\u30fc\u30e9\u30fc\u3084\u3001PC\u3001\u30b9\u30de\u30d5\u30a9\u306a\u3069\u306e\u30e6\u30fc\u30b6\u30fc\u306e\u52d5\u5411\u3092\u5206\u6790<br \/>\n\u7279\u5b9a\u306e\u30e6\u30fc\u30b6\u30fc\u306e\u884c\u52d5\u3092\u8ffd\u3046\u3053\u3068\u304c\u51fa\u6765\u308b\uff08\u904b\u7528\u4fdd\u5b88\uff09<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d449237434c4406c9fe47\/3-0.png\" alt=\"image\" \/><\/div>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d449237434c4406c9fe47\/4-0.png\" alt=\"image\" \/><\/div>\n<h2>\u7531\u4e8e\u8fd9\u53ea\u662f\u8bd5\u9a8c\uff0c\u6240\u4ee5\u6211\u4eec\u5728\u8bb8\u591a\u65b9\u9762\u4f5c\u51fa\u4e86\u59a5\u534f\u3002<\/h2>\n<p>Kibana 4.4.1 \u548c Elasticsearch 2.2<br \/>\n\u7f51\u7edc\u548c\u5b89\u5168\u7ec4\u8bbe\u7f6e\u7565\u8fc7\u3002<br \/>\n\u524d\u63d0\u6761\u4ef6\u662f\uff1aKibana \u548c Rails \u670d\u52a1\u5668\u5728\u540c\u4e00\u7f51\u7edc\u4e2d\uff0c\u901a\u8fc7\u79c1\u6709IP\u8fdb\u884c\u901a\u4fe1\u3002<\/p>\n<h2>\u51c6\u5907\u5728Rails\u4e0b<\/h2>\n<pre class=\"post-pre\"><code><span class=\"n\">gem<\/span> <span class=\"s2\">\"lograge\"<\/span>        <span class=\"c1\">#elastic_search\u7528 log\u6574\u5f62<\/span>\r\n<span class=\"n\">gem<\/span> <span class=\"s2\">\"logstash-event\"<\/span> <span class=\"c1\">#elastic_serach\u7528\u30ed\u30b0\u3092\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/span>\r\n<span class=\"n\">gem<\/span> <span class=\"s2\">\"rack-user_agent\"<\/span> <span class=\"c1\">#request\u304b\u3089\u3001os, browser\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u304c\u5206\u304b\u308b\uff08\u30ed\u30b0\u306b\u60c5\u5831\u3092\u3060\u3057\u305f\u3044\u305f\u3081\u306b\u5229\u7528\uff09<\/span>\r\n<\/code><\/pre>\n<p>\u53ea\u9700\u4e00\u4e2a\u9009\u9879\uff0c\u7528\u4e2d\u6587\u91cd\u65b0\u8868\u8fbe\u5982\u4e0b\u53e5\u5b50:<br \/>\n\u672c\u6765\u5e94\u8be5\u76f4\u63a5\u5c06\u65e5\u5fd7\u53d1\u9001\u5230fluentd\u4ee3\u7406\uff0c\u4f46\u56e0\u4e3a\u4e0d\u77e5\u9053\u5982\u4f55\u64cd\u4f5c\uff0c\u6240\u4ee5\u6211\u51b3\u5b9a\u5148\u5c06\u65e5\u5fd7\u8f93\u51fa\u5e76\u901a\u8fc7tail\u76d1\u63a7\u4f20\u7ed9fluentd\u3002\u8fd9\u4e9b\u65e5\u5fd7\u662f\u5355\u72ec\u8f93\u51fa\u5230\u53e6\u4e00\u4e2a\u6587\u4ef6\u800c\u4e0d\u662f\u5e38\u89c4\u65e5\u5fd7\u4e2d\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">unless<\/span> <span class=\"no\">Rails<\/span><span class=\"p\">.<\/span><span class=\"nf\">env<\/span><span class=\"p\">.<\/span><span class=\"nf\">test?<\/span> <span class=\"c1\">#\u30c6\u30b9\u30c8\u306e\u6642\u4ee5\u5916\u3092\u60f3\u5b9a<\/span>\r\n  <span class=\"c1\">#fluentd\u304ctail\u3059\u308b\u7528\u306e\u30ed\u30b0\u3092\u8a2d\u5b9a<\/span>\r\n  <span class=\"n\">path<\/span>                                   <span class=\"o\">=<\/span> <span class=\"s2\">\"<\/span><span class=\"si\">#{<\/span><span class=\"no\">Rails<\/span><span class=\"p\">.<\/span><span class=\"nf\">root<\/span><span class=\"si\">}<\/span><span class=\"s2\">\/log\/lograge_<\/span><span class=\"si\">#{<\/span><span class=\"no\">Rails<\/span><span class=\"p\">.<\/span><span class=\"nf\">env<\/span><span class=\"si\">}<\/span><span class=\"s2\">.log\"<\/span>\r\n  <span class=\"c1\">#100M\u3054\u3068\u306b\u6368\u3066\u308b\uff08\u30ed\u30fc\u30c6\u30fc\u30c8\u8a2d\u5b9a\uff09<\/span>\r\n  <span class=\"n\">config<\/span><span class=\"p\">.<\/span><span class=\"nf\">lograge<\/span><span class=\"p\">.<\/span><span class=\"nf\">logger<\/span>                  <span class=\"o\">=<\/span> <span class=\"no\">ActiveSupport<\/span><span class=\"o\">::<\/span><span class=\"no\">Logger<\/span><span class=\"p\">.<\/span><span class=\"nf\">new<\/span><span class=\"p\">(<\/span><span class=\"n\">path<\/span><span class=\"p\">,<\/span> <span class=\"mi\">1<\/span><span class=\"p\">,<\/span> <span class=\"mi\">100<\/span><span class=\"p\">.<\/span><span class=\"nf\">megabytes<\/span><span class=\"p\">)<\/span>\r\n  <span class=\"n\">config<\/span><span class=\"p\">.<\/span><span class=\"nf\">lograge<\/span><span class=\"p\">.<\/span><span class=\"nf\">enabled<\/span>                 <span class=\"o\">=<\/span> <span class=\"kp\">true<\/span>\r\n  <span class=\"n\">config<\/span><span class=\"p\">.<\/span><span class=\"nf\">lograge<\/span><span class=\"p\">.<\/span><span class=\"nf\">keep_original_rails_log<\/span> <span class=\"o\">=<\/span> <span class=\"kp\">true<\/span>\r\n  <span class=\"n\">config<\/span><span class=\"p\">.<\/span><span class=\"nf\">lograge<\/span><span class=\"p\">.<\/span><span class=\"nf\">formatter<\/span>               <span class=\"o\">=<\/span> <span class=\"no\">Lograge<\/span><span class=\"o\">::<\/span><span class=\"no\">Formatters<\/span><span class=\"o\">::<\/span><span class=\"no\">Logstash<\/span><span class=\"p\">.<\/span><span class=\"nf\">new<\/span>\r\n\r\n  <span class=\"n\">config<\/span><span class=\"p\">.<\/span><span class=\"nf\">lograge<\/span><span class=\"p\">.<\/span><span class=\"nf\">custom_options<\/span> <span class=\"o\">=<\/span> <span class=\"nb\">lambda<\/span> <span class=\"k\">do<\/span> <span class=\"o\">|<\/span><span class=\"n\">event<\/span><span class=\"o\">|<\/span>\r\n    <span class=\"n\">opts<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span> <span class=\"ss\">host:            <\/span><span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:host<\/span><span class=\"p\">],<\/span>\r\n             <span class=\"ss\">user_id:         <\/span><span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:user_id<\/span><span class=\"p\">],<\/span>\r\n             <span class=\"ss\">remote_ip:       <\/span><span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:remote_ip<\/span><span class=\"p\">],<\/span>\r\n             <span class=\"ss\">user_agent:      <\/span><span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:user_agent<\/span><span class=\"p\">],<\/span>\r\n             <span class=\"ss\">os:              <\/span><span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:os<\/span><span class=\"p\">],<\/span>\r\n             <span class=\"ss\">os_version:      <\/span><span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:os_version<\/span><span class=\"p\">],<\/span>\r\n             <span class=\"ss\">browser:         <\/span><span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:browser<\/span><span class=\"p\">],<\/span>\r\n             <span class=\"ss\">browser_version: <\/span><span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:browser_version<\/span><span class=\"p\">],<\/span>\r\n             <span class=\"ss\">es:              <\/span><span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:elasticsearch_runtime<\/span><span class=\"p\">],<\/span>\r\n             <span class=\"ss\">category:        <\/span><span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:category_name<\/span><span class=\"p\">],<\/span> <span class=\"c1\">#\u30a2\u30d7\u30ea\u306e\u51fa\u3057\u305f\u3044\u60c5\u5831\u306a\u3069<\/span>\r\n             <span class=\"ss\">time:            <\/span><span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">time<\/span> <span class=\"p\">}<\/span>\r\n\r\n    <span class=\"c1\">#error\u6642\u306e\u30d0\u30c3\u30af\u30c8\u30ec\u30fc\u30b9\u306a\u3093\u304b\u3082\u898b\u308c\u305f\u3089\u4fdd\u5b88\u304c\u4fbf\u5229\u306a\u306e\u3067\u51fa\u3059<\/span>\r\n    <span class=\"k\">if<\/span> <span class=\"n\">stacktrace<\/span> <span class=\"o\">=<\/span> <span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:stacktrace<\/span><span class=\"p\">]<\/span> \r\n      <span class=\"n\">opts<\/span><span class=\"p\">[<\/span><span class=\"ss\">:stacktrace<\/span><span class=\"p\">]<\/span>    <span class=\"o\">=<\/span> <span class=\"n\">stacktrace<\/span>\r\n      <span class=\"n\">opts<\/span><span class=\"p\">[<\/span><span class=\"ss\">:error<\/span><span class=\"p\">]<\/span>         <span class=\"o\">=<\/span> <span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:error<\/span><span class=\"p\">]<\/span>\r\n      <span class=\"n\">opts<\/span><span class=\"p\">[<\/span><span class=\"ss\">:error_message<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"n\">event<\/span><span class=\"p\">.<\/span><span class=\"nf\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:error_message<\/span><span class=\"p\">]<\/span>\r\n    <span class=\"k\">end<\/span>\r\n    <span class=\"n\">opts<\/span>\r\n  <span class=\"k\">end<\/span>\r\n<span class=\"k\">end<\/span>\r\n\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"n\">protect_from_forgery<\/span> <span class=\"c1\">#\u2190\u3053\u306e\u8a18\u8ff0\u306f\u3082\u3068\u3082\u3068\u3042\u308b\u306f\u305a\u3001\u30a2\u30d7\u30ea\u306e\u8981\u4ef6\u306b\u5408\u308f\u305b\u3066\u30aa\u30d7\u30b7\u30e7\u30f3\u3092\u8a18\u8ff0\u3001\u3053\u306e\u8a18\u8ff0\u304c\u306a\u3044\u3068\u30ed\u30b0\u304c\u51fa\u529b\u3055\u308c\u306a\u3044\uff08csrf\u95a2\u9023\u306erails\u306e\u8a2d\u5b9a\uff09<\/span>\r\n\r\n<span class=\"k\">def<\/span> <span class=\"nf\">append_info_to_payload<\/span><span class=\"p\">(<\/span><span class=\"n\">payload<\/span><span class=\"p\">)<\/span>\r\n  <span class=\"k\">super<\/span>\r\n  <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:host<\/span><span class=\"p\">]<\/span>                <span class=\"o\">=<\/span> <span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"nf\">host<\/span>\r\n  <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:user_id<\/span><span class=\"p\">]<\/span>             <span class=\"o\">=<\/span> <span class=\"n\">current_user<\/span><span class=\"p\">.<\/span><span class=\"nf\">try<\/span><span class=\"p\">(<\/span><span class=\"ss\">:id<\/span><span class=\"p\">).<\/span><span class=\"nf\">to_s<\/span>\r\n  <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:remote_ip<\/span><span class=\"p\">]<\/span>           <span class=\"o\">=<\/span> <span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"nf\">remote_ip<\/span>\r\n  <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:user_agent<\/span><span class=\"p\">]<\/span>          <span class=\"o\">=<\/span> <span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"nf\">user_agent<\/span>\r\n  <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:os<\/span><span class=\"p\">]<\/span>                  <span class=\"o\">=<\/span> <span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"nf\">os<\/span>\r\n  <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:os_version<\/span><span class=\"p\">]<\/span>          <span class=\"o\">=<\/span> <span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"nf\">os_version<\/span>\r\n  <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:browser<\/span><span class=\"p\">]<\/span>             <span class=\"o\">=<\/span> <span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"nf\">browser<\/span>\r\n  <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:browser_version<\/span><span class=\"p\">]<\/span>     <span class=\"o\">=<\/span> <span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"nf\">browser_version<\/span>\r\n  <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:category_name<\/span><span class=\"p\">]<\/span>       <span class=\"o\">=<\/span> <span class=\"n\">params<\/span><span class=\"p\">.<\/span><span class=\"nf\">try<\/span><span class=\"p\">(<\/span><span class=\"ss\">:[]<\/span><span class=\"p\">,<\/span> <span class=\"ss\">:category_name<\/span><span class=\"p\">)<\/span> <span class=\"c1\">#\u30a2\u30d7\u30ea\u306e\u51fa\u3057\u305f\u3044\u60c5\u5831<\/span>\r\n<span class=\"k\">end<\/span>\r\n\r\n<\/code><\/pre>\n<p>\u4e3a\u4e86\u8f93\u51fa\u5806\u6808\u8ddf\u8e2a\u4fe1\u606f\uff0c\u6211\u4eec\u4f7f\u7528\u4e86\u4e00\u4e2a\u9488\u5bf9Rails 4.2.5\u7684Monkey Patch\u3002\u5982\u679c\u4f7f\u7528\u5176\u4ed6\u7248\u672c\u7684Rails\uff0c\u8bf7\u786e\u4fdd\u8fdb\u884c\u786e\u8ba4\u3002<br \/>\n\u6211\u4eec\u4fee\u6b63\u4e86\u4f4d\u4e8eactionpack-4.2.5\/lib\/action_controller\/metal\/instrumentation.rb\u4e2d\u8d4b\u503cresponse.status\u7684\u5f02\u5e38\u5904\u7406\u90e8\u5206\uff0c\u5e76\u6dfb\u52a0\u4e86\u989d\u5916\u7684\u4fe1\u606f\u3002<\/p>\n<p>\u6b64\u5916\uff0c\u82e5\u5728\u5f00\u53d1\u73af\u5883\u4e2d\u5347\u7ea7Rails\u7248\u672c\u540e\uff0c\u9700\u8ba9\u5176\u5d29\u6e83\uff08\u56e0\u4e3a\u5982\u679c\u53ea\u6709\u8fd9\u91cc\u4fdd\u6301\u65e7\u72b6\u6001\uff0c\u5e94\u7528\u7a0b\u5e8f\u7684\u8fd0\u884c\u4f1a\u51fa\u73b0\u95ee\u9898\uff09\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">module<\/span> <span class=\"nn\">ActionController<\/span>\r\n  <span class=\"k\">module<\/span> <span class=\"nn\">Instrumentation<\/span>\r\n    <span class=\"k\">def<\/span> <span class=\"nf\">process_action<\/span><span class=\"p\">(<\/span><span class=\"o\">*<\/span><span class=\"n\">args<\/span><span class=\"p\">)<\/span>\r\n      <span class=\"k\">if<\/span> <span class=\"no\">Rails<\/span><span class=\"p\">.<\/span><span class=\"nf\">env<\/span><span class=\"p\">.<\/span><span class=\"nf\">development?<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"no\">Rails<\/span><span class=\"p\">.<\/span><span class=\"nf\">version<\/span> <span class=\"o\">!=<\/span> <span class=\"s2\">\"4.2.5\"<\/span>\r\n        <span class=\"k\">raise<\/span> <span class=\"s2\">\"#\uff12\uff10\u5e74\u5f8c\u306e\u50d5\u3078\u30014.2.5\u306e\u6642\u306egem\u306e\u5185\u5bb9\u3092\u30b3\u30d4\u30fc\u3057\u3066\u6301\u3063\u3066\u304d\u3066\u3044\u307e\u3059.\u30d0\u30fc\u30b8\u30e7\u30f3\u304c\u3042\u304c\u3063\u305f\u3089\u78ba\u8a8d\u3057\u3066, \u5909\u66f4\u304c\u3042\u308c\u3070\u30b3\u30d4\u30fc\u3057\u3066\u4e0b\u3055\u3044\u3002actionpack-4.2.5\/lib\/action_controller\/metal\/instrumentation.rb\"<\/span>\r\n      <span class=\"k\">end<\/span>\r\n      <span class=\"n\">raw_payload<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"ss\">controller: <\/span><span class=\"nb\">self<\/span><span class=\"p\">.<\/span><span class=\"nf\">class<\/span><span class=\"p\">.<\/span><span class=\"nf\">name<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"ss\">action: <\/span><span class=\"nb\">self<\/span><span class=\"p\">.<\/span><span class=\"nf\">action_name<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"ss\">params: <\/span><span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"nf\">filtered_parameters<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"ss\">format: <\/span><span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"nf\">format<\/span><span class=\"p\">.<\/span><span class=\"nf\">try<\/span><span class=\"p\">(<\/span><span class=\"ss\">:ref<\/span><span class=\"p\">),<\/span>\r\n        <span class=\"ss\">method: <\/span><span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"nf\">request_method<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"ss\">path: <\/span><span class=\"p\">(<\/span><span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"nf\">fullpath<\/span> <span class=\"k\">rescue<\/span> <span class=\"s2\">\"unknown\"<\/span><span class=\"p\">)<\/span>\r\n      <span class=\"p\">}<\/span>\r\n\r\n      <span class=\"no\">ActiveSupport<\/span><span class=\"o\">::<\/span><span class=\"no\">Notifications<\/span><span class=\"p\">.<\/span><span class=\"nf\">instrument<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"start_processing.action_controller\"<\/span><span class=\"p\">,<\/span> <span class=\"n\">raw_payload<\/span><span class=\"p\">.<\/span><span class=\"nf\">dup<\/span><span class=\"p\">)<\/span>\r\n\r\n      <span class=\"no\">ActiveSupport<\/span><span class=\"o\">::<\/span><span class=\"no\">Notifications<\/span><span class=\"p\">.<\/span><span class=\"nf\">instrument<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"process_action.action_controller\"<\/span><span class=\"p\">,<\/span> <span class=\"n\">raw_payload<\/span><span class=\"p\">)<\/span> <span class=\"k\">do<\/span> <span class=\"o\">|<\/span><span class=\"n\">payload<\/span><span class=\"o\">|<\/span>\r\n        <span class=\"k\">begin<\/span>\r\n          <span class=\"n\">result<\/span> <span class=\"o\">=<\/span> <span class=\"k\">super<\/span>\r\n          <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:status<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"n\">response<\/span><span class=\"p\">.<\/span><span class=\"nf\">status<\/span>\r\n          <span class=\"n\">result<\/span>\r\n        <span class=\"k\">rescue<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"n\">e<\/span>\r\n          <span class=\"c1\">#kibana\u3067stack_trace\u3092\u898b\u308b\u305f\u3081\u306b\u62e1\u5f35\u3057\u3066\u3044\u308b\u3001\u4ed6\u306f\u305d\u306e\u307e\u307e<\/span>\r\n          <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:error<\/span><span class=\"p\">]<\/span>         <span class=\"o\">=<\/span> <span class=\"n\">e<\/span><span class=\"p\">.<\/span><span class=\"nf\">class<\/span><span class=\"p\">.<\/span><span class=\"nf\">name<\/span>\r\n          <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:error_message<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"n\">e<\/span><span class=\"p\">.<\/span><span class=\"nf\">message<\/span>\r\n          <span class=\"n\">payload<\/span><span class=\"p\">[<\/span><span class=\"ss\">:stacktrace<\/span><span class=\"p\">]<\/span>    <span class=\"o\">=<\/span> <span class=\"n\">e<\/span><span class=\"p\">.<\/span><span class=\"nf\">backtrace<\/span><span class=\"p\">.<\/span><span class=\"nf\">join<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"<\/span><span class=\"se\">\\n\\t<\/span><span class=\"s2\">\"<\/span><span class=\"p\">)<\/span>\r\n          <span class=\"k\">raise<\/span>\r\n        <span class=\"k\">ensure<\/span>\r\n          <span class=\"n\">append_info_to_payload<\/span><span class=\"p\">(<\/span><span class=\"n\">payload<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"k\">end<\/span>\r\n      <span class=\"k\">end<\/span>\r\n    <span class=\"k\">end<\/span>\r\n  <span class=\"k\">end<\/span>\r\n<span class=\"k\">end<\/span>\r\n\r\n<\/code><\/pre>\n<p>\u5982\u679c\u8fd0\u884cRails\u5e94\u7528\uff0c\u5e94\u8be5\u4f1a\u8f93\u51fa\u65e5\u5fd7\u3002<br \/>\n\u4f7f\u7528jq\u6267\u884ctail\u547d\u4ee4\u6765\u786e\u8ba4\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nb\">tail<\/span> <span class=\"nt\">-f<\/span> log\/lograge_development.log | jq <span class=\"s2\">\".\"<\/span>\r\n<\/code><\/pre>\n<h2>\u5728AWS\u4e2d\u51c6\u5907\u597d(Elasticsearch Kibana\u7684EC2\u5b9e\u4f8b)\u3002<\/h2>\n<p>\u5728\u521b\u5efa\u4e9a\u9a6c\u900a Linux\u5b9e\u4f8b\u65f6\uff0c\u8bf7\u6ce8\u610f\u865a\u62df\u5316\u5b58\u50a8\uff08\u5982Amazon\u5f39\u6027\u5757\u5b58\u50a8\uff09\u3002\u865a\u62df\u5316\u5b58\u50a8\u5bf9\u4e8eElasticsearch\u7684\u8fd0\u884c\u6765\u8bf4\u5df2\u7ecf\u8db3\u591f\u3002\u800c\u4e14\uff0c\u5b83\u4eec\u975e\u5e38\u5bb9\u6613\u4e14\u5feb\u901f\u5730\u51c6\u5907\u597d\u4f7f\u7528\uff0c\u8fd9\u4f7f\u5176\u76f8\u5f53\u5438\u5f15\u4eba\u3002\u7136\u800c\uff0c\u4e0e\u672c\u5730\u5b58\u50a8\u76f8\u6bd4\uff0c\u865a\u62df\u5316\u5b58\u50a8\u5728\u672c\u8d28\u4e0a\u8f83\u6162\u3002<\/p>\n<p>\u56e0\u6b64\uff0c\u6211\u5efa\u8bae\u6269\u5c55\u6839\u5b58\u50a8\u3002<br \/>\n\u6682\u65f6\u5c06\u6839\u5b58\u50a8\u8bbe\u4e3a20GB\uff0c\u8fdb\u884c\u4e0b\u4e00\u6b65\u3002<\/p>\n<pre class=\"post-pre\"><code>$ sudo yum update -y\r\n<\/code><\/pre>\n<p>\u5c06\u65f6\u95f4\u8bbe\u5b9a\u4e3a\u65e5\u672c\u65f6\u95f4\u3002<\/p>\n<pre class=\"post-pre\"><code>$ sudo vim \/etc\/sysconfig\/clock\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"n\">ZONE<\/span>=<span class=\"s2\">\"Asia\/Tokyo\"<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code>$ sudo ln -sf \/usr\/share\/zoneinfo\/Asia\/Tokyo \/etc\/localtime\r\n$ sudo reboot\r\n<\/code><\/pre>\n<p>\u5b89\u88c5 Elasticsearch 2.2<\/p>\n<pre class=\"post-pre\"><code>sudo yum -y install java-1.8.0-openjdk-devel.x86_64\r\nsudo rpm --import https:\/\/packages.elastic.co\/GPG-KEY-elasticsearch\r\nsudo vim \/etc\/yum.repos.d\/elasticsearch.repo\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code>[<span class=\"n\">elasticsearch<\/span>-<span class=\"m\">2<\/span>.<span class=\"n\">x<\/span>]\r\n<span class=\"n\">name<\/span>=<span class=\"n\">Elasticsearch<\/span> <span class=\"n\">repository<\/span> <span class=\"n\">for<\/span> <span class=\"m\">2<\/span>.<span class=\"n\">x<\/span> <span class=\"n\">packages<\/span>\r\n<span class=\"n\">baseurl<\/span>=<span class=\"n\">http<\/span>:\/\/<span class=\"n\">packages<\/span>.<span class=\"n\">elastic<\/span>.<span class=\"n\">co<\/span>\/<span class=\"n\">elasticsearch<\/span>\/<span class=\"m\">2<\/span>.<span class=\"n\">x<\/span>\/<span class=\"n\">centos<\/span>\r\n<span class=\"n\">gpgcheck<\/span>=<span class=\"m\">1<\/span>\r\n<span class=\"n\">gpgkey<\/span>=<span class=\"n\">http<\/span>:\/\/<span class=\"n\">packages<\/span>.<span class=\"n\">elastic<\/span>.<span class=\"n\">co<\/span>\/<span class=\"n\">GPG<\/span>-<span class=\"n\">KEY<\/span>-<span class=\"n\">elasticsearch<\/span>\r\n<span class=\"n\">enabled<\/span>=<span class=\"m\">1<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code>sudo yum install elasticsearch -y\r\nsudo vim \/etc\/elasticsearch\/elasticsearch.yml\r\n<\/code><\/pre>\n<p>\u5982\u679c\u4e0d\u8fdb\u884c\u6b64\u8bbe\u7f6e\uff0c\u5c31\u65e0\u6cd5\u4ece\u5916\u90e8\u7f51\u7edc\u8fdb\u884c\u8fde\u63a5\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"n\">cluster<\/span>.<span class=\"n\">name<\/span>: <span class=\"n\">kibana_cluster<\/span> <span class=\"c\">#\u9069\u5f53\u306b\u540d\u524d\u3064\u3051\u3068\u304f\r\n<\/span><span class=\"n\">network<\/span>.<span class=\"n\">host<\/span>: <span class=\"n\">xxxx<\/span>.<span class=\"n\">xxxx<\/span>.<span class=\"n\">xxx<\/span>.<span class=\"n\">xxx<\/span> <span class=\"c\">#elasticsearch\u30b5\u30fc\u30d0\u30fc\u306eip\r\n<\/span><span class=\"n\">http<\/span>.<span class=\"n\">port<\/span>: <span class=\"m\">9200<\/span>\r\n<\/code><\/pre>\n<p>\u542f\u52a8<\/p>\n<pre class=\"post-pre\"><code>sudo \/etc\/init.d\/elasticsearch start\r\n<\/code><\/pre>\n<p>\u786e\u8ba4<\/p>\n<pre class=\"post-pre\"><code>curl localhost:9200\r\n<\/code><\/pre>\n<p>\u5b89\u88c5\u63d2\u4ef6\uff08\u6839\u636e\u4e2a\u4eba\u559c\u597d\uff09<\/p>\n<pre class=\"post-pre\"><code>sudo \/usr\/share\/elasticsearch\/bin\/plugin install analysis-kuromoji\r\nsudo \/usr\/share\/elasticsearch\/bin\/plugin install mobz\/elasticsearch-head\r\nsudo \/usr\/share\/elasticsearch\/bin\/plugin install royrusso\/elasticsearch-HQ\r\nsudo \/etc\/init.d\/elasticsearch restart\r\n<\/code><\/pre>\n<p>\u5b89\u88c5Kibana 4.4.1\u7248\u672c\u3002<\/p>\n<pre class=\"post-pre\"><code>curl -L -O https:\/\/download.elastic.co\/kibana\/kibana\/kibana-4.4.1-linux-x64.tar.gz\r\ntar xzvf kibana-4.4.1-linux-x64.tar.gz\r\nvim kibana-4.4.1-linux-x64\/config\/kibana.yml\r\n<\/code><\/pre>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d449237434c4406c9fe47\/39-0.png\" alt=\"image\" \/><\/div>\n<p>\u786e\u8ba4\u52a8\u4f5c<\/p>\n<pre class=\"post-pre\"><code>.\/kibana-4.4.1-linux-x64\/bin\/kibana\r\n<\/code><\/pre>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d449237434c4406c9fe47\/42-0.png\" alt=\"image\" \/><\/div>\n<p>\u7531\u4e8e\u4e3a\u4e86\u542f\u52a8\u80cc\u666f\u670d\u52a1\u800c\u4f7f\u7528Nginx\u6709\u70b9\u9ebb\u70e6\uff0c\u6682\u65f6\u5148\u59a5\u534f\u4e00\u4e0b\u3002<\/p>\n<pre class=\"post-pre\"><code>sudo .\/kibana-4.4.1-linux-x64\/bin\/kibana  &gt; .\/kibana.log &amp;\r\n<\/code><\/pre>\n<p>\u5728\u4e2d\u6587\u5b57\u7b26\u4e0a\uff0c\u8fd9\u662f\u5173\u4e8eKibana\u8fd0\u884c\u6d4b\u8bd5\u7684\u8868\u8fbe\uff1ahttp:\/\/xxxx.xxxx.xxxx.xxxx:5601\/<\/p>\n<h2>\u51c6\u5907\u8fd0\u884c\u5728EC2\u4e0a\u7684Rails\u7684fluentd\u3002<\/h2>\n<p>\u5b89\u88c5Fluentd<\/p>\n<pre class=\"post-pre\"><code>sudo vi \/etc\/yum.repos.d\/treasuredata.repo\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code>[<span class=\"n\">treasuredata<\/span>]\r\n<span class=\"n\">name<\/span>=<span class=\"n\">TreasureData<\/span>\r\n<span class=\"n\">baseurl<\/span>=<span class=\"n\">http<\/span>:\/\/<span class=\"n\">packages<\/span>.<span class=\"n\">treasure<\/span>-<span class=\"n\">data<\/span>.<span class=\"n\">com<\/span>\/<span class=\"n\">redhat<\/span>\/$<span class=\"n\">basearch<\/span>\r\n<span class=\"n\">gpgcheck<\/span>=<span class=\"m\">0<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code>sudo yum install td-agent -y\r\nsudo chkconfig td-agent on\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code>sudo \/usr\/lib64\/fluent\/ruby\/bin\/fluent-gem install --no-ri --no-rdoc fluent-plugin-elasticsearch\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code>sudo vim \/etc\/td-agent\/td-agent.conf\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">&lt;source&gt;<\/span>\r\n  type     tail\r\n  format   json\r\n  tag      rails\r\n  path     \/path\/to\/log\/lograge_production.log\r\n  pos_file \/path\/to\/log\/lograge_production.log.pos\r\n  time_key time\r\n<span class=\"nt\">&lt;\/source&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;match<\/span> <span class=\"err\">rails<\/span><span class=\"nt\">&gt;<\/span>\r\n  type elasticsearch\r\n  retry_limit 5\r\n  host xxxx.xxxx.xxxx.xxxx #elasticsearch ip\r\n  port 9200\r\n  logstash_format true\r\n  logstash_prefix lograge\r\n  flush_interval  1s\r\n<span class=\"nt\">&lt;\/match&gt;<\/span>\r\n<\/code><\/pre>\n<p>\u7531\u4e8e\u5728\u6743\u9650\u65b9\u9762\u542f\u52a8\u4f1a\u5bfc\u81f4\u5d29\u6e83\uff0c\u56e0\u6b64\u9700\u8981\u66f4\u6539fluentd\u4ee5\u4ee5root\u6743\u9650\u8fd0\u884c\u3002<\/p>\n<pre class=\"post-pre\"><code>sudo vim \/etc\/init.d\/td-agent\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"gd\">- DAEMON_ARGS=${DAEMON_ARGS---user td-agent}\r\n<\/span><span class=\"gi\">+ DAEMON_ARGS=${DAEMON_ARGS---user root}\r\n<\/span><span class=\"p\">TD_AGENT_ARGS=\"${TD_AGENT_ARGS-\/usr\/sbin\/td-agent --user root --group td-agent --log \/var\/log\/td-agent\/td-agent.log}\"\r\n<\/span><\/code><\/pre>\n<p>\u5f00\u673a<\/p>\n<pre class=\"post-pre\"><code>sudo \/etc\/init.d\/td-agent start\r\n# \u5fc5\u305astatus\u3067\u8d77\u52d5\u72b6\u614b\u3092\u78ba\u8a8d\u3059\u308b\r\nsudo \/etc\/init.d\/td-agent status\r\n<\/code><\/pre>\n<p>\u5982\u679c\u72b6\u6001\u786e\u8ba4\u5931\u8d25\uff0c\u6211\u4f1a\u67e5\u770b\u65e5\u5fd7<\/p>\n<pre class=\"post-pre\"><code>less \/var\/log\/td-agent\/td-agent.log\r\n<\/code><\/pre>\n<p>\u5982\u679c\u4f60\u80fd\u505a\u5230\u8fd9\u4e00\u70b9\uff0c\u90a3\u4e48\u53ea\u8981Rails\u8fd0\u884c\uff0c\u65e5\u5fd7\u5c31\u4f1a\u5b58\u50a8\u5230elasticsearch\u4e2d\uff0c\u5e76\u4e14\u5e94\u8be5\u53ef\u4ee5\u5728kibana\u4e2d\u67e5\u770b\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d449237434c4406c9fe47\/62-0.png\" alt=\"image\" \/><\/div>\n<h2>\u7ed9\u51fa\u7684\u94fe\u63a5\u548c\u5907\u5fd8\u5f55\u662f\u63d0\u4f9b\u53c2\u8003\u7684\u3002<\/h2>\n<p>\u5982\u679c\u4f7f\u7528logstash-logger\uff0c\u53ef\u80fd\u4e0d\u9700\u8981\u4f7f\u7528tail\u547d\u4ee4\u6765\u5b8c\u6210\u3002<br \/>\n\u5173\u4e8estacktrace\u7684\u90e8\u5206\uff0c\u8bf7\u53c2\u8003Gist\u3002<br \/>\n\u5728Qiita\u4e0a\uff0c\u6709\u5173\u4e8e\u5728Lograge\u4e2d\u8fdb\u884cRails\u65e5\u5fd7\u8bb0\u5f55\u7684\u4fe1\u606f\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u7531\u4e8eRails\u548cKibana\u4e2d\u7684\u65b0\u4fe1\u606f\u5c1a\u672a\u6574\u7406\u597d\uff0c\u6240\u4ee5\u6211\u505a\u4e86\u603b\u7ed3\u3002 \u80fd\u591f\u51fa\u6765\u7684\u4e8b\u60c5 de Rails log\u306e [&hellip;]<\/p>\n","protected":false},"author":9,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-41057","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>\u901a\u8fc7Kibana4\u5bf9Rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528EC2 Amazon Linux\u4f5c\u4e3a\u670d\u52a1\u5668 - 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\/\u901a\u8fc7kibana4\u5bf9rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528ec2-amazon-linux\u4f5c\u4e3a\u670d\u52a1\u5668\u3002\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u901a\u8fc7Kibana4\u5bf9Rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528EC2 Amazon Linux\u4f5c\u4e3a\u670d\u52a1\u5668\" \/>\n<meta property=\"og:description\" content=\"\u7531\u4e8eRails\u548cKibana\u4e2d\u7684\u65b0\u4fe1\u606f\u5c1a\u672a\u6574\u7406\u597d\uff0c\u6240\u4ee5\u6211\u505a\u4e86\u603b\u7ed3\u3002 \u80fd\u591f\u51fa\u6765\u7684\u4e8b\u60c5 de Rails log\u306e [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u901a\u8fc7kibana4\u5bf9rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528ec2-amazon-linux\u4f5c\u4e3a\u670d\u52a1\u5668\u3002\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-09-29T04:20:50+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-05-03T16:53:43+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d449237434c4406c9fe47\/3-0.png\" \/>\n<meta name=\"author\" content=\"\u6e05, \u626c\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u6e05, \u626c\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"4 \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\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/\",\"name\":\"\u901a\u8fc7Kibana4\u5bf9Rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528EC2 Amazon Linux\u4f5c\u4e3a\u670d\u52a1\u5668 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-09-29T04:20:50+00:00\",\"dateModified\":\"2024-05-03T16:53:43+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/cb5556d2501da73d864cac945e8d9461\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u901a\u8fc7Kibana4\u5bf9Rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528EC2 Amazon Linux\u4f5c\u4e3a\u670d\u52a1\u5668\"}]},{\"@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\/cb5556d2501da73d864cac945e8d9461\",\"name\":\"\u6e05, \u626c\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/32a4239de8ff29adace466261d309424a1e5fe9f7e3036bf89fe03f2e3dbe717?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/32a4239de8ff29adace466261d309424a1e5fe9f7e3036bf89fe03f2e3dbe717?s=96&d=mm&r=g\",\"caption\":\"\u6e05, \u626c\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/qingyang\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u901a\u8fc7Kibana4\u5bf9Rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528EC2 Amazon Linux\u4f5c\u4e3a\u670d\u52a1\u5668 - 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\/\u901a\u8fc7kibana4\u5bf9rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528ec2-amazon-linux\u4f5c\u4e3a\u670d\u52a1\u5668\u3002\/","og_locale":"zh_CN","og_type":"article","og_title":"\u901a\u8fc7Kibana4\u5bf9Rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528EC2 Amazon Linux\u4f5c\u4e3a\u670d\u52a1\u5668","og_description":"\u7531\u4e8eRails\u548cKibana\u4e2d\u7684\u65b0\u4fe1\u606f\u5c1a\u672a\u6574\u7406\u597d\uff0c\u6240\u4ee5\u6211\u505a\u4e86\u603b\u7ed3\u3002 \u80fd\u591f\u51fa\u6765\u7684\u4e8b\u60c5 de Rails log\u306e [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u901a\u8fc7kibana4\u5bf9rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528ec2-amazon-linux\u4f5c\u4e3a\u670d\u52a1\u5668\u3002\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-09-29T04:20:50+00:00","article_modified_time":"2024-05-03T16:53:43+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d449237434c4406c9fe47\/3-0.png"}],"author":"\u6e05, \u626c","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u6e05, \u626c","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"4 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/","name":"\u901a\u8fc7Kibana4\u5bf9Rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528EC2 Amazon Linux\u4f5c\u4e3a\u670d\u52a1\u5668 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-09-29T04:20:50+00:00","dateModified":"2024-05-03T16:53:43+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/cb5556d2501da73d864cac945e8d9461"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u901a\u8fc7Kibana4\u5bf9Rails\u5e94\u7528\u8fdb\u884c\u53ef\u89c6\u5316\uff0c\u4f7f\u7528EC2 Amazon Linux\u4f5c\u4e3a\u670d\u52a1\u5668"}]},{"@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\/cb5556d2501da73d864cac945e8d9461","name":"\u6e05, \u626c","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/32a4239de8ff29adace466261d309424a1e5fe9f7e3036bf89fe03f2e3dbe717?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/32a4239de8ff29adace466261d309424a1e5fe9f7e3036bf89fe03f2e3dbe717?s=96&d=mm&r=g","caption":"\u6e05, \u626c"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/qingyang\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%80%9a%e8%bf%87kibana4%e5%af%b9rails%e5%ba%94%e7%94%a8%e8%bf%9b%e8%a1%8c%e5%8f%af%e8%a7%86%e5%8c%96%ef%bc%8c%e4%bd%bf%e7%94%a8ec2-amazon-linux%e4%bd%9c%e4%b8%ba%e6%9c%8d%e5%8a%a1%e5%99%a8%e3%80%82\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/41057","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\/9"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=41057"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/41057\/revisions"}],"predecessor-version":[{"id":95132,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/41057\/revisions\/95132"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=41057"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=41057"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=41057"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}