エンジニア的なネタを毎週書くブログ

東京でWebサービスの開発をしています 【英語版やってみました】http://taichiw-e.hatenablog.com/

迷ったら帰る場所 「『テレビを作りたかった』自分」

一年半ぶりの記事が全然技術ネタじゃないのですけども…。

自分がなぜ今その職についているのか、ふとした時に思い出せる、「帰る場所」を持っているのは大事なことだと思う、という話です。


かの大捕手、野村克也氏はよく仰っておりました。
「迷ったら原点、外角低めに投げるのだ」と。

この話と同じかどうか…は怪しいところですが、
毎日仕事してればいろんなことがありますよね。嫌なこと、辛いこと、思い通りに行かないこと、テンションの上がらないこと、失敗したこと…
そんなときに、「あ、そういえば自分はこれがしたくて今の仕事についていたんだった」と、ふと思い出す、『原点』を自分の中に持っておくことってとても大切だと思うのです。
いつもいつもその『原点』は覚えていなくてもいいんだけど、ふとしたときに帰れる場所が持てるといいですよね。


私にとっての原点は…すでに以前書いているのでリンクだけ張って割愛。
taichiw.hatenablog.com

「子供に『このテレビはお父さんが作ったんだよ』っていう」という、おぼろげな夢というかイメージ。
これが自分の原点になっています。

ブラウザがCSSキャッシュしてしまうのを止める方法

CSSに限らないのですが、こんな感じでブラウザはダウンロードしたコンテンツをキャッシュする機能を持っています。
f:id:taichiw:20200724210451p:plain
200 OK とか言ってますが、サーバに何らかのリクエストを投げることすらしていないわけですね。

これが過剰に効いてしまうと、HTML/CSSを修正したのにCSSだけキャッシュが使われてしまって思いっきり画面が崩れてしまう…なんてことが起こり得ます。

これを解消する方法としてよく紹介されているのが、

<link rel="stylesheet" href="hoge.css?ver=20200724">

こんな感じでCSSのURLに適当なクエリストリングをつけ、変更のたびにパラメータを変えていくというもの。

しかしこの方法ですと、単にCSSを差し替えたいだけでもHTML側を修正しなくてはならず、HTMLをプログラムで生成しているような場合には「プログラムのリリース」が必要になってしまいます。
サーバ上でCSSファイルのタイムスタンプを取得してパラメータにする… というのも見つけたのですが、これではアクセスがあるたびに(ちょっととはいえ)ファイルI/Oが発生してしまうので、システムにあまり優しくなさそうです。

で、今更ながら調べていたところ、
HTTP responeヘッダのCache-Controlを使えばキャッシュ期間が指定できること、
および、Apacheの場合はmod_expiresを使えばCache-Controlを返せるようになることがわかりました。

実際にやってみた

apacheのconfファイル。試しに1秒でキャッシュが切れるようにしてみます。

LoadModule expires_module modules/mod_expires.so

...

<ifModule mod_expires.c>
  ExpiresActive On
  ExpiresByType text/css "access plus 1 second"
</ifModule>

f:id:taichiw:20200724212108p:plain
Cache-Control ヘッダが返るようになりました。

f:id:taichiw:20200724212236p:plain
ちゃんとサーバにアクセスした上で、304を受け取っています。

Windowsでsshしてターミナル作業してるときに「テロン」「テロン」ってうるさい音を消す

基本的にオフィスではPCの音は全消ししてたので、いままでは気にしてなかったのですが、
世の中はすっかり在宅勤務時代。

同僚の方とZoomなどでつないで、時にはサーバに入って作業している状況をシェアすることも増えました。
そのときに… tabキーで補完をするたびに「テロン♪」「テロン♪」 ってうるさーーーーい!!


ググってもググっても ぴったりなものが見つからなかったのですが*1……


やっと見つけました!
infotech.hateblo.jp

「一般の警告音」をオフにすることによって、止められました-!

*1:Bash on Windowsでビープ音を消す というのは見つかるのだが、これで止められるのはローカルでターミナル作業しているときだけで、サーバ上だとダメポ

SRE Lounge #12 に参加しました!

やったこと

こちらに参加しました!
sre-lounge.connpass.com

今回は、オンライン参加でハードルが低かったこともあり、運用に近いところをやってくれている、これからやろうとしてくれているメンバー2人を誘って一緒に参加しました。
セッション中は、Twitterでワーワーいうのもやってたんですが、同時に、社内のMS Teamsで、セッションの内容を自分たちの事例に置き換えながら雑談する、というのも並行してやってました。

分かったこと

  • NewRelicのブログすごい。ボリュームが凄くて読みきれないけど、リンクとして残しておきたい…のでメモ。

あとは要所要所「なるほど!」とか「そうだよね!」ってのがあったのですが、twitter.com
自分が門外漢だからなのかな、いまいち消化しきれませんでした。

それよりも、途中途中、
自分たちの部署の事例に置き換えながら、3人で雑談してたのがなかなか楽しかったです。
「この3人で話すのか」っていう、ちょっとレアな組み合わせだったのもあって新鮮でした。

