ようへいの日々精進XP

おっさんの日記です。

2022 年 07 月 31 日 (日)

アクティビティ (今までの走行 (歩行) 距離)

https://pixe.la/v1/users/inokappa/graphs/fitbit-activity

Fitibit Charge2 のアクティビティから走行 (歩行) 距離を Fitbit Web API で取得して Pixela で草生やしている。色が濃くなれば濃くなる程強度が高い (歩行、走行距離が長い) ということで。実装の詳細はこちら

ジョギング

クロストレーナートレッドミルの間で、いつもの補強を 3 セット。

レアジョブ

今日はお休み。

夕飯

妻の体調不良が続いているが、頑張ってくれて野菜の煮浸しや鶏のソテー等を作ってくれた。ありがたい。久しぶりの妻の食事はやっぱり美味い。

Happy Hacking Keyboard Professional BT を Windows 10 でペアリングしようとして PIN が入力出来ない場合の対処手順

経緯

Happy Hacking Keyboard Professional BT (以後、HHKB BT) を Windows 10 でペアリングしようとして PIN が入力出来ない場合の対処手順が個人的にトリッキーだったのでメモしておく。

手順

この時点で、「え、PIN って何を入力すれば良いのか?」という状態に陥る。

ドキュメント によると...

  1. パソコン本体 (もしくは、USB 接続された外部キーボード) で「1」を入力
  2. 入力後に「接続」をマウスクリック
  3. 直後、間髪入れず (ここがトリッキー) に HHKB BT の「1」を押して「Enter」を入力

ドキュメントにも、「タイミングが非常に重要になります。接続が成功するまで繰り返してください。」と書かれているけど、今のところは失敗せずにペアリング出来ている。

接続完了。

参考

faq.pfu.jp

2022 年 07 月 30 日 (土)

アクティビティ (今までの走行 (歩行) 距離)

https://pixe.la/v1/users/inokappa/graphs/fitbit-activity

Fitibit Charge2 のアクティビティから走行 (歩行) 距離を Fitbit Web API で取得して Pixela で草生やしている。色が濃くなれば濃くなる程強度が高い (歩行、走行距離が長い) ということで。実装の詳細はこちら

ジョギング

完全休養。

レアジョブ

16:30 から。「明日は休むけどごめんね。他の先生でレッスンしてみて。ちょっとジェラシーだけど」って言われて笑った。

夕飯

インスタグラムで紹介されていた「フライドおくら」を作ってみたけど、カリッとやみつきな感じにならなくてイマイチだった。ついでに手羽中の唐揚げも作ってみたけど、油切れが悪くてイマイチだった。

Active Support 便利だった

というブログを書いた。

inokara.hateblo.jp

Active Support が便利だった

経緯

ほんと、タイトルの通り。

以下のような、ネストされたハッシュのキーをシンボルに変換したくてインターネットを彷徨っていたら、Active Support の deep_transform_keys が便利に使えるよとのことだったので、見様見真似で使ってみたら意図した結果を得られたのでメモしておく。

 {"aa"=>{"bb"=>[{"cc"=>"11", "dd"=>"22"}, {"ee"=>"33", "ff"=>"44"}, {"gg"=>"55", "hh"=>"66"}], "ii"=>"77"}}

本記事で扱う Ruby のバージョンは以下の通り。

ruby 3.0.4p208 (2022-04-12 revision 3fa771dded) [x86_64-darwin21]

Active Support について

railsguides.jp

Active SupportはRuby on Railsコンポーネントであり、Ruby言語の拡張やユーティリティを提供します。

ドキュメントの冒頭に上記のように記載されている。Rails だけのものだと思っていたけど、そうじゃないんだなー。

デモ

Ruby 本体にも transform_keys というメソッドがあった

docs.ruby-lang.org

以下の通り、トップレベルのキーだけはシンボルに変換された。

irb(main):002:0> h = {"aa"=>{"bb"=>[{"cc"=>"11", "dd"=>"22"}, {"ee"=>"33", "ff"=>"44"}, {"gg"=>"55", "hh"=>"66"}], "ii"=>"77"}}
irb(main):005:0> h.transform_keys(&:to_sym)
=> {:aa=>{"bb"=>[{"cc"=>"11", "dd"=>"22"}, {"ee"=>"33", "ff"=>"44"}, {"gg"=>"55", "hh"=>"66"}], "ii"=>"77"}}

