{"id":1593,"date":"2025-03-24T08:50:19","date_gmt":"2025-03-23T23:50:19","guid":{"rendered":"https:\/\/dexall.co.jp\/articles\/?p=1593"},"modified":"2025-03-24T08:50:19","modified_gmt":"2025-03-23T23:50:19","slug":"%e3%80%90%e5%ae%9f%e8%b7%b5%e3%82%ac%e3%82%a4%e3%83%89%e3%80%91sidekiq%e3%81%a7%e5%ae%9f%e7%8f%be%e3%81%99%e3%82%8b%e9%ab%98%e6%80%a7%e8%83%bd%e3%81%aa%e9%9d%9e%e5%90%8c%e6%9c%9f%e5%87%a6%e7%90%86","status":"publish","type":"post","link":"https:\/\/dexall.co.jp\/articles\/?p=1593","title":{"rendered":"\u3010\u5b9f\u8df5\u30ac\u30a4\u30c9\u3011Sidekiq\u3067\u5b9f\u73fe\u3059\u308b\u9ad8\u6027\u80fd\u306a\u975e\u540c\u671f\u51e6\u7406 -\u5c0e\u5165\u304b\u3089\u904b\u7528\u307e\u3067\u5b8c\u5168\u89e3\u8aac"},"content":{"rendered":"\n<div class=\"toc\"><br \/>\n<b>Warning<\/b>:  Undefined array key \"is_admin\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>116<\/b><br \/>\n<br \/>\n<b>Warning<\/b>:  Undefined array key \"is_category_top\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>121<\/b><br \/>\n<br \/>\n<b>Warning<\/b>:  Undefined array key \"is_top\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>128<\/b><br \/>\n    <div id=\"toc_container\" class=\"sgb-toc--bullets js-smooth-scroll\" data-dialog-title=\"\u76ee\u6b21\">\n      <p class=\"toc_title\">\u76ee\u6b21 <\/p>\n      <ul class=\"toc_list\">  <li class=\"first\">    <a href=\"#i-0\">Sidekiq\u3068\u306f \u2013 \u30d0\u30c3\u30af\u30b0\u30e9\u30a6\u30f3\u30c9\u30b8\u30e7\u30d6\u51e6\u7406\u306e\u4e3b\u529b\u30c4\u30fc\u30eb<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-1\">Ruby\u30a8\u30b3\u30b7\u30b9\u30c6\u30e0\u306b\u304a\u3051\u308b\u30d0\u30c3\u30af\u30b0\u30e9\u30a6\u30f3\u30c9\u30b8\u30e7\u30d6\u306e\u91cd\u8981\u6027<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-2\">Sidekiq\u304c\u9078\u3070\u308c\u308b3\u3064\u306e\u7406\u7531<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-3\">Sidekiq\u306e\u5c0e\u5165\u3068\u57fa\u672c\u8a2d\u5b9a<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-4\">Gemfile\u3078\u306e\u8ffd\u52a0\u3068\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u624b\u9806<\/a>      <\/li>      <li>        <a href=\"#i-5\">Redis\u306e\u8a2d\u5b9a\u3068Sidekiq\u306e\u8d77\u52d5\u65b9\u6cd5<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-6\">\u57fa\u672c\u7684\u306aWorker\u30af\u30e9\u30b9\u306e\u5b9f\u88c5\u4f8b<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-7\">\u52b9\u7387\u7684\u306a\u30b8\u30e7\u30d6\u7ba1\u7406\u3068\u30ad\u30e5\u30fc\u8a2d\u8a08<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-8\">\u8907\u6570\u306e\u30ad\u30e5\u30fc\u306e\u6d3b\u7528\u3068\u30d7\u30e9\u30a4\u30aa\u30ea\u30c6\u30a3\u8a2d\u5b9a<\/a>      <\/li>      <li>        <a href=\"#i-9\">Worker\u30af\u30e9\u30b9\u306e\u6b63\u3057\u3044\u8a2d\u8a08\u30d1\u30bf\u30fc\u30f3<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-10\">\u30ea\u30c8\u30e9\u30a4\u6226\u7565\u3068\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-11\">Sidekiq\u306e\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3068\u904b\u7528\u7ba1\u7406<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-12\">Web\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u8a2d\u5b9a\u3068\u6d3b\u7528\u6cd5<\/a>      <\/li>      <li>        <a href=\"#i-13\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-14\">\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u306e\u5177\u4f53\u7684\u306a\u624b\u9806<\/a>      <\/li>    <\/ul>  <\/li>  <li class=\"last\">    <a href=\"#i-15\">Sidekiq\u3092\u7528\u3044\u305f\u5927\u898f\u6a21\u30b7\u30b9\u30c6\u30e0\u306e\u69cb\u7bc9<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-16\">\u30b9\u30b1\u30fc\u30e9\u30d3\u30ea\u30c6\u30a3\u3092\u8003\u616e\u3057\u305f\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u8a2d\u8a08<\/a>      <\/li>      <li>        <a href=\"#i-17\">\u9ad8\u53ef\u7528\u6027\u3092\u5b9f\u73fe\u3059\u308b\u305f\u3081\u306e\u5177\u4f53\u7684\u306a\u65bd\u7b56<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-18\">\u672c\u756a\u74b0\u5883\u3067\u306e\u904b\u7528\u30ce\u30a6\u30cf\u30a6<\/a>      <\/li>    <\/ul>  <\/li><\/ul>\n      <a href=\"#\" class=\"sgb-toc-button js-toc-button\" rel=\"nofollow\" data-open-dialog=\"true\"><i class=\"fa fa-list\"><\/i><span class=\"sgb-toc-button__text\">\u76ee\u6b21\u3078<\/span><\/a>\n    <\/div><\/div><h2 class=\"wp-block-heading\" id=\"i-0\">Sidekiq\u3068\u306f \u2013 \u30d0\u30c3\u30af\u30b0\u30e9\u30a6\u30f3\u30c9\u30b8\u30e7\u30d6\u51e6\u7406\u306e\u4e3b\u529b\u30c4\u30fc\u30eb<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-1\">Ruby\u30a8\u30b3\u30b7\u30b9\u30c6\u30e0\u306b\u304a\u3051\u308b\u30d0\u30c3\u30af\u30b0\u30e9\u30a6\u30f3\u30c9\u30b8\u30e7\u30d6\u306e\u91cd\u8981\u6027<\/h3>\n\n\n\n<p>Web\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u958b\u767a\u306b\u304a\u3044\u3066\u3001\u30d0\u30c3\u30af\u30b0\u30e9\u30a6\u30f3\u30c9\u30b8\u30e7\u30d6\u51e6\u7406\u306f\u975e\u5e38\u306b\u91cd\u8981\u306a\u8981\u7d20\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002\u7279\u306bRuby\u30a8\u30b3\u30b7\u30b9\u30c6\u30e0\u3067\u306f\u3001\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u3092\u640d\u306a\u308f\u306a\u3044\u305f\u3081\u306b\u3001\u6642\u9593\u306e\u304b\u304b\u308b\u51e6\u7406\u3092\u975e\u540c\u671f\u3067\u5b9f\u884c\u3059\u308b\u3053\u3068\u304c\u4e00\u822c\u7684\u306a\u5b9f\u8df5\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30d0\u30c3\u30af\u30b0\u30e9\u30a6\u30f3\u30c9\u30b8\u30e7\u30d6\u51e6\u7406\u304c\u5fc5\u8981\u3068\u306a\u308b\u4e3b\u306a\u30b1\u30fc\u30b9\uff1a<\/p>\n\n\n<div id=\"id-4b5d59f7-5447-41b2-94e0-e6dd3113c140\">\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th>\u30e6\u30fc\u30b9\u30b1\u30fc\u30b9<\/th><th>\u5177\u4f53\u4f8b<\/th><th>\u30e1\u30ea\u30c3\u30c8<\/th><\/tr><\/thead><tbody><tr><td>\u5927\u91cf\u30e1\u30fc\u30eb\u9001\u4fe1<\/td><td>\u30cb\u30e5\u30fc\u30b9\u30ec\u30bf\u30fc\u914d\u4fe1\u3001\u901a\u77e5\u30e1\u30fc\u30eb<\/td><td>\u30e6\u30fc\u30b6\u30fc\u306e\u5f85\u3061\u6642\u9593\u3092\u524a\u6e1b<\/td><\/tr><tr><td>\u30c7\u30fc\u30bf\u96c6\u8a08\u51e6\u7406<\/td><td>\u6708\u6b21\u30ec\u30dd\u30fc\u30c8\u4f5c\u6210\u3001\u30ed\u30b0\u89e3\u6790<\/td><td>\u30b7\u30b9\u30c6\u30e0\u306e\u5fdc\u7b54\u6027\u3092\u7dad\u6301<\/td><\/tr><tr><td>\u5916\u90e8API\u9023\u643a<\/td><td>\u6c7a\u6e08\u51e6\u7406\u3001\u30c7\u30fc\u30bf\u540c\u671f<\/td><td>\u5916\u90e8\u30b5\u30fc\u30d3\u30b9\u306e\u9045\u5ef6\u5f71\u97ff\u3092\u8efd\u6e1b<\/td><\/tr><tr><td>\u753b\u50cf\u30fb\u52d5\u753b\u51e6\u7406<\/td><td>\u30b5\u30e0\u30cd\u30a4\u30eb\u751f\u6210\u3001\u52d5\u753b\u30a8\u30f3\u30b3\u30fc\u30c9<\/td><td>\u30ea\u30bd\u30fc\u30b9\u96c6\u4e2d\u578b\u51e6\u7406\u306e\u5206\u6563\u5316<\/td><\/tr><\/tbody><\/table><\/figure>\n<\/div>\n\n\n<h3 class=\"wp-block-heading\" id=\"i-2\">Sidekiq\u304c\u9078\u3070\u308c\u308b3\u3064\u306e\u7406\u7531<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u512a\u308c\u305f\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3068\u52b9\u7387\u6027<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Redis\u3092\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u306b\u4f7f\u7528\u3057\u3001\u9ad8\u901f\u306a\u51e6\u7406\u3092\u5b9f\u73fe<\/li>\n\n\n\n<li>\u30de\u30eb\u30c1\u30b9\u30ec\u30c3\u30c9\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u306b\u3088\u308a\u3001\u5c11\u306a\u3044\u30e1\u30e2\u30ea\u3067\u591a\u6570\u306e\u30b8\u30e7\u30d6\u3092\u51e6\u7406<\/li>\n\n\n\n<li>\u30c7\u30d5\u30a9\u30eb\u30c8\u306725\u500b\u306e\u30b9\u30ec\u30c3\u30c9\u3092\u4f7f\u7528\u3057\u3001\u52b9\u7387\u7684\u306a\u30ea\u30bd\u30fc\u30b9\u5229\u7528\u3092\u5b9f\u73fe<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u67d4\u8edf\u306a\u8a2d\u5b9a\u3068\u30b9\u30b1\u30fc\u30e9\u30d3\u30ea\u30c6\u30a3<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u512a\u5148\u5ea6\u306b\u5fdc\u3058\u305f\u8907\u6570\u306e\u30ad\u30e5\u30fc\u8a2d\u5b9a\u304c\u53ef\u80fd<\/li>\n\n\n\n<li>Redis\u30af\u30e9\u30b9\u30bf\u30ea\u30f3\u30b0\u306b\u3088\u308b\u6c34\u5e73\u30b9\u30b1\u30fc\u30ea\u30f3\u30b0\u306e\u30b5\u30dd\u30fc\u30c8<\/li>\n\n\n\n<li>\u30a8\u30f3\u30bf\u30fc\u30d7\u30e9\u30a4\u30ba\u7248\u3067\u306f\u66f4\u306b\u9ad8\u5ea6\u306a\u6a5f\u80fd\u3092\u63d0\u4f9b<\/li>\n<\/ul>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   # \u30ad\u30e5\u30fc\u306e\u512a\u5148\u5ea6\u8a2d\u5b9a\u4f8b\n   Sidekiq.configure_server do |config|\n     config.redis = { url: 'redis:\/\/localhost:6379\/0' }\n     # \u512a\u5148\u5ea6\u306e\u9ad8\u3044\u30ad\u30e5\u30fc\u304b\u3089\u9806\u306b\u51e6\u7406\n     config.queues = ['critical', 'high', 'default', 'low']\n   end<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u5145\u5b9f\u3057\u305f\u904b\u7528\u652f\u63f4\u6a5f\u80fd<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Web UI\u306b\u3088\u308b\u76f4\u89b3\u7684\u306a\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0<\/li>\n\n\n\n<li>\u8a73\u7d30\u306a\u30e1\u30c8\u30ea\u30af\u30b9\u53ce\u96c6\u3068\u53ef\u8996\u5316<\/li>\n\n\n\n<li>\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u3068\u30ea\u30c8\u30e9\u30a4\u6a5f\u80fd<\/li>\n<\/ul>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   # \u30ea\u30c8\u30e9\u30a4\u8a2d\u5b9a\u4f8b\n   class ImportantJob\n     include Sidekiq::Worker\n     sidekiq_options retry: 5  # \u30ea\u30c8\u30e9\u30a4\u56de\u6570\u30925\u56de\u306b\u8a2d\u5b9a\n\n     def perform(args)\n       # \u91cd\u8981\u306a\u51e6\u7406\n     rescue StandardError =&gt; e\n       logger.error \"\u30a8\u30e9\u30fc\u767a\u751f: #{e.message}\"\n       raise # \u30ea\u30c8\u30e9\u30a4\u306e\u305f\u3081\u30a8\u30e9\u30fc\u3092\u518d\u5ea6\u767a\u751f\n     end\n   end<\/pre>\n\n\n\n<p>Sidekiq\u306f\u3001\u3053\u308c\u3089\u306e\u7279\u5fb4\u306b\u3088\u308a\u3001\u5c0f\u898f\u6a21\u306a\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u304b\u3089\u5927\u898f\u6a21\u306a\u30a8\u30f3\u30bf\u30fc\u30d7\u30e9\u30a4\u30ba\u30b7\u30b9\u30c6\u30e0\u307e\u3067\u3001\u5e45\u5e83\u3044\u5834\u9762\u3067\u63a1\u7528\u3055\u308c\u3066\u3044\u307e\u3059\u3002\u7279\u306b\u3001\u9ad8\u3044\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3068\u904b\u7528\u6027\u306e\u4e21\u7acb\u304c\u6c42\u3081\u3089\u308c\u308b\u73fe\u4ee3\u306eWeb\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u958b\u767a\u306b\u304a\u3044\u3066\u3001Sidekiq\u306f\u975e\u5e38\u306b\u91cd\u8981\u306a\u30c4\u30fc\u30eb\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-3\">Sidekiq\u306e\u5c0e\u5165\u3068\u57fa\u672c\u8a2d\u5b9a<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-4\">Gemfile\u3078\u306e\u8ffd\u52a0\u3068\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u624b\u9806<\/h3>\n\n\n\n<p>Sidekiq\u306e\u5c0e\u5165\u306f\u3001\u4ed6\u306eRubygem\u3068\u540c\u69d8\u306b\u7c21\u5358\u306b\u884c\u3048\u307e\u3059\u3002\u307e\u305a\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306eGemfile\u306b\u5fc5\u8981\u306a\u4f9d\u5b58\u95a2\u4fc2\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># Gemfile\ngem 'sidekiq', '~&gt; 7.0'  # \u6700\u65b0\u306e\u5b89\u5b9a\u7248\u3092\u4f7f\u7528\ngem 'redis', '~&gt; 5.0'    # Redis\u30af\u30e9\u30a4\u30a2\u30f3\u30c8<\/pre>\n\n\n\n<p>\u6b21\u306b\u3001\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3057\u3066gem\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3059\uff1a<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">bundle install<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-5\">Redis\u306e\u8a2d\u5b9a\u3068Sidekiq\u306e\u8d77\u52d5\u65b9\u6cd5<\/h3>\n\n\n\n<p>Sidekiq\u3092\u4f7f\u7528\u3059\u308b\u306b\u306f\u3001Redis\u30b5\u30fc\u30d0\u30fc\u304c\u5fc5\u8981\u3067\u3059\u3002\u958b\u767a\u74b0\u5883\u3067\u306f\u4ee5\u4e0b\u306e\u624b\u9806\u3067\u8a2d\u5b9a\u3057\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>Redis\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3068\u8d77\u52d5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   # macOS\u306e\u5834\u5408\n   brew install redis\n   brew services start redis\n\n   # Ubuntu\u306e\u5834\u5408\n   sudo apt-get install redis-server\n   sudo systemctl start redis-server<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>Sidekiq\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u306e\u4f5c\u6210<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   # config\/initializers\/sidekiq.rb\n   Sidekiq.configure_server do |config|\n     config.redis = {\n       url: ENV.fetch('REDIS_URL', 'redis:\/\/localhost:6379\/0'),\n       network_timeout: 5,\n       pool_timeout: 5\n     }\n   end\n\n   Sidekiq.configure_client do |config|\n     config.redis = {\n       url: ENV.fetch('REDIS_URL', 'redis:\/\/localhost:6379\/0'),\n       network_timeout: 5,\n       pool_timeout: 5\n     }\n   end<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>Sidekiq\u306e\u8d77\u52d5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   # \u958b\u767a\u74b0\u5883\u3067\u306e\u8d77\u52d5\n   bundle exec sidekiq\n\n   # \u672c\u756a\u74b0\u5883\u3067\u306e\u8d77\u52d5\uff08\u30d0\u30c3\u30af\u30b0\u30e9\u30a6\u30f3\u30c9\u5b9f\u884c\uff09\n   bundle exec sidekiq -d -L log\/sidekiq.log<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-6\">\u57fa\u672c\u7684\u306aWorker\u30af\u30e9\u30b9\u306e\u5b9f\u88c5\u4f8b<\/h3>\n\n\n\n<p>Sidekiq\u3092\u4f7f\u7528\u3057\u305f\u975e\u540c\u671f\u51e6\u7406\u306f\u3001Worker\u30af\u30e9\u30b9\u3068\u3057\u3066\u5b9f\u88c5\u3057\u307e\u3059\u3002\u4ee5\u4e0b\u306b\u57fa\u672c\u7684\u306a\u5b9f\u88c5\u4f8b\u3092\u793a\u3057\u307e\u3059\uff1a<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># app\/workers\/email_worker.rb\nclass EmailWorker\n  include Sidekiq::Worker\n\n  # \u30ea\u30c8\u30e9\u30a4\u8a2d\u5b9a\u3084\u30ad\u30e5\u30fc\u306e\u6307\u5b9a\n  sidekiq_options retry: 3, queue: 'mailer'\n\n  def perform(user_id, message_type)\n    user = User.find(user_id)\n\n    case message_type\n    when 'welcome'\n      UserMailer.welcome_email(user).deliver_now\n    when 'reminder'\n      UserMailer.reminder_email(user).deliver_now\n    end\n  rescue ActiveRecord::RecordNotFound =&gt; e\n    logger.error \"\u30e6\u30fc\u30b6\u30fc\u304c\u898b\u3064\u304b\u308a\u307e\u305b\u3093: #{e.message}\"\n    # \u30ea\u30c8\u30e9\u30a4\u4e0d\u8981\u306a\u306e\u3067\u30a8\u30e9\u30fc\u3092\u63e1\u308a\u3064\u3076\u3059\n  rescue StandardError =&gt; e\n    logger.error \"\u30e1\u30fc\u30eb\u9001\u4fe1\u30a8\u30e9\u30fc: #{e.message}\"\n    raise # \u30ea\u30c8\u30e9\u30a4\u306e\u305f\u3081\u30a8\u30e9\u30fc\u3092\u518d\u767a\u751f\n  end\nend<\/pre>\n\n\n\n<p>\u30b8\u30e7\u30d6\u306e\u5b9f\u884c\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u884c\u3044\u307e\u3059\uff1a<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u975e\u540c\u671f\u5b9f\u884c\nEmailWorker.perform_async(user.id, 'welcome')\n\n# \u6307\u5b9a\u6642\u9593\u5f8c\u306b\u5b9f\u884c\nEmailWorker.perform_in(30.minutes, user.id, 'reminder')\n\n# \u6307\u5b9a\u65e5\u6642\u306b\u5b9f\u884c\nEmailWorker.perform_at(DateTime.tomorrow.noon, user.id, 'reminder')<\/pre>\n\n\n\n<p>Rails\u74b0\u5883\u3067\u306f\u3001<code>config\/application.rb<\/code>\u306bActiveJob\u306e\u30a2\u30c0\u30d7\u30bf\u30fc\u3068\u3057\u3066Sidekiq\u3092\u8a2d\u5b9a\u3059\u308b\u3053\u3068\u3082\u3067\u304d\u307e\u3059\uff1a<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># config\/application.rb\nconfig.active_job.queue_adapter = :sidekiq<\/pre>\n\n\n\n<p>\u3053\u306e\u8a2d\u5b9a\u306b\u3088\u308a\u3001ActiveJob\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u901a\u3058\u3066Sidekiq\u3092\u4f7f\u7528\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\uff1a<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class WelcomeEmailJob &lt; ApplicationJob\n  queue_as :mailer\n\n  def perform(user_id)\n    user = User.find(user_id)\n    UserMailer.welcome_email(user).deliver_now\n  end\nend\n\n# \u30b8\u30e7\u30d6\u306e\u5b9f\u884c\nWelcomeEmailJob.perform_later(user.id)<\/pre>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-7\">\u52b9\u7387\u7684\u306a\u30b8\u30e7\u30d6\u7ba1\u7406\u3068\u30ad\u30e5\u30fc\u8a2d\u8a08<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-8\">\u8907\u6570\u306e\u30ad\u30e5\u30fc\u306e\u6d3b\u7528\u3068\u30d7\u30e9\u30a4\u30aa\u30ea\u30c6\u30a3\u8a2d\u5b9a<\/h3>\n\n\n\n<p>\u8907\u6570\u306e\u30ad\u30e5\u30fc\u3092\u52b9\u679c\u7684\u306b\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u30b8\u30e7\u30d6\u306e\u512a\u5148\u5ea6\u306b\u5fdc\u3058\u305f\u51e6\u7406\u306e\u6700\u9069\u5316\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># config\/sidekiq.yml\n---\n:concurrency: 5\n:queues:\n  - [critical, 3]  # \u6700\u9ad8\u512a\u5148\u5ea6\n  - [high, 2]      # \u9ad8\u512a\u5148\u5ea6\n  - [default, 1]   # \u901a\u5e38\u512a\u5148\u5ea6\n  - [low, 1]       # \u4f4e\u512a\u5148\u5ea6<\/pre>\n\n\n\n<p>\u5404\u30ad\u30e5\u30fc\u306e\u63a8\u5968\u3055\u308c\u308b\u7528\u9014\u3068\u8a2d\u5b9a\uff1a<\/p>\n\n\n<div id=\"id-e783d057-6297-4b47-b715-329819f669bc\">\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th>\u30ad\u30e5\u30fc\u540d<\/th><th>\u7528\u9014<\/th><th>\u4e26\u884c\u51e6\u7406\u6570<\/th><th>\u30bf\u30a4\u30e0\u30a2\u30a6\u30c8\u8a2d\u5b9a<\/th><\/tr><\/thead><tbody><tr><td>critical<\/td><td>\u6c7a\u6e08\u51e6\u7406\u3001\u91cd\u8981\u901a\u77e5<\/td><td>2-3<\/td><td>5\u5206<\/td><\/tr><tr><td>high<\/td><td>\u30e6\u30fc\u30b6\u30fc\u95a2\u9023\u51e6\u7406<\/td><td>3-5<\/td><td>10\u5206<\/td><\/tr><tr><td>default<\/td><td>\u4e00\u822c\u7684\u306a\u51e6\u7406<\/td><td>5-10<\/td><td>15\u5206<\/td><\/tr><tr><td>low<\/td><td>\u30d0\u30c3\u30c1\u51e6\u7406\u3001\u96c6\u8a08<\/td><td>2-3<\/td><td>30\u5206<\/td><\/tr><\/tbody><\/table><\/figure>\n<\/div>\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u30ad\u30e5\u30fc\u8a2d\u5b9a\u3092\u9069\u7528\u3057\u305fWorker\u306e\u4f8b\nclass PaymentProcessor\n  include Sidekiq::Worker\n  sidekiq_options queue: 'critical',\n                 retry: 3,\n                 backtrace: true\n\n  def perform(payment_id)\n    payment = Payment.find(payment_id)\n    process_payment(payment)\n  end\nend<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-9\">Worker\u30af\u30e9\u30b9\u306e\u6b63\u3057\u3044\u8a2d\u8a08\u30d1\u30bf\u30fc\u30f3<\/h3>\n\n\n\n<p>\u52b9\u679c\u7684\u306aWorker\u30af\u30e9\u30b9\u306e\u8a2d\u8a08\u306b\u306f\u3001\u4ee5\u4e0b\u306e\u539f\u5247\u3092\u8003\u616e\u3057\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u5358\u4e00\u8cac\u4efb\u306e\u539f\u5247<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u826f\u3044\u4f8b\uff1a\u660e\u78ba\u306a\u8cac\u4efb\u3092\u6301\u3064Worker\nclass ImageResizeWorker\n  include Sidekiq::Worker\n\n  def perform(image_id)\n    image = Image.find(image_id)\n\n    ImageService.new(image).tap do |service|\n      service.resize\n      service.optimize\n      service.store\n    end\n  end\nend\n\n# \u60aa\u3044\u4f8b\uff1a\u8907\u6570\u306e\u8cac\u4efb\u304c\u6df7\u5728\nclass MediaProcessor\n  include Sidekiq::Worker\n\n  def perform(media_id, type)\n    case type\n    when 'image'\n      process_image(media_id)\n    when 'video'\n      process_video(media_id)\n    when 'audio'\n      process_audio(media_id)\n    end\n  end\nend<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u3079\u304d\u7b49\u6027\u306e\u78ba\u4fdd<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class OrderConfirmationWorker\n  include Sidekiq::Worker\n\n  def perform(order_id)\n    order = Order.find(order_id)\n\n    # \u65e2\u306b\u51e6\u7406\u6e08\u307f\u306e\u5834\u5408\u306f\u30b9\u30ad\u30c3\u30d7\n    return if order.confirmation_sent?\n\n    Order.transaction do\n      OrderMailer.confirmation(order).deliver_now\n      order.update!(confirmation_sent_at: Time.current)\n    end\n  end\nend<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-10\">\u30ea\u30c8\u30e9\u30a4\u6226\u7565\u3068\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0<\/h3>\n\n\n\n<p>\u5805\u7262\u306a\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u3068\u30ea\u30c8\u30e9\u30a4\u6226\u7565\u306e\u5b9f\u88c5\u4f8b\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u6bb5\u968e\u7684\u306a\u30ea\u30c8\u30e9\u30a4\u9593\u9694\u306e\u8a2d\u5b9a<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class ExternalApiWorker\n  include Sidekiq::Worker\n\n  sidekiq_options retry: 5,\n                 retry_in: -&gt;(count) {\n                   # 10\u79d2\u300130\u79d2\u300190\u79d2\u3001270\u79d2\u3001810\u79d2\u3068\u9593\u9694\u3092\u5e83\u3052\u308b\n                   (10 * (3 ** count))\n                 }\n\n  def perform(api_request_id)\n    request = ApiRequest.find(api_request_id)\n\n    begin\n      response = api_client.execute(request.payload)\n      process_response(response)\n    rescue ApiClient::RateLimitError =&gt; e\n      # \u30ec\u30fc\u30c8\u30ea\u30df\u30c3\u30c8\u6642\u306f\u9577\u3081\u306e\u9593\u9694\u3092\u7a7a\u3051\u3066\u518d\u8a66\u884c\n      retry_job_in = calculate_rate_limit_retry_interval(e)\n      self.class.perform_in(retry_job_in, api_request_id)\n    rescue ApiClient::ServerError =&gt; e\n      # \u30b5\u30fc\u30d0\u30fc\u30a8\u30e9\u30fc\u306f\u901a\u5e38\u306e\u30ea\u30c8\u30e9\u30a4\u306b\u4efb\u305b\u308b\n      raise\n    rescue ApiClient::InvalidRequestError =&gt; e\n      # \u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u30a8\u30e9\u30fc\u306f\u30ea\u30c8\u30e9\u30a4\u3057\u306a\u3044\n      handle_invalid_request(request, e)\n    end\n  end\nend<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30a8\u30e9\u30fc\u76e3\u8996\u3068\u901a\u77e5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class CriticalJobWorker\n  include Sidekiq::Worker\n\n  sidekiq_options retry: 3\n\n  sidekiq_retries_exhausted do |msg, exception|\n    Honeybadger.notify(\n      error_class: exception.class.name,\n      error_message: exception.message,\n      context: {\n        job_id: msg['jid'],\n        arguments: msg['args'],\n        failed_at: Time.current\n      }\n    )\n\n    # \u7ba1\u7406\u8005\u3078\u306e\u901a\u77e5\n    AdminNotifier.job_failed(\n      worker_class: self.class.name,\n      job_id: msg['jid'],\n      error: exception\n    )\n  end\n\n  def perform(args)\n    # \u51e6\u7406\u5185\u5bb9\n  end\nend<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30d0\u30c3\u30c1\u51e6\u7406\u306e\u6700\u9069\u5316<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class BatchProcessor\n  include Sidekiq::Worker\n\n  sidekiq_options queue: 'low',\n                 retry: 0  # \u30d0\u30c3\u30c1\u5168\u4f53\u3067\u7ba1\u7406\u3059\u308b\u305f\u3081\u500b\u5225\u30ea\u30c8\u30e9\u30a4\u306f\u7121\u52b9\u5316\n\n  def perform(batch_id)\n    batch = Batch.find(batch_id)\n\n    batch.items.find_each do |item|\n      begin\n        process_item(item)\n      rescue StandardError =&gt; e\n        # \u30a8\u30e9\u30fc\u3092\u30ed\u30b0\u306b\u8a18\u9332\n        batch.log_error(item: item, error: e)\n        # \u7d9a\u884c\uff08\u4ed6\u306e\u30a2\u30a4\u30c6\u30e0\u306e\u51e6\u7406\u3092\u7d99\u7d9a\uff09\n        next\n      end\n    end\n\n    # \u30d0\u30c3\u30c1\u5168\u4f53\u306e\u72b6\u614b\u3092\u66f4\u65b0\n    batch.complete!\n  rescue StandardError =&gt; e\n    batch.fail!(error: e)\n    raise\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30d1\u30bf\u30fc\u30f3\u3092\u9069\u5207\u306b\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u30b9\u30b1\u30fc\u30e9\u30d6\u30eb\u3067\u4fdd\u5b88\u6027\u306e\u9ad8\u3044\u30b8\u30e7\u30d6\u51e6\u7406\u30b7\u30b9\u30c6\u30e0\u3092\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002\u30ad\u30e5\u30fc\u306e\u8a2d\u8a08\u3001Worker\u306e\u5b9f\u88c5\u3001\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u306e\u305d\u308c\u305e\u308c\u306b\u3064\u3044\u3066\u3001\u30b7\u30b9\u30c6\u30e0\u306e\u8981\u4ef6\u306b\u5fdc\u3058\u3066\u6700\u9069\u306a\u65b9\u6cd5\u3092\u9078\u629e\u3059\u308b\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-11\">Sidekiq\u306e\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3068\u904b\u7528\u7ba1\u7406<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-12\">Web\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u8a2d\u5b9a\u3068\u6d3b\u7528\u6cd5<\/h3>\n\n\n\n<p>Sidekiq\u306f\u3001\u30d3\u30eb\u30c8\u30a4\u30f3\u306eWeb\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u63d0\u4f9b\u3057\u3066\u304a\u308a\u3001\u7c21\u5358\u306b\u76e3\u8996\u3068\u30c7\u30d0\u30c3\u30b0\u3092\u884c\u3046\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>Web\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u8a2d\u5b9a<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># config\/routes.rb\nrequire 'sidekiq\/web'\n\nRails.application.routes.draw do\n  # Basic\u8a8d\u8a3c\u306e\u8a2d\u5b9a\n  Sidekiq::Web.use(Rack::Auth::Basic) do |username, password|\n    ActiveSupport::SecurityUtils.secure_compare(\n      ::Digest::SHA256.hexdigest(username),\n      ::Digest::SHA256.hexdigest(ENV['SIDEKIQ_USERNAME'])) &amp;\n    ActiveSupport::SecurityUtils.secure_compare(\n      ::Digest::SHA256.hexdigest(password),\n      ::Digest::SHA256.hexdigest(ENV['SIDEKIQ_PASSWORD']))\n  end\n\n  # \u7ba1\u7406\u8005\u306e\u307f\u30a2\u30af\u30bb\u30b9\u53ef\u80fd\u306b\u5236\u9650\n  authenticate :user, lambda { |u| u.admin? } do\n    mount Sidekiq::Web =&gt; '\/sidekiq'\n  end\nend<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u4e3b\u8981\u306a\u76e3\u8996\u9805\u76ee<\/strong><\/li>\n<\/ol>\n\n\n<div id=\"id-34597118-7abb-4498-82b5-c72eaf0edca7\">\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th>\u76e3\u8996\u9805\u76ee<\/th><th>\u78ba\u8a8d\u30dd\u30a4\u30f3\u30c8<\/th><th>\u30a2\u30e9\u30fc\u30c8\u95be\u5024<\/th><\/tr><\/thead><tbody><tr><td>Processed<\/td><td>\u51e6\u7406\u6e08\u307f\u30b8\u30e7\u30d6\u6570\u306e\u63a8\u79fb<\/td><td>\u6025\u6fc0\u306a\u5897\u6e1b<\/td><\/tr><tr><td>Failed<\/td><td>\u5931\u6557\u3057\u305f\u30b8\u30e7\u30d6\u6570<\/td><td>\u4e00\u5b9a\u6570\u4ee5\u4e0a<\/td><\/tr><tr><td>Busy<\/td><td>\u5b9f\u884c\u4e2d\u306e\u30ef\u30fc\u30ab\u30fc\u6570<\/td><td>\u6700\u5927\u5024\u8fd1\u304f<\/td><\/tr><tr><td>Enqueued<\/td><td>\u30ad\u30e5\u30fc\u5185\u306e\u30b8\u30e7\u30d6\u6570<\/td><td>\u7570\u5e38\u306a\u84c4\u7a4d<\/td><\/tr><tr><td>Latency<\/td><td>\u51e6\u7406\u5f85\u3061\u6642\u9593<\/td><td>\u898f\u5b9a\u5024\u8d85\u904e<\/td><\/tr><\/tbody><\/table><\/figure>\n<\/div>\n\n\n<h3 class=\"wp-block-heading\" id=\"i-13\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30e1\u30c8\u30ea\u30af\u30b9\u53ce\u96c6\u306e\u8a2d\u5b9a<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># config\/initializers\/sidekiq.rb\nSidekiq.configure_server do |config|\n  # Prometheus\u3067\u306e\u30e1\u30c8\u30ea\u30af\u30b9\u53ce\u96c6\n  require 'prometheus_exporter\/middleware'\n  config.server_middleware do |chain|\n    chain.add PrometheusExporter::Middleware\n  end\n\n  # \u30ab\u30b9\u30bf\u30e0\u30e1\u30c8\u30ea\u30af\u30b9\n  config.server_middleware do |chain|\n    chain.add CustomMetricsMiddleware\n  end\nend\n\n# \u30ab\u30b9\u30bf\u30e0\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u306e\u5b9f\u88c5\nclass CustomMetricsMiddleware\n  def call(worker, job, queue)\n    start_time = Time.now\n\n    begin\n      yield\n      record_success_metrics(worker, job, queue, start_time)\n    rescue =&gt; e\n      record_failure_metrics(worker, job, queue, e)\n      raise\n    end\n  end\n\n  private\n\n  def record_success_metrics(worker, job, queue, start_time)\n    duration = Time.now - start_time\n    StatsD.timing(\"sidekiq.jobs.#{worker.class.name}.duration\", duration * 1000)\n    StatsD.increment(\"sidekiq.jobs.#{worker.class.name}.success\")\n  end\n\n  def record_failure_metrics(worker, job, queue, error)\n    StatsD.increment(\"sidekiq.jobs.#{worker.class.name}.failure\")\n    StatsD.increment(\"sidekiq.jobs.#{worker.class.name}.error.#{error.class.name}\")\n  end\nend<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30a2\u30e9\u30fc\u30c8\u8a2d\u5b9a<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># Grafana\u30a2\u30e9\u30fc\u30c8\u306e\u4f8b\n{\n  \"alertname\": \"SidekiqQueueLatency\",\n  \"expr\": \"sidekiq_queue_latency{queue='critical'} &gt; 300\",\n  \"for\": \"5m\",\n  \"labels\": {\n    \"severity\": \"critical\"\n  },\n  \"annotations\": {\n    \"summary\": \"Sidekiq critical queue latency is high\",\n    \"description\": \"Queue latency has exceeded 5 minutes\"\n  }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-14\">\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u306e\u5177\u4f53\u7684\u306a\u624b\u9806<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u4e00\u822c\u7684\u306a\u554f\u984c\u3068\u5bfe\u51e6\u6cd5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u30e1\u30e2\u30ea\u4f7f\u7528\u91cf\u306e\u76e3\u8996\u3068\u5236\u5fa1\nclass MemoryIntensiveWorker\n  include Sidekiq::Worker\n\n  def perform(*args)\n    # \u30e1\u30e2\u30ea\u4f7f\u7528\u91cf\u306e\u78ba\u8a8d\n    memory_usage = GetProcessMem.new.mb\n\n    if memory_usage &gt; 1024  # 1GB\u4ee5\u4e0a\n      GC.start  # \u5f37\u5236\u7684\u306bGC\u5b9f\u884c\n      logger.warn \"High memory usage detected: #{memory_usage}MB\"\n    end\n\n    # \u51e6\u7406\u5b9f\u884c\n    process_data(*args)\n  ensure\n    # \u5927\u304d\u306a\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306e\u89e3\u653e\n    cleanup_resources\n  end\nend<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30c7\u30d0\u30c3\u30b0\u7528\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u306e\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class DebugMiddleware\n  def call(worker, job, queue)\n    logger.info \"Starting job #{worker.class} with args #{job['args']}\"\n    start_time = Time.now\n\n    begin\n      yield\n    rescue =&gt; error\n      logger.error \"Job failed: #{error.class} - #{error.message}\"\n      logger.error error.backtrace.join(\"\\n\")\n      raise\n    ensure\n      duration = Time.now - start_time\n      logger.info \"Finished job #{worker.class} in #{duration.round(2)}s\"\n    end\n  end\nend<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u30c1\u30a7\u30c3\u30af\u30ea\u30b9\u30c8<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>[ ] Redis\u306e\u63a5\u7d9a\u72b6\u614b\u78ba\u8a8d<\/li>\n\n\n\n<li>[ ] \u30e1\u30e2\u30ea\u4f7f\u7528\u91cf\u306e\u76e3\u8996<\/li>\n\n\n\n<li>[ ] \u30ef\u30fc\u30ab\u30fc\u30d7\u30ed\u30bb\u30b9\u306e\u72b6\u614b\u78ba\u8a8d<\/li>\n\n\n\n<li>[ ] \u30ed\u30b0\u30d5\u30a1\u30a4\u30eb\u306e\u89e3\u6790<\/li>\n\n\n\n<li>[ ] \u30ad\u30e5\u30fc\u306e\u6df1\u3055\u3068\u51e6\u7406\u901f\u5ea6\u306e\u78ba\u8a8d<\/li>\n\n\n\n<li>[ ] \u30a8\u30e9\u30fc\u30ec\u30fc\u30c8\u306e\u76e3\u8996<\/li>\n\n\n\n<li>[ ] \u30cd\u30c3\u30c8\u30ef\u30fc\u30af\u30ec\u30a4\u30c6\u30f3\u30b7\u30fc\u306e\u78ba\u8a8d<\/li>\n<\/ul>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3068\u904b\u7528\u7ba1\u7406\u306e\u65bd\u7b56\u3092\u9069\u5207\u306b\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3067\u3001Sidekiq\u3092\u7528\u3044\u305f\u975e\u540c\u671f\u51e6\u7406\u30b7\u30b9\u30c6\u30e0\u306e\u5b89\u5b9a\u904b\u7528\u304c\u53ef\u80fd\u3068\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-15\">Sidekiq\u3092\u7528\u3044\u305f\u5927\u898f\u6a21\u30b7\u30b9\u30c6\u30e0\u306e\u69cb\u7bc9<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-16\">\u30b9\u30b1\u30fc\u30e9\u30d3\u30ea\u30c6\u30a3\u3092\u8003\u616e\u3057\u305f\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u8a2d\u8a08<\/h3>\n\n\n\n<p>\u5927\u898f\u6a21\u30b7\u30b9\u30c6\u30e0\u3067\u306f\u3001\u9069\u5207\u306a\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u8a2d\u8a08\u304c\u6027\u80fd\u3068\u5b89\u5b9a\u6027\u3092\u5de6\u53f3\u3057\u307e\u3059\u3002\u4ee5\u4e0b\u306b\u4e3b\u8981\u306a\u8a2d\u8a08\u30dd\u30a4\u30f3\u30c8\u3092\u793a\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u5206\u6563\u30b7\u30b9\u30c6\u30e0\u306e\u69cb\u6210<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># config\/initializers\/sidekiq.rb\nSidekiq.configure_server do |config|\n  # Redis Sentinel\u3092\u4f7f\u7528\u3057\u305f\u9ad8\u53ef\u7528\u6027\u69cb\u6210\n  config.redis = {\n    url: ENV['REDIS_URL'],\n    sentinels: [\n      { host: ENV.fetch('SENTINEL_HOST_1'), port: 26379 },\n      { host: ENV.fetch('SENTINEL_HOST_2'), port: 26379 },\n      { host: ENV.fetch('SENTINEL_HOST_3'), port: 26379 }\n    ],\n    sentinel_command_timeout: 3,\n    role: :master\n  }\n\n  # Worker\u6570\u306e\u52d5\u7684\u8abf\u6574\n  config.options[:concurrency] = calculate_optimal_concurrency\nend\n\ndef calculate_optimal_concurrency\n  # \u4f7f\u7528\u53ef\u80fd\u306aCPU\u30b3\u30a2\u6570\u306b\u57fa\u3065\u3044\u3066\u6700\u9069\u306a\u4e26\u884c\u6570\u3092\u8a08\u7b97\n  processor_count = Etc.nprocessors\n  memory_limit = ENV.fetch('MEMORY_LIMIT_MB', 4096).to_i\n\n  # \u30e1\u30e2\u30ea\u3068CPU\u306e\u30d0\u30e9\u30f3\u30b9\u3092\u8003\u616e\n  [(processor_count * 2), (memory_limit \/ 400)].min\nend<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30b7\u30e3\u30fc\u30c7\u30a3\u30f3\u30b0\u306e\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class ShardedWorker\n  include Sidekiq::Worker\n\n  sidekiq_options queue: -&gt; { determine_shard_queue }\n\n  def self.determine_shard_queue\n    shard_count = ENV.fetch('SHARD_COUNT', 4).to_i\n    shards = (0...shard_count).map { |i| \"queue_shard_#{i}\" }\n\n    # \u30b8\u30e7\u30d6\u306e\u7279\u6027\u306b\u57fa\u3065\u3044\u3066\u30b7\u30e3\u30fc\u30c9\u3092\u9078\u629e\n    shard_index = Digest::SHA1.hexdigest(job_key).to_i(16) % shard_count\n    shards[shard_index]\n  end\n\n  def perform(job_key, payload)\n    # \u30b7\u30e3\u30fc\u30c9\u56fa\u6709\u306e\u51e6\u7406\n    with_shard_connection(job_key) do\n      process_payload(payload)\n    end\n  end\nend<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-17\">\u9ad8\u53ef\u7528\u6027\u3092\u5b9f\u73fe\u3059\u308b\u305f\u3081\u306e\u5177\u4f53\u7684\u306a\u65bd\u7b56<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30b5\u30fc\u30ad\u30c3\u30c8\u30d6\u30ec\u30fc\u30ab\u30fc\u306e\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class CircuitBreaker\n  include Singleton\n\n  def self.with_circuit_breaker(service_name, options = {}, &amp;block)\n    instance.with_circuit_breaker(service_name, options, &amp;block)\n  end\n\n  def with_circuit_breaker(service_name, options = {})\n    return fallback_value(service_name) if circuit_open?(service_name)\n\n    begin\n      result = yield\n      reset_failure_count(service_name)\n      result\n    rescue StandardError =&gt; e\n      handle_failure(service_name, e)\n      raise\n    end\n  end\n\n  private\n\n  def circuit_open?(service_name)\n    failure_count = Sidekiq.redis { |r| r.get(\"circuit_breaker:#{service_name}:failures\").to_i }\n    failure_count &gt;= failure_threshold\n  end\nend\n\n# \u30b5\u30fc\u30ad\u30c3\u30c8\u30d6\u30ec\u30fc\u30ab\u30fc\u3092\u4f7f\u7528\u3057\u305fWorker\nclass ExternalServiceWorker\n  include Sidekiq::Worker\n\n  def perform(request_id)\n    CircuitBreaker.with_circuit_breaker('external_api', timeout: 30) do\n      api_client.process_request(request_id)\n    end\n  end\nend<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30b0\u30ec\u30fc\u30b9\u30d5\u30eb\u30b7\u30e3\u30c3\u30c8\u30c0\u30a6\u30f3\u306e\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># config\/initializers\/sidekiq.rb\nSidekiq.configure_server do |config|\n  config.on(:shutdown) do\n    # \u30b7\u30e3\u30c3\u30c8\u30c0\u30a6\u30f3\u958b\u59cb\u6642\u306e\u51e6\u7406\n    shutdown_start = Time.current\n\n    # \u5b9f\u884c\u4e2d\u306e\u30b8\u30e7\u30d6\u306e\u5b8c\u4e86\u3092\u5f85\u6a5f\n    while Sidekiq::Workers.new.size &gt; 0\n      break if Time.current - shutdown_start &gt; 30  # 30\u79d2\u3067\u30bf\u30a4\u30e0\u30a2\u30a6\u30c8\n      sleep 1\n    end\n\n    # \u672a\u5b8c\u4e86\u306e\u30b8\u30e7\u30d6\u3092\u518d\u30ad\u30e5\u30fc\u30a4\u30f3\u30b0\n    Sidekiq::Workers.new.each do |process_id, thread_id, work|\n      job = work['payload']\n      Sidekiq::Client.push(job)\n    end\n  end\nend<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-18\">\u672c\u756a\u74b0\u5883\u3067\u306e\u904b\u7528\u30ce\u30a6\u30cf\u30a6<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u30c1\u30e5\u30fc\u30cb\u30f3\u30b0<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class OptimizedWorker\n  include Sidekiq::Worker\n\n  sidekiq_options queue: 'critical',\n                 pool_size: 5,\n                 retry: 3\n\n  def perform(batch_id)\n    # \u30b3\u30cd\u30af\u30b7\u30e7\u30f3\u30d7\u30fc\u30eb\u306e\u6700\u9069\u5316\n    ActiveRecord::Base.connection_pool.with_connection do\n      batch = Batch.find(batch_id)\n\n      # \u30d0\u30c3\u30c1\u51e6\u7406\u306e\u6700\u9069\u5316\n      batch.items.find_each(batch_size: 1000) do |item|\n        process_item(item)\n      end\n    end\n  end\n\n  private\n\n  def process_item(item)\n    # \u30e1\u30e2\u30ea\u4f7f\u7528\u91cf\u306e\u76e3\u8996\n    if memory_critical?\n      GC.start\n      Rails.logger.warn \"Memory threshold reached, GC triggered\"\n    end\n\n    # \u5b9f\u969b\u306e\u51e6\u7406\n    item.process\n  end\n\n  def memory_critical?\n    GetProcessMem.new.mb &gt; ENV.fetch('MEMORY_THRESHOLD_MB', 1024).to_i\n  end\nend<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3068\u76e3\u8996<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u30ab\u30b9\u30bf\u30e0\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u306b\u3088\u308b\u8a73\u7d30\u306a\u30e1\u30c8\u30ea\u30af\u30b9\u53ce\u96c6\nclass MetricsMiddleware\n  def call(worker, job, queue)\n    start_time = Time.current\n    tags = {\n      worker_class: worker.class.name,\n      queue: queue,\n      jid: job['jid']\n    }\n\n    begin\n      StatsD.increment(\"sidekiq.job.start\", tags: tags)\n      yield\n      record_success(worker, job, queue, start_time, tags)\n    rescue =&gt; e\n      record_failure(worker, job, queue, e, tags)\n      raise\n    end\n  end\n\n  private\n\n  def record_success(worker, job, queue, start_time, tags)\n    duration = Time.current - start_time\n    StatsD.timing(\"sidekiq.job.duration\", duration * 1000, tags: tags)\n    StatsD.increment(\"sidekiq.job.success\", tags: tags)\n  end\n\n  def record_failure(worker, job, queue, error, tags)\n    error_tags = tags.merge(error_class: error.class.name)\n    StatsD.increment(\"sidekiq.job.failure\", tags: error_tags)\n  end\nend<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30b9\u30b1\u30fc\u30ea\u30f3\u30b0\u6226\u7565<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># config\/initializers\/sidekiq.rb\nSidekiq.configure_server do |config|\n  # \u52d5\u7684\u306a\u30b9\u30b1\u30fc\u30ea\u30f3\u30b0\u8a2d\u5b9a\n  config.average_scheduled_poll_interval = 5\n\n  # \u30ad\u30e5\u30fc\u3054\u3068\u306e\u91cd\u307f\u4ed8\u3051\u8a2d\u5b9a\n  config.queue_groups = {\n    'critical' =&gt; { weight: 3, workers: 5 },\n    'default' =&gt; { weight: 2, workers: 3 },\n    'low' =&gt; { weight: 1, workers: 2 }\n  }\n\n  # \u30ea\u30bd\u30fc\u30b9\u4f7f\u7528\u91cf\u306b\u57fa\u3065\u304f\u81ea\u52d5\u30b9\u30b1\u30fc\u30ea\u30f3\u30b0\n  config.on(:startup) do\n    ScalingManager.new.start_monitoring\n  end\nend\n\nclass ScalingManager\n  def start_monitoring\n    Thread.new do\n      loop do\n        adjust_worker_pool\n        sleep 60  # 1\u5206\u3054\u3068\u306b\u78ba\u8a8d\n      end\n    end\n  end\n\n  private\n\n  def adjust_worker_pool\n    current_load = system_load_average\n\n    case\n    when current_load &gt; 0.8\n      decrease_worker_count\n    when current_load &lt; 0.3\n      increase_worker_count\n    end\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u5b9f\u88c5\u3068\u8a2d\u5b9a\u306b\u3088\u308a\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u5229\u70b9\u304c\u5f97\u3089\u308c\u307e\u3059\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u9ad8\u3044\u53ef\u7528\u6027\u3068\u8010\u969c\u5bb3\u6027<\/li>\n\n\n\n<li>\u52b9\u7387\u7684\u306a\u30ea\u30bd\u30fc\u30b9\u5229\u7528<\/li>\n\n\n\n<li>\u30b9\u30b1\u30fc\u30e9\u30d6\u30eb\u306a\u51e6\u7406\u80fd\u529b<\/li>\n\n\n\n<li>\u8a73\u7d30\u306a\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3068\u554f\u984c\u306e\u65e9\u671f\u767a\u898b<\/li>\n\n\n\n<li>\u67d4\u8edf\u306a\u30b9\u30b1\u30fc\u30ea\u30f3\u30b0\u5bfe\u5fdc<\/li>\n<\/ul>\n\n\n\n<p>\u5927\u898f\u6a21\u30b7\u30b9\u30c6\u30e0\u306e\u904b\u7528\u3067\u306f\u3001\u3053\u308c\u3089\u306e\u8981\u7d20\u3092\u7d44\u307f\u5408\u308f\u305b\u306a\u304c\u3089\u3001\u30b7\u30b9\u30c6\u30e0\u306e\u7279\u6027\u306b\u5fdc\u3058\u3066\u9069\u5207\u306b\u30c1\u30e5\u30fc\u30cb\u30f3\u30b0\u3092\u884c\u3046\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Warning: Undefined array key &#8220;is_admin&#8221; in \/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/ &#8230; <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[3],"tags":[],"class_list":{"0":"post-1593","1":"post","2":"type-post","3":"status-publish","4":"format-standard","6":"category-ruby","7":"nothumb"},"_links":{"self":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/1593","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1593"}],"version-history":[{"count":1,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/1593\/revisions"}],"predecessor-version":[{"id":1594,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/1593\/revisions\/1594"}],"wp:attachment":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1593"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1593"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1593"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}