部署内のパブリックなチャネル*1で会話していたので、このやりとりが、誰かの目には止まってたかも。

次にやること

常々、みんながもっともっと自主的に勉強するエンジニアを組織を作りたい、勉強会とかバンバン行ってほしい…と思いつつ、
自身が背中を見せられていない不言不実行状態が続いておりました。
そういった意味で、今日はとても楽しい時間でした。
特に都内はまだまだオンラインでの勉強会が続くかな…?と思いますので、
積極的に周りのメンバーを誘って、また他の勉強会に参加し、部署内に雰囲気を作っていきたいと思います。

*1:勉強会などについて語る専用のチャネルです

守備には3種類あると思った

今、自分の中では世紀の発見をしたくらいのキモチになってまして、忘れないように書きとめておこうと思います。
多分後で読み返したら「なにを当たり前のことを言ってるんだ」って感じだと思うんですけど。

その昔書いたこの記事のように、サッカーだったり剣道だったり、時々野球だったりをイメージしてるんですが、団体競技でも個人競技でも何かしら攻防のある、お好みのスポーツをイメージしてもらえれば意味は通じる…と思います。多分。
ログイン - はてな(仕事の話です)剣道とサッカーと交渉ごとって似ていると思うんですよ - エンジニア的なネタを毎週書くブログ

さて、その上でタイトルに書いたとおり、「守備には3種類ある」のだと思い至りました。
1. 相手の攻撃を止める守備
2. 相手の攻撃を止めた上で攻撃に転じる守備
3. 相手をコントロールし、相手の攻撃の幅を狭めることによって行う守備

1. 相手の攻撃を止める守備

サッカーであればとりあえずシュートを止めるとか。自陣内で相手からボールを奪うとか。
剣道であれば打ってきた面をとりあえず竹刀で受けるとか。
相手がポイントを取ろうとしてきた攻撃をなにかの方法で防いで、失点を0にする、最も直接的な守備です。

2. 相手の攻撃を止めた上で攻撃に転じる守備

1.で相手の攻撃を止めた上で、その機を逃さずに攻撃に転じることです。狭義では「守備」ではないかもしれませんが、
相手に攻撃を仕掛ける → 相手が守りに転じる → 相手の攻撃の機会を奪う
となり、結果的に相手に攻撃させない、広義での「守備」となります。
スポーツで言えばカウンターが相当すると思います。

3. 相手をコントロールし、相手の攻撃の幅を狭めることによって行う守備

1.は相手の攻撃に対して応じた動き、2.はそこで終わらずにそこから攻撃に転じることによって相手の攻撃機会を減らすアクションでした。
3.は、よりこちらから働きかけていく守備です。
右サイドを固めておくことで左側へ誘導する…といったことです。

システムの「運用」も同じ!

ここまで、一体何の話が始まったんだ!? という内容をお送りしてまいりました。
システムの開発/運用における「守備」とも言える運用においても、同様に3つの守備 が定義できると思います。

1. 相手の攻撃を止める守備

とにかく被害を出さないアクションです。
トラブルが発生しているのであれば復旧する、バグがあるなら直してリリースする、期日までに終えないとサービスに問題がある作業があるのであれば終える。
などです。
流通など、実際のサービスへの影響が起きない、または置きても小さくて済めば成功と言えると思います。

2. 相手の攻撃を止めた上で攻撃に転じる守備

1.で被害を出さなかった上で、1で起こるような問題の原因を潰しに行くようなアクションがこちらです。
手順がまとまっていないオペレーションが原因でトラブルが起きやすいので再発防止のために手順書をちゃんと書く とか
SQLに不慣れなメンバーが多くてバグが多いのでSQLを勉強してもらう とか
何か能動的なアクションを起こすことによって、これまで発生している問題を潰しに行くのが2です。
一見、次の3.のようにも感じますが、
何か悪いコトがまず起こり、発生した問題に対応するなにか施策を行う
というアクションですので、2.です。

3. 相手をコントロールし、相手の攻撃の幅を狭めることによって行う守備

では3.は何かというと、そもそもまだ発生していない問題を察知し、先に潰しに行く というアクションです。
例えば、

  • トラフィック増に伴って検索処理の性能劣化が見られるので、システム増強しておくことでトラブルを未然に防ぐ

など、まだ問題の形にすらなっていない種を発見し、潰しにかかるのがこちらです。

Windows10にOracleをインストールしようとしたらありがちな罠にハマった

Oracle18cのWindows用のZipを落としてきて、解答して、
setup.exe
を管理者権限で実行するんだけど、一瞬だけウインドウが表示されたあと、すぐに消えてしまう現象が発生。

ググると同じお悩みの人は多い。
質問サイトを読んでいると…

"Remove all the spaces in the name of directory"
community.oracle.com

ビンゴ! "Program Files" の下でやろうとしてたのが原因でした。
ありがち。
https://community.oracle.com/thread/4175173

f:id:taichiw:20200209125846p:plain
※ダウンロードも時間かかったけど、セットアップがまた長い…