ApexドメインをALIASレコードで運用してはいけない

ApexドメインをALIASレコードで運用してはいけない

ApexドメインをALIASレコードで運用してはいけない

遅いぞ

English version is here.

ApexドメインはNakedドメインとも呼ばれ、サブドメインがついていないドメインを指す。自分のアプリ「Inkdrop」のウェブサイトを今まで inkdrop.app で運用してきたが、最近 www.inkdrop.app に移動した。Netlifyという、しばしば速いと評判のウェブホスティングサービスにデプロイしている。確かに、多くのNetlifyでホストされているウェブサイトがとても高速に読み込まれているのを目にした。しかしなぜか自分のサイトはそこまで速度が出ていなかった。特にTTFB (Time-to-first-byte)が異常に遅くて、常に200msより大きく、さらに120KBのダウンロードに800msもかかっていた。いったいなぜ?

ALIASレコードはgeo-targetingを無効化する

もしあなたが自分のドメインを持っているなら、Netlifyのドメインに対して CNAME を設定しなければならない。しかしながら、ApexドメインはDNSの仕様上 CNAME が割り当てられない。

NetlifyでApexドメインを使うには、その一つの方法として ALIAS レコードを使えとドキュメントにある:

Custom domains
A domain name is the URL or web address where visitors find your site. By default, any site on Netlify is accessible…

この ALIASレコードを使用するため、自分はNS1というDNSホスティングサービスを使っている。このNS1のドキュメントに ALIAS レコードに関する記述を見つけた:

Disadvantages of an ALIAS record
Geo-targeting information is lost.
Since it is the authoritative server for example.com (issuing the queries for lb.example.net), then any intelligent routing functionality on the lb.example.net record will act upon the location of the authoritative server instead of your location. The EDNS0 edns-client-subnet option does not apply here. This means that you may be potentially mis-routed. For example, if you are in New York and the authoritative server for example.com is in California, then lb.example.net will think you are in California, and will return an answer that is distinctly sub-optimal for you in New York.

まじか。

要するに、 ALIAS レコードはDNS問い合わせ時にNS1のサーバが仲介するので、Netlifyがサイトの訪問者がどの地域からアクセスしているのか分からなくなる、という事だ。厳密には常にNS1のサーバが置かれている地域からのアクセスということになる。なので転送経路を最適化できない。この件に関してNetlifyのフォーラムで質問してみた

という訳で残念ながらそれは真実のようであった。仕方ないので自分のサイトを www サブドメインに移すことにした。Apexドメインは(開発者から見て)美しいが、訪問者にとってはさして大きな問題ではなさそうだ。また、最近のブラウザは www をアドレスバーに表示しないことに気づいた。例えばChromeだと:

iOSのSafariでも表示されない:

Chromiumの中の人によればwww とか m (モバイル用)はGoogleから “trivial (重要でない)” と認識されていて、その理由は多くの人がそこにあんまり注意する必要性が無いからだとしている:

the www and m (for mobile) subdomains are being classified by Google as "trivial" subdomains because they feel most people do not need to be concerned with the information they represent.

自分もそうだなと思い当たるふしがあった。例えば今回の事があるまでNetlifyのウェブサイトが https://www.netlify.com/ だという事なんて気づかなかった。

TTFBが275msから73msに改善した

ご覧の通り、サイトのドメインをwww.inkdrop.app に移動したらめちゃくちゃ速くなった:

ダウンロード速度も申し分ない。Cool.

それでもApexドメインが使いたい?

foolが上記フォーラムで答えているとおり、あなたには2つの選択肢がある:

  1. Netlify DNSを使う。これは “Linked A Record” が使えるので彼らのgeo-targetingが有効にできる
  2. Cloudflareの CNAME flatteningを使う。それだとNetlifyのgeo-に干渉しない

なぜ自分が上記選択肢を取らなかったかと言うと、自分はすでにNS1を使っており、 www に移行するのが最も早かったからだ。

あなたのウェブサイトの速度改善の参考になれば嬉しい。

Read more

ノート駆動AIコーディング術の提案

ノート駆動AIコーディング術の提案

