[Solr] Circuit Breaker の新機能

Solr 9.4 で Circuit Breaker にいろいろと変更が加えられました。以前の記事で取り上げたときとは変わったところも多いです。

  • CPUCircuitBreakerが名前の通りCPU使用率をチェックするようになりました。以前はCPUと言いつつ実際にはロードアベレージをチェックしていました
  • ロードアベレージをチェックする Circuit Breaker は LoadAverageCircuitBreaker になりました
  • 検索リクエストだけでなく更新リクエストにも効くようになりました

これらの変更に伴い設定方法が変更になっています。

CPUCircuitBreaker

クラス名と閾値を指定します。たとえば以下のように指定すると、CPU使用率75%を超えたら発動します。

<circuitBreaker class="org.apache.solr.util.circuitbreaker.CPUCircuitBreaker">
 <double  name="threshold">75</double>
</circuitBreake>

LoadAverageCircuitBreaker

クラス名と閾値を指定します。たとえば以下のように指定すると、ロードアベレージ8.0を超えたら発動します。

<circuitBreaker class="org.apache.solr.util.circuitbreaker.LoadAverageCircuitBreaker">
 <double  name="threshold">8.0</double>
</circuitBreaker>

MemoryCircuitBreaker

クラス名と閾値を指定します。たとえば以下のように指定するとメモリ使用率75%を超えたら発動します。

<circuitBreaker class="org.apache.solr.util.circuitbreaker.MemoryCircuitBreaker">
 <double name="threshold">75</double>
</circuitBreaker>

リクエストタイプの指定

リクエストタイプとして search, update を指定できます。上記の例のようにリクエストタイプをしない場合はデフォルトとして search が指定されたことになります。search, update それぞれに別の閾値を設定することもできます。

以下の例の場合、CPU使用率が80%を超えたら更新リクエストの受付を停止し、95%を超えたら検索リクエストを停止するという設定になります。

<config>
  <circuitBreaker class="solr.CPUCircuitBreaker">
   <double  name="threshold">80</double>
   <arr name="requestTypes">
     <str>update</str>
   </arr>
  </circuitBreaker>

  <circuitBreaker class="solr.CPUCircuitBreaker">
   <double  name="threshold">95</double>
   <arr name="requestTypes">
     <str>query</str>
   </arr>
  </circuitBreaker>
</config>

続 梅体験専門店「蝶矢」に行ってみた

以前に投稿したブログの中で、特別な梅酒と名高い「蝶矢 限定熟成」をついに開封したのでレポしていこうと思います。
梅体験専門店「蝶矢」に行ってみた

蝶矢 限定熟成開封の儀

  

かっこいい見た目。。
ぱっと見、色もかなり濃くて凝縮されている感と、何かで割らないと体温が一気に上がってしまいそうなくらい色々濃い。
実際に飲んでみたところ、見た目通りの印象。
割らずに飲むと激濃でした!
危険を察知しソーダ割りに変更したのですが、香りもよくて梅感たっぷりで美味しかったです。
プレミアム感も相まってほわほわでした。

そんな蝶矢 限定熟成のお供はお米でした。
この日は青天の霹靂というお米。
甘くて美味しいし、レトルトパックで売っているのも衝撃。

今日紹介した蝶矢 限定熟成は、梅体験専門店蝶矢の京都店と鎌倉店で購入できますよ〜。
各店舗1日限定5本の販売みたいです。
購入した日からそろそろ1年なのでまた行かねば。。
https://choyaume.jp/

WebAssemblyを使ってブラウザでRubyを動かす

WebAssemblyによりJavaScript以外のプログラミング言語で書かれたコードをブラウザ上で動かす道が広く開かれました。現時点ではRustが使われることが多いようですが、RubyやPythonなどのスクリプト言語を利用する手段も整ってきています。たとえばRubyはバージョン3.2からWebAssembly上で動くようになりました。
WebAssembly 上で動くようにコンパイルされたRubyインタープリターがruby.wasmで、そのruby.wasm 上でRubyのコードが動きます。

ブラウザ上でRubyを動かすのは非常に簡単です。以下はruby.wasmのサイトのQuick Exampleです。

<html>
  <script src="https://cdn.jsdelivr.net/npm/ruby-3_2-wasm-wasi@2.1.0/dist/browser.script.iife.js"></script>
  <script type="text/ruby">
    puts "Hello, world!"
  </script>
</html>

これをexample.htmlとして保存し、同じディレクトリでRubyのhttpdを起動します。

ruby -run -e httpd .

ブラウザで以下にアクセスします。

http://localhost:8080/example.html

注意しないといけないのは、puts の実行結果がそのままブラウザ上で表示されるわけではないことです。デベロッパーツールを開いてコンソールを見ると”Hello, world!”が出力されていることがわかります。

ブラウザ上に表示するためにはDOMを操作する必要があります。RubyからはJSパッケージを使ってJavaScriptを通じてDOMを操作できます。

<html>
  <script src="https://cdn.jsdelivr.net/npm/ruby-3_2-wasm-wasi@2.1.0/dist/browser.script.iife.js"></script>
  <script type="text/ruby">
    require "js"
    document = JS.global[:document]
    body = document[:body]
    button = document.getElementById("b1")
    button.addEventListener("click") do |e|
      div = document.getElementById("d1")
      div[:innerText] = "Hello, World""
    end
  </script>

  <button id="b1">Say Hello</button>
  <div id="d1"></div>
</html>

ボタンを押すとその下に”Hello, World!”と出力されます。

