06:40:14
icon

おはようございます。

06:40:29
2024-11-28 09:00:38 MICROPEN情報センター님의 게시물 info@mi.kuropen.org
icon

This account is not set to public on notestock.

06:40:59
icon

このあと 7:00 からこのサーバーは止まります
https://status.kuropen.org/maintenance/451708

Web site image
MICROPENサーバー システム切り替え作業 | Kuropen.org
08:36:47
icon

新サーバー起動。とりあえず様子見中。
動作に問題なければ8:45くらいにメンテ完了宣言出す

09:06:37
icon

メトリクス収集のコンフィグなどをいじっていてメンテ完了宣言が遅れたが、そろそろ完了宣言出そう

09:10:12
2024-11-30 09:10:08 MICROPEN情報センター님의 게시물 info@mi.kuropen.org
icon

This account is not set to public on notestock.

09:12:56
icon

@acid_rain@amefur.asia おはようございます!

09:19:45
icon

【MICROPENサーバー 本日のメンテナンスでの変更点】
- Misskeyのバージョンが 2024.11.0 になりました
- サーバーを Oracle Cloud 東京リージョン から さくらのVPS 石狩リージョン に移動しました
- サーバーOSを Ubuntu 20.04 から almalinux 9 に変更しました
- アプリケーション側のリバースプロキシを Cloudflare + nginx から Caddy に変更しました (メディアストレージは Cloudflare + Cloudflare R2 のままです)
- サーバーのメトリクス監視を Mackerel から Better Stackに変更しました
- IPv6アドレスのみを持つActivityPubインスタンスとの連合に対応しました
- SSH接続におけるセキュリティ対策の方法を変更しました

10:33:57
2024-11-30 10:24:01 stux⚡님의 게시물 stux@mstdn.social
icon

This account is not set to public on notestock.

10:33:58
2024-11-30 10:29:33 Hostdon公式アカウント님의 게시물 hostdon@mstdn.hostdon.jp
icon

【障害情報】
【復旧済】
現在オブジェクトストレージにて障害が発生しております。そのため、画像の閲覧や投稿ができない状況となっております。
この問題について、事業者側での復旧作業完了待ちとなっています。
復旧までしばらくお待ち下さい。

11:02:46
2024-11-29 12:08:10 kt2003님의 게시물 kt2003@www2.kt2003.info
icon

This account is not set to public on notestock.

11:08:04
icon

FacebookとBlueskyでは投稿者が投稿時にサムネイルを削除することができる。

Chatworkなどでは受信側でリンクプレビュー自体を表示するかどうかを選択できる仕様になっている。

11:10:47
icon

Misskeyの場合は 設定→データセーバー→URLプレビューのサムネイルを非表示 で、受け手がリンクプレビューに含まれる画像を非表示にすることはできる。

Attach image
15:24:48
2024-11-30 14:06:44 のえる님의 게시물 noellabo@fedibird.com
icon

Mastodonの画像処理についてちょっと書いておきましょうか。

まず、Mastodonは、サーバのユーザーが投稿しようとしている画像、リモートからやってきた投稿などについてくるリモート画像を、添付ファイルの保存場所に保存します。

ファイルの取得がエラーになったり、ファイル種別と拡張子がウソだったり、サイズが大きすぎたり、未対応の形式だった場合、

投稿の場合はWebUIやクライアントにエラーを返し、

リモート画像の場合はURLだけ保存して、ファイル未取得の添付ファイルとしてデータベースに記録を保存します。

添付ファイルは通常、APIから取得した場合、様々なメタデータを取得できますが、未取得・エラーの場合はそれを提供できないので、ほとんどがデータなし、ファイル種別は不明になります。

リモートのURLだけは教えてくれるので、クライアントアプリの実装側で、これを直接参照して、うまくいけば画像表示することは可能です。

ただし、Mastodonが通常行う、不正なデータを拒否し、サイズを調整し、必要なら読める形式に画像変換するなど、安全に対する対策が効かなくなります。

そのために直接参照ではなく取得したデータを提供しているので、安直にリモートURLへフォールバックすることはお勧めしません。

15:24:56
2024-11-30 14:06:56 のえる님의 게시물 noellabo@fedibird.com
icon

WebUIでは『利用できません』という表示とともに、クリックしたときにローカルサーバのメディアプロキシのURLに飛ぶように、添付ファイルの表示を行います。

このプロキシは、クリックしてリクエストされると、そのタイミングでもう一度リモートへメディアを取得しにいき、うまく取得できたらその画像のURLにリダイレクトしてくれます。

うまく取得できたら、サーバ上のリモート画像も保存されるので、次回からは『利用できません』ではなく、ちゃんと画像が表示されるようになります。

誰かが必要としたタイミングでリトライし、復元するための機能です。よくできてますね。

また、未対応形式の場合は、サムネイルは表示できませんが、リモートのURLに直接ジャンプするリンクになります。

相手先のサーバが対応している場合、添付ファイルにはブラーハッシュ(BlurHash)という、画像を極端にぼかしたイメージを再現するためのデータがついています。

サムネイルとしてセンシティブ画像などを伏せる際に使われる他、画像取得中の一時表示、そして取得失敗したときに、画像の代わりに表示します。