これでは要件を満たせない。

Active Support の deep_transform_keys メソッドでやってみる

Gemfile に追加。

# frozen_string_literal: true

source "https://rubygems.org"

git_source(:github) { |repo_name| "https://github.com/#{repo_name}" }

gem 'active_support'

フットプリントを最小限にするため、Active Support はデフォルトでは最小限の依存関係を読み込むとのことだけど、今回、以下のようにハッシュの拡張機能のみを読み込んでいる (つもり)。実際のところ、どのくらいメモリ使用量が変わるんだろうか。気になるところ。

irb(main):001:0> require 'active_support/core_ext/hash/keys'
=> true
irb(main):002:0> h = {"aa"=>{"bb"=>[{"cc"=>"11", "dd"=>"22"}, {"ee"=>"33", "ff"=>"44"}, {"gg"=>"55", "hh"=>"66"}], "ii"=>"77"}}
=> {"aa"=>{"bb"=>[{"cc"=>"11", "dd"=>"22"}, {"ee"=>"33", "ff"=>"44"}, {"gg"=>"55", "hh"=>"66"}], "ii"=>"77"}}
irb(main):003:0> h.deep_transform_keys(&:to_sym)
=> {:aa=>{:bb=>[{:cc=>"11", :dd=>"22"}, {:ee=>"33", :ff=>"44"}, {:gg=>"55", :hh=>"66"}], :ii=>"77"}}

おお、簡単!素晴らしい。

Active Support を使わないパターンを考えた

stackoverflow.com

上記の記事を参考にして、以下のようなコードを書いてみた。んー、良いんだか悪いだな。

require 'minitest/autorun'

def make_all_keys_symbol(hash)
  symbold_hash = {}
  hash.each do |k, v|
    if v.is_a?(Hash)
      symbold_hash[k.to_sym] = make_all_keys_symbol(v)
    elsif v.is_a?(Array)
      nested_array = []
      v.each do |e|
        nested_array << e.transform_keys(&:to_sym)
      end
      symbold_hash[k.to_sym] = nested_array
    else
      symbold_hash[k.to_sym] = v
    end
  end
  symbold_hash
end

class TestMakeAllKeysSymbol < Minitest::Test
  def setup
    @h = {"aa"=>{"bb"=>[{"cc"=>"11", "dd"=>"22"}, {"ee"=>"33", "ff"=>"44"}, {"gg"=>"55", "hh"=>"66"}], "ii"=>"77"}}
  end

  def test_make_all_keys_symbol
    assert_equal({:aa=>{:bb=>[{:cc=>"11", :dd=>"22"}, {:ee=>"33", :ff=>"44"}, {:gg=>"55", :hh=>"66"}], :ii=>"77"}}, make_all_keys_symbol(@h))
  end
end

いちおう、問題なく動く。

$ ruby test.rb
Run options: --seed 60294

# Running:

.

Finished in 0.000705s, 1418.4397 runs/s, 1418.4397 assertions/s.

1 runs, 1 assertions, 0 failures, 0 errors, 0 skips

ということで

Active Support が便利だったメモでした。

おまけ

irbrequire 'active_support' した時と require 'active_support/core_ext/hash/keys' した時のメモリ使用量を ps コマンドで見てみた。

USER               PID  %CPU %MEM      VSZ    RSS   TT  STAT STARTED      TIME COMMAND
kappa            72224   0.0  0.1 34924040  26564 s012  S+    3:01PM   0:00.36 irb
kappa            72224   0.0  0.1 34925192  31072 s012  S+    3:01PM   0:00.46 irb # require 'active_support'
kappa            75776   0.0  0.1 35071496  27224 s012  S+    3:02PM   0:00.37 irb # require 'active_support/core_ext/hash/keys'

確かに、若干ではあるが、ハッシュの拡張機能をのみを読み込んだ時の方がメモリ使用量 (RSS) が少ないように見える。

2022 年 07 月 29 日 (金)

アクティビティ (今までの走行 (歩行) 距離)

https://pixe.la/v1/users/inokappa/graphs/fitbit-activity