Slackのブックマークと後で読む機能が便利です

仕事でSlackを使っているのですが流れてくるメッセージが多くてメンション付きのものだったり後で読もうとしたものだったりを忘れることはありませんか?
そんな時に便利なのがブックマークする、後で読むの機能です。

基本的には作業の記録などはプロジェクト管理ツールのチケット管理でやっていますがチケットに記載するほどのことではないやりとりやTODOとして保持していたり返信待ちに使ったりと後で忘れないようにするのに便利です。

使い方は簡単で対象のメッセージのメニューから「ブックマークする」を押すだけで後で読むに追加されます。後は画像にある「後で」を押すことでブックマークしたものが一覧で表示されます。読んだ後や対応した後は「完了にする」または「後で」から外すで外せば綺麗に無くなります。

注意点として課金していない場合は長期間経つとブックマークしたメッセージ自体が消えてしまったりするのでそういった場合は別途自分宛に記載しなおしたりメモに残したりが必要です。

メールでも受信トレイを同じような扱いで運用しています。
読み逃しや返信忘れ、予定など現状の対応が必要なものを残したままにしているので作業忘れは少ないです。
ただ迷惑メールや作業メールなどに埋もれると困るので随時フィルターを駆使してやっているので少し手間はかかります。

仕事の進め方、ツールの使い方は人それぞれだと思いますがそれなりに長くこのやり方で運用していますが忘れてしまうことがかなり減っているのでおすすめです。

仕事でSlackを使っているのですが流れてくるメッセージが多くてメンション付きのものだったり後で読もうとしたものだったりを忘れることはありませんか?
そんな時に便利なのがブックマークする、後で読むの機能です。

基本的には作業の記録などはプロジェクト管理ツールのチケット管理でやっていますがチケットに記載するほどのことではないやりとりやTODOとして保持していたり返信待ちに使ったりと後で忘れないようにするのに便利です。

使い方は簡単で対象のメッセージのメニューから「ブックマークする」を押すだけで後で読むに追加されます。後は画像にある「後で」を押すことでブックマークしたものが一覧で表示されます。読んだ後や対応した後は「完了にする」または「後で」から外すで外せば綺麗に無くなります。

注意点として課金していない場合は長期間経つとブックマークしたメッセージ自体が消えてしまったりするのでそういった場合は別途自分宛に記載しなおしたりメモに残したりが必要です。

メールでも受信トレイを同じような扱いで運用しています。
読み逃しや返信忘れ、予定など現状の対応が必要なものを残したままにしているので作業忘れは少ないです。
ただ迷惑メールや作業メールなどに埋もれると困るので随時フィルターを駆使してやっているので少し手間はかかります。

仕事の進め方、ツールの使い方は人それぞれだと思いますがそれなりに長くこのやり方で運用していますが忘れてしまうことがかなり減っているのでおすすめです。

[AWS]ALBのルーティングアルゴリズム

ALBのターゲットグループ配下のインスタンスにどのようにリクエストを振り分けるかのアルゴリズム(ルーティングアルゴリズム)は複数用意されていて、ターゲットグループごとに設定できるようになっています。
ALBのルーティングアルゴリズムは長らくラウンドロビンだけでしたが、後に最小未処理リクエスト、更にその後に加重ランダムが追加されました。

ラウンドロビン

多くの場合ではデフォルトのラウンドロビンでうまくいきます。ラウンドロビンはターゲットグループ内のターゲットを順番に選択してリクエストを割り当てます。すべてのターゲットに均等にリクエストを割り当てる手法であり、各インスタンスの能力が同等でタスクの処理の重さも同じくらいであるときに利用されます。

最小未処理リクエスト(Least Outstanding Requests: LOR)

処理中のリクエストが最も少ないターゲットを選択します。
リクエストの種類ごとの処理の複雑さにばらつきが有る場合、ラウンドロビンでは特定のターゲットに負荷の高いリクエストが集中することが起こりえます。最小未処理リクエストはいわば一番暇なターゲットにリクエストを割り当ててる手法であり、特定のターゲットに負荷が集中してしまうことを防げます。

また、ターゲットの処理能力が均一でない場合にラウンドロビンでは最も処理能力の低いターゲットの負荷が問題になりますが、この場合も最小未処理リクエストを採用すればうまく対応できます。

荷重ランダム(Weighted Random)

Automatic Target Weights (ATW) を利用するときに選択します。
加重ランダムを選択すると「異常緩和をオンにする」という設定項目が表示されるようになります。異常緩和をオンにすると(500エラーを頻繁に応答するなど)異常と判定されたターゲットへのリクエスト割り当てを徐々に減らしていきます。ターゲットの状態が回復したと判定されると逆にリクエストの割り当てを徐々に戻します。

余談ですが

以前最小未処理リクエストの採用を検討したことがありましたが、とある理由でうまくいきませんでした。

そのサービスでは、アプリケーションサーバで処理するリクエストの中で特定の1種類でだけCPUを集中的に利用するケースがあり、そのようなリクエストがたまたま1台のサーバに集中するとCPU利用率が100%に達してしまうことがありました。

まさに最小未処理リクエストの出番のように見えました。しかし、そのタイプのリクエストでは重めの処理を exec で別プロセスとして起動してリクエスト自体は即座に応答するという作りになっていたため、未処理リクエストとしては扱えないことが分かって断念しました。(キューを使って処理を外出しにすることになりました)

未処理リクエストとしてカウントされる基準が重要、というお話でした。