ブラーハッシュの実体は短いテキストなので、保存コストがゼロに近く、画像の保存や取得と違い、受け取り失敗することがないため、非常に便利な仕組みです。

15:25:06
2024-11-30 14:21:43 のえる님의 게시물 noellabo@fedibird.com
icon

Mastodonは、サーバが利用者を守る設計になっています。

利用者の代わりに、サーバがリモートの情報にアクセスし、適切な変換をかけ、それを提供します。

サイズが大きすぎれば縮小し、一般的でない形式は扱える形式に変換し、サムネイルやブラーハッシュを生成して軽量に内容を確認できるようにします。

悪意あるメディアはブラウザをクラッシュさせるかもしれませんし、規格外のデータは、利用者の帯域(とくにモバイル)を大量消費したり、相手サーバの応答が遅ければクライアントの動作に悪影響を与えることもあります。

また、事前に代理取得しておくことで、いつアクセスしたか、誰がアクセスしたかをリモート側に悟られないよう隠蔽し、アクセスするブラウザの脆弱性などを突かれて不正なプログラムを仕込まれたり、情報が盗まれたり、騙されたりしないようにしています。

これらの処理は、サーバ側では処理や保管に相応の負担を引き受けることになりますが、

クライアントのプライバシーが守られ、安全で楽で快適になりますし、

全クライアントが直接アクセスするより、相手サーバも送信トラフィックが減ることになります。

(他方、CDNやリバースプロキシで軽減できますが、連合したサーバ数だけ同時アクセスが行われる問題はあります)

15:25:18
2024-11-30 14:42:54 のえる님의 게시물 noellabo@fedibird.com
icon

メディアの保存には、Mastodonのプログラムを置いて実行しているサーバのローカルストレージに直接保存する方法の他、オブジェクトストレージという、メディアを保存する専用の保管場所を使うこともできます。

ローカルストレージを使った方法は、別途サーバを用意する必要がないこと、仕組みが単純なことから、設置・提供が簡単というメリットもありますが、

メディアは大量に保存され、保存容量がどんどん増えていくため、

ストレージが不足してエラーになり、その際にサーバプロセスも巻き添えにして全部に影響を与えてしまう問題、

サーバの処理負担の増大とトラフィックが多くなる(転送量課金されるとサーバで特に厳しい)問題、

サーバが大きくなってきた時に、複数のサーバで構成しようと思っても、特定サーバのストレージに依存していることで台数を増やせない(スケールアップできない)問題などがあり、

大量のデータを保存しても自動拡大し(事実上、お金を払えば無限に保存できる)、サーバプロセスとは分離した保管場所として、オブジェクトストレージを利用することがあります。

AWS(S3)やAzure、GCP、Wasabi、Cloudflare R2、VPS業者提供のものなどがよく利用されています。

Misskeyなども事情は同様です。

15:25:32
2024-11-30 15:07:48 のえる님의 게시물 noellabo@fedibird.com
icon

オブジェクトストレージはすごく便利なのですが、短所もあります。

オブジェクトストレージは比較的みなで同じサービスを使っていることが多いので、今回のWasabiの障害のように、複数のサーバで同時に障害が発生する結果となることがあります。

オブジェクトストレージは通常、多重にバックアップされる運用がされており、データが失われる可能性が極めて低くなるように設計されていて、たとえ一時的な障害が発生しても永久に内容が失われる心配はあまりされていません。

どうにもならず失われた場合、あきらめるという運用が一般的で、オブジェクトストレージをバックアップする運用は少ないと思われます。

信頼性はAmazon S3が圧倒的に高いですが、落ちたことがないワケではありません。

Wasabiは、昔はよく落ちましたが、最近は安定しています。でも、忘れた頃に障害を発生させます。

オブジェクトストレージサービスを自分で設置することもできるので、そういう運用をしている人もいます。

ただ、S3より信頼性の高いサービスができるかというと、難しいです。

バックアップを万全にしようとか、スケールやパフォーマンスを確保しようとするとコストが跳ね上がるので、自前運用する場合は、どのレベルで妥協するかがポイントになってきます。

15:25:39
2024-11-30 15:23:59 のえる님의 게시물 noellabo@fedibird.com
icon

Mastodon本体とオブジェクトストレージが分離していることで、理解しにくい挙動をすることがあります。

投稿に画像を添付してアップロードできるのに、それが壊れた画像になって表示できないという現象です。

この場合、オブジェクトストレージへの保存の経路は生きていて、参照する経路が死んでいます。

投稿したサーバには、画像は正しく保存されています。

参照する経路は、Mastodon本体とは別経路のサーバを辿るので、そういう不具合の出方もあります。

参照経路が回復したら、表示されるようになります。

なお、この参照に不具合が発生しているときにリモートに投稿が配送された場合、挙動は二通りになります。

リモートサーバからは参照でき、正しく扱われ、ちゃんと表示される場合と、

リモートからも参照経路から画像を取得できず、保存も表示も失敗する場合です。

後者の場合、後日参照経路が回復してから再取得されない限り、先方では壊れたままになるので、投稿タイミングはちょっと考えどころですね。

他のサーバの状況は、いくつかのサーバにアカウントがある状態でないと検証できないので、違うサーバのアカウントを使う仲間同士で連携をとっておくか、自分で複数アカウントを運用して相互フォローしておくのが吉です。