どうもTAKUYAです。みなさんはAIエージェントを普段のコーディングで活用されていますか。ちょっと面白いワークフローを思いついたのでシェアします。それは、ノート駆動のエージェンティック・コーディング・ワークフローです。最近Claude Codeのプランモードを使っていたら、ターミナル内で生成されたプランを読むのが辛かったんです。それで、じゃあMarkdownノートアプリであるInkdropをプランの保存先バックエンドとして使えば解決するんじゃないかと思って、 試してみました。こちらがそのデモです(英語): こちらがClaude Codeの設定ファイル群です: GitHub - inkdropapp/note-driven-agentic-coding-workflow at devas.lifeComplete Claude Code configuration collection - agents, skills, hooks, commands, rules, MCPs. Battle-tested configs from an Anthropic hackathon w

By Takuya Matsuyama
2025年個人開発活動の振り返り

2025年個人開発活動の振り返り

どうもTAKUYAです。もう1月も半ばに差し掛かっているけど、2025年の自分の活動の振り返りをしたい。去年を一言で言うなら、本厄を満喫した年だった。 厄年とは、人生の節目にあたって、体調不良や災難が起こりやすいと経験的に言われる年齢のこと。数え年で42歳、確かにもう若さに任せた事は出来ないなと痛感した年だった。(ところであなたの国ではこのような年はありますか?) 夏に体調を崩して2~3ヶ月動けなくなった 暖かくなり花粉が飛び出した頃に、持病のアトピーが悪化しだして、まともに生活出来なくなってしまった。酷さで言うと、2019年に脱ステした時と同じぐらい。 脱ステに無事成功したから、この地獄は二度と味わうことはないだろうと高を括っていたが、まさか7年後にまた味わうとは思わなかった。当時の独身時代と違い、妻も子供もいる中で、周りに多大な迷惑をかける事となった。夏の子供との思い出が全く無い。悲しい。 現在はQoLもほとんど元の状態まで復活できた。写真を撮って症状の変化を記録したので、機会があればシェアしたい。食事療法など色々試したが、結局歩くのが一番自分に効いた。それ以来、一日一万歩

By Takuya Matsuyama
書いて、歩け!なぜノートアプリはシンプルで充分なのか

書いて、歩け!なぜノートアプリはシンプルで充分なのか

どうもTAKUYAです。今回はノートやメモから新しい発想を生むための考え方についてシェアします。 自分はシンプルさをウリにした開発者向けのMarkdownアプリInkdropを作っています。なので、どうしても「ノートアプリの作者」としてのポジショントークが含まれてしまいますが、逆に言えば、「ノートアプリを約10年間作り続けてきた人間が、どうやってアイデアを生み出しているのか」 という実際的な体験談として読んでもらえれば幸いです。 結論から言うと、僕は「アプリ上でノート同士を連携させる必要はない。繋げるのはあなたの脳だ」と考えています。本稿では、ノートアプリの機能に溺れずユニークなアイデアを考え出すために僕が実践している事をシェアします。 TL;DR * ノート整理に時間をかけるな。グループ化で充分だ * すごい人はアイデアが「降りてくる」のを待つ * プログラミング × 料理動画 という有機的な掛け合わせ * ノートは「忘れる」ために書く * 歩け! ノート整理に時間をかけるな。グループ化で充分だ 巷ではZettelkastenなどが流行っているようですね。これ

By Takuya Matsuyama
貫禄を捨てて愛嬌で生き延びろ!40代オッサンの生存戦略

貫禄を捨てて愛嬌で生き延びろ!40代オッサンの生存戦略

どうもTAKUYAです。 つい先週(11月19日)に誕生日を迎え、41歳になりました。40代と言うのは若い頃には想像もしなかった年代で、どう生きれば良いのかというイメージがあまり具体的に湧かない、曖昧な年齢ではないでしょうか?自分の父親を想像するも、日中はいつも仕事でいなかったのであまり参考になりません。 自分は個人開発で生計を立てていて20代、30代で積み上げて来たものが上手く実を結んだおかげで今の生活があります。育児にも、いわゆるサラリーマンよりかは柔軟に参加できていて、子供との時間も沢山取れています。ママ友も出来ました(迷惑かけっぱなしですが)。 本記事では、そんなライフスタイルを送る自分が40代で大事にしたいことについて書きたいと思います。タイトルにもある通り、結論から言うとそれは「愛嬌」だと思います。以下、中年男性の愛嬌の重要性について説明します。 TL;DR * 「貫禄が出てきたね」と言われたら注意 * 笑顔を作れ。オッサンがムスッとしてたら普通に怖い * 謙虚に振る舞え。実績を積むと周りが萎縮する * ギャップ萌えを活用しろ 「貫禄が出てきたね」と言わ

By Takuya Matsuyama