Fitibit Charge2 のアクティビティから走行 (歩行) 距離を Fitbit Web API で取得して Pixela で草生やしている。色が濃くなれば濃くなる程強度が高い (歩行、走行距離が長い) ということで。実装の詳細はこちら

ジョギング

通院。リハビリとクロストレーナーを 10 分。たった 10 分しか動かしていないのにヘトヘトになった。

レアジョブ

安定の 9:30 から。今月のレッスンは 20 回を超えていた。頑張ったというより、正蔵先生との毎日の雑談を楽しめたので良かった (笑

夕飯

弟弐号からもらった冷凍シュウマイやらをチンして頂きました。おごちそうさまでした。

ヘトヘト

夕飯終わったら電池が切れたように寝てしまっていた。そして、目が覚めたら日付が変わっていて、7/30 (土) の朝にこの日記を書きました。

(小ネタ道場一本勝負) AWS CLI の s3api に隠しオプションを発見!?

追記 2022/07/30

AWS CLI--debug を使えば、API リクエストの様子も見れるので、試してみたら案の定 key-marker パラメータが付いてた。

$ aws --debug s3api list-object-versions --bucket BUCKET_NAME --key d/ --query 'DeleteMarkers[]'
...
GET
/BUCKET_NAME
encoding-type=url&key-marker=d%2F&versions=
host:s3.ap-northeast-1.amazonaws.com
x-amz-content-sha256:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
x-amz-date:20220729T223700Z
...

タイトルが

釣りっぽくなってしまい恐縮ですが、詳しい情報をお持ちの方がいらっしゃったら教えて下さいmm

ちなみに、本記事での AWS CLI のバージョンは以下の通りです。

$ aws --version
aws-cli/2.7.11 Python/3.10.5 Darwin/21.5.0 source/x86_64 prompt/off

最新バージョン (2.7.19) ではありません。

--key オプションって何?

見つけたというと大げさだけど、たまたま、とある S3 バケットdevelopment/ というプレフィックス以下のオブジェクトバージョン一覧を取得したくて、以下のようなリクエストを送っていて気づきました。

$ aws s3api list-object-versions --bucket BUCKET_NAME --key deployment'

パスの名前は development/ なのに、リクエストには、存在しないオプション (--key) で、さらに存在しないプレフィックス (deployment/) を指定していたにも関わらず、ちゃんと、以下のようなレスポンスを返していたのです...

[
    "development/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx1",
...
    "development/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx99",
]

え、なんで?

API リファレンスを見ると...

以下のリファレンスによると、aws s3api list-object-versions には、確かに --key というオプションは存在していません。見落としていたらすいません。

docs.aws.amazon.com

でも、S3 の API ドキュメントを見ると、怪しい記述が...

docs.aws.amazon.com

key-marker というリクエストパラメータが存在するらしいぞ...

key-marker
    Specifies the key to start with when listing objects in a bucket.

おお、そうなのかー。ということで、awscurl を使って確認。

$ awscurl --service s3 'https://s3.ap-northeast-1.amazonaws.com/BUCKET_NAME/?versions&key-marker=deployment' | tidy -xml -iq

以下のように、AWS CLI--key オプションを付与した際と同じレスポンスが返ってきます。

<?xml version="1.0" encoding="utf-8"?>
<ListVersionsResult xmlns="http://s3.amazonaws.com/doc/2006-03-01/">

  <Name>BUCKET_NAME</Name>
  <Prefix></Prefix>
  <KeyMarker>dev</KeyMarker>
  <VersionIdMarker></VersionIdMarker>
  <NextKeyMarker>
  development/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx1</NextKeyMarker>
  <NextVersionIdMarker>
...

おおー、なるほどー、隠しオプション?? の --key は、APIkey-marker オプションをラップしたものなのかなーという結論に至りましたとさ。

現場からは以上です!

2022 年 07 月 28 日 (木)

アクティビティ (今までの走行 (歩行) 距離)

https://pixe.la/v1/users/inokappa/graphs/fitbit-activity

Fitibit Charge2 のアクティビティから走行 (歩行) 距離を Fitbit Web API で取得して Pixela で草生やしている。色が濃くなれば濃くなる程強度が高い (歩行、走行距離が長い) ということで。実装の詳細はこちら

ジョギング

夕方は少し駆け足してみた。シンスプリントも右足も微妙に痛い。そもそも、痛みに敏感になっているのでは... という気持ちになった。

レアジョブ

今日も引き続き、企業面接ネタ。チートシートを見ながら、仮想面接。面白かった。

夕飯

パスタを作った。ちょっち味が薄い感じ。ブレブレだな〜

小ネタ

inokara.hateblo.jp

2022 年 07 月 27 日 (水)

アクティビティ (今までの走行 (歩行) 距離)

https://pixe.la/v1/users/inokappa/graphs/fitbit-activity

Fitibit Charge2 のアクティビティから走行 (歩行) 距離を Fitbit Web API で取得して Pixela で草生やしている。色が濃くなれば濃くなる程強度が高い (歩行、走行距離が長い) ということで。実装の詳細はこちら

ジョギング

夕方にウォーキング。

ウォーキングって、頑張っているつもりでペースが遅いことに気付いた。心拍を上げた早歩きで 7 〜 8 分/km くらいなので、いかに競歩のペースが変態的であるかを痛感。

レアジョブ

引き続き、企業面接ネタ。ちょっとした自己紹介が英語で出来るようになるという面ではかなり有用な教材かも。明日もやってみよう。

夕飯

俺たちのサニーで 20% オフの唐揚げと天ぷらを買ってきて天ぷらそばを作った。そばは乾麺を茹でで水で〆ただけ。地味に美味しゅうございました。

妻を病院に連れていく

体調不良が続いていたので、仕事を午後から休んで妻を病院に連れていった。点滴を受けて少し体調を持ち直したようで良かった。看護師さんが YAMAP ユーザーで嬉しそうに話しかけて下さったのが今日のハイライトだった。YAMAP 社員で良かったなーと思える瞬間。しかし、恥ずかしくない言動を心がけなければ...時既に遅しか...(汗

2022 年 07 月 26 日 (火)

アクティビティ (今までの走行 (歩行) 距離)

https://pixe.la/v1/users/inokappa/graphs/fitbit-activity

Fitibit Charge2 のアクティビティから走行 (歩行) 距離を Fitbit Web API で取得して Pixela で草生やしている。色が濃くなれば濃くなる程強度が高い (歩行、走行距離が長い) ということで。実装の詳細はこちら

ジョギング

完全休養。朝と夕方にウォーキング。ウォーキングでは痛みが無いので嬉しいけど、腰が痛い...

レアジョブ

安定の 9:30 からだった。教材が企業の面接っぽい感じで緊張したし、自分のことを言っていいのか、教材内のシチュエーションなのかがごっちゃになってアタフタしてしまった。明日はちょっとだけ予習をして臨もうかな...

夕飯

今日はゴーヤとベーコンのパスタを作って食べた。美味しゅうございました。

父にイヤフォンを贈った

良さげなイヤフォン (しかもインナーイヤー型で有線) を探しているとのことだったので、以下のイヤフォンをヨドバシから贈った。

www.audio-technica.co.jp

最近は Bluetooth 接続タイプでカナル型が多くて、インナーイヤー型を探すのに苦労した (笑

2022 年 07 月 25 日 (月)

アクティビティ (今までの走行 (歩行) 距離)

https://pixe.la/v1/users/inokappa/graphs/fitbit-activity

Fitibit Charge2 のアクティビティから走行 (歩行) 距離を Fitbit Web API で取得して Pixela で草生やしている。色が濃くなれば濃くなる程強度が高い (歩行、走行距離が長い) ということで。実装の詳細はこちら

ジョギング

今日も完全休養。チューブトレしたり、トリガーポイントでコロコロするくらいだった。

レアジョブ

今日は、予約していたけど、キャンセルした。明日は安定の 9:30 から。

夕飯

奥さんが体調を崩しているので、いつものおかゆ (おじや) を作って食べてもらった。自分は、いつもの居酒屋セルフサービス。世界陸上の総集編に涙しながら食べた砂肝串の味は忘れない。

負荷試験ツール vegeta

シュッと対象ホストに負荷を掛けたい場合、vegeta がかなりお気に入り。

github.com

POST のリクエストを投げる場合、以下のように実行する。

echo "POST http://goku:9090/things
X-Account-ID: 8675309
@/path/to/newthing.json" | vegeta attack --duration=1s --rate=5

パラメータは /path/to/newthing.json に用意しておいて、vegeta attack する。