{"id":1773,"date":"2008-09-28T18:43:24","date_gmt":"2008-09-28T10:43:24","guid":{"rendered":"http:\/\/ihower.idv.tw\/blog\/?p=1773"},"modified":"2015-09-05T10:53:21","modified_gmt":"2015-09-05T02:53:21","slug":"handle-rails-exception","status":"publish","type":"post","link":"https:\/\/ihower.tw\/blog\/1773-handle-rails-exception","title":{"rendered":"\u4e3b\u52d5\u6514\u622a Rails exception \u932f\u8aa4"},"content":{"rendered":"<p><img decoding=\"async\" data-attachment-id=\"1774\" data-permalink=\"https:\/\/ihower.tw\/blog\/1773-handle-rails-exception\/rails-500\" data-orig-file=\"https:\/\/ihower.tw\/blog\/wp-content\/uploads\/2008\/09\/rails-500.png\" data-orig-size=\"586,153\" data-comments-opened=\"1\" data-image-meta=\"{&quot;aperture&quot;:&quot;0&quot;,&quot;credit&quot;:&quot;&quot;,&quot;camera&quot;:&quot;&quot;,&quot;caption&quot;:&quot;&quot;,&quot;created_timestamp&quot;:&quot;0&quot;,&quot;copyright&quot;:&quot;&quot;,&quot;focal_length&quot;:&quot;0&quot;,&quot;iso&quot;:&quot;0&quot;,&quot;shutter_speed&quot;:&quot;0&quot;,&quot;title&quot;:&quot;&quot;}\" data-image-title=\"rails-500\" data-image-description=\"\" data-image-caption=\"\" data-medium-file=\"https:\/\/ihower.tw\/blog\/wp-content\/uploads\/2008\/09\/rails-500-300x78.png\" data-large-file=\"https:\/\/ihower.tw\/blog\/wp-content\/uploads\/2008\/09\/rails-500.png\" src=\"\/blog\/wp-content\/uploads\/2008\/09\/rails-500.png\" alt=\"\" title=\"rails-500\" width=\"440\" class=\"aligncenter size-full wp-image-1774\" srcset=\"https:\/\/ihower.tw\/blog\/wp-content\/uploads\/2008\/09\/rails-500.png 586w, https:\/\/ihower.tw\/blog\/wp-content\/uploads\/2008\/09\/rails-500-300x78.png 300w\" sizes=\"(max-width: 586px) 100vw, 586px\" \/><\/p>\n<p>\u5594\uff0c\u70b8\u4e86\u3002<\/p>\n<p>\u76f8\u4fe1\u4ee5\u4e0a\u756b\u9762\u5927\u5bb6\u90fd\u4e0d\u964c\u751f\uff0c\u9019\u662f\u4e00\u500b\u6a19\u6e96\u7684 Rails app \u932f\u8aa4\u9801\u9762\u3002\u96d6\u7136\u6211\u5011\u52aa\u529b\u907f\u514d\uff0c\u4f46\u7e3d\u662f\u6709\u51fa\u932f\u7684\u6642\u5019\uff0c\u4e00\u500b\u4e0a production mode \u7684\u5c08\u696d Rails app \u7d55\u4e0d\u6703\u75f4\u75f4\u5730\u7b49\u5f85\u4f7f\u7528\u8005\u544a\u8a34\u4f60\u7db2\u7ad9\u70b8\u4e86\uff0c\u800c\u662f\u8981\u80fd\u5920\u4e3b\u52d5\u901a\u77e5\u53ca\u7d00\u9304\u4e0b\u9019\u500b\u932f\u8aa4\u4f8b\u5916(exception)\uff0c\u597d\u8b93\u6211\u53ef\u4ee5 trace error\u3001fixed bug \u751a\u81f3\u5728\u767c\u751f\u932f\u8aa4\u6c92\u591a\u4e45\u5c31\u53ef\u4ee5 E-mail \u544a\u8a34\u9019\u4f4d\u4f7f\u7528\u8005\u82e6\u4e3b\u767c\u751f\u4e86\u4ec0\u9ebc\u4e8b\u60c5\u3002<\/p>\n<p>\u89e3\u6cd5\u6709\u5e7e\u7a2e\uff1a<\/p>\n<ol>\n<li>\u5b89\u88dd <a href=\"http:\/\/github.com\/rails\/exception_notification\/tree\">exceiption_notifition<\/a>\uff0c\u9019\u662f\u500b\u5b98\u65b9\u7684\u57fa\u672c Plugin \uff0c\u5b83\u6703\u5728\u767c\u751f\u4f8b\u5916\u6642\u5bc4 email \u901a\u77e5\u4f60(\u5011)\u3002<\/p>\n<\/li>\n<li>\n<p>\u5b89\u88dd <a href=\"http:\/\/github.com\/defunkt\/exception_logger\/tree\/master\">ExceptionLogger<\/a> (\u4f5c\u8005 defunkt \u4e5f\u662f <a href=\"http:\/\/famspam.com\/facebox\">facebox<\/a> \u7684\u4f5c\u8005 :p )\uff0c\u9019\u500b  Plugin \u6703\u7d00\u9304\u5230 database\uff0c\u4e26\u63d0\u4f9b\u4e00\u500b\u5f8c\u53f0\u53ef\u4ee5\u700f\u89bd\u3002\u4e0d\u904e\u9019\u500b\u5f8c\u53f0\u88dd\u8d77\u4f86\u6bd4\u8f03\u9ebb\u7169\uff0c\u4f8b\u5982\u4f60\u9084\u5f97\u8655\u7406\u700f\u89bd\u6b0a\u9650\u7b49\u7b49\u3002<\/p>\n<\/li>\n<li>\n<p>\u4f7f\u7528 <a href=\"http:\/\/www.hoptoadapp.com\/welcome\">Hoptoad<\/a> \u7b2c\u4e09\u65b9\u670d\u52d9\uff0c\u9019\u662f\u500b\u7531\u77e5\u540dRails\u5718\u968a <a href=\"http:\/\/www.thoughtbot.com\/\">thoughtbot<\/a> \u6240\u63d0\u4f9b\u7684 Web service\u3002\u7533\u8acb\u5e33\u865f\u4e4b\u5f8c\u53ef\u4ee5\u62ff\u5230 API key \u53ca Plugin\uff0c\u65bc\u662f\u4f60\u7684\u7db2\u7ad9\u767c\u751f exception \u7684\u6642\u5019\u5c31\u6703\u81ea\u52d5\u5c07\u932f\u8aa4\u8a0a\u606f\u9001\u5230 Hoptoad \u6536\u96c6\u8d77\u4f86\u3002Hoptoad \u63d0\u4f9b\u4e86\u9084\u883b\u4e0d\u932f\u7684\u5f8c\u53f0\u53ef\u4ee5\u700f\u89bd\u3002\u9019\u500b\u89e3\u6cd5\u5b89\u88dd\u6700\u7c21\u55ae\uff0c\u529f\u80fd\u53c8\u5f88\u5920\u7528\uff0c\u9084\u53ef\u4ee5\u7d71\u8a08\u53ca\u8ffd\u8e64\u4f8b\u5916\u8655\u7406\u7684\u60c5\u6cc1\uff0c\u6211\u500b\u4eba\u5341\u5206\u63a8\u85a6\u4f7f\u7528\u3002<\/p>\n<\/li>\n<\/ol>\n<p>github \u4e0a\u61c9\u8a72\u9084\u6709\u5176\u4ed6\u7684 Plugins \u53ef\u4ee5\u5e6b\u52a9\u4f60\u8655\u7406\u9019\u500b\u554f\u984c\u3002anyway&#8230; \u6700\u7cdf\u7684\u5c31\u662f\u4ec0\u9ebc\u90fd\u4e0d\u505a\uff0c\u8b93\u4f7f\u7528\u8005\u544a\u8a34\u4f60\u6709\u6771\u897f\u70b8\u4e86\uff0c\u7136\u5f8c\u4f60\u518d\u53bb\u722c\u53bb\u627e log \u6a94 :)<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u5594\uff0c\u70b8\u4e86\u3002 \u76f8\u4fe1\u4ee5\u4e0a\u756b\u9762\u5927\u5bb6\u90fd\u4e0d\u964c\u751f\uff0c\u9019\u662f\u4e00\u500b\u6a19\u6e96\u7684 Rails app \u932f\u8aa4\u9801\u9762\u3002\u96d6\u7136\u6211\u5011\u52aa\u529b\u907f\u514d\uff0c\u4f46\u7e3d\u662f\u6709 &hellip; <\/p>\n<p class=\"link-more\"><a href=\"https:\/\/ihower.tw\/blog\/1773-handle-rails-exception\" class=\"more-link\">\u95b1\u8b80\u5168\u6587<span class=\"screen-reader-text\">\u3008\u4e3b\u52d5\u6514\u622a Rails exception \u932f\u8aa4\u3009<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":false,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"font":"","enabled":false},"version":2}},"categories":[68,53],"tags":[],"class_list":["post-1773","post","type-post","status-publish","format-standard","hentry","category-devops","category-rails","entry"],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack_shortlink":"https:\/\/wp.me\/p1q6tG-sB","jetpack_sharing_enabled":true,"jetpack_likes_enabled":true,"_links":{"self":[{"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/posts\/1773","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/comments?post=1773"}],"version-history":[{"count":3,"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/posts\/1773\/revisions"}],"predecessor-version":[{"id":8311,"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/posts\/1773\/revisions\/8311"}],"wp:attachment":[{"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/media?parent=1773"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/categories?post=1773"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/tags?post=1773"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}