Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Rails 8で作るActivityPub リレーサーバ
Search
S.H.
December 05, 2024
0
390
Rails 8で作るActivityPub リレーサーバ
RubyWorld Conference 2024 Sponser LT
S.H.
December 05, 2024
Tweet
Share
More Decks by S.H.
See All by S.H.
ゆるゆるMastodon 鯖缶生活
gamelinks007
0
580
1週間で作るActivityPubリレーサーバ
gamelinks007
0
79
Developing an ActivityPub Relay with Rails 8
gamelinks007
0
38
Mastodon on Ruby master
gamelinks007
0
100
Trying to Make Ruby's Parser Available as a Gem
gamelinks007
1
310
ユーザーから見たLrama
gamelinks007
0
210
Contributing to the Ruby Parser
gamelinks007
2
1.1k
Featured
See All Featured
Testing 201, or: Great Expectations
jmmastey
42
7.5k
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
45
7.2k
Scaling GitHub
holman
459
140k
For a Future-Friendly Web
brad_frost
177
9.7k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
105
19k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
41
2.3k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
34
2.9k
Designing for humans not robots
tammielis
253
25k
Building Applications with DynamoDB
mza
94
6.4k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
5
550
Gamification - CAS2011
davidbonilla
81
5.3k
Site-Speed That Sticks
csswizardry
6
530
Transcript
Rails 8 で作る ActivityPub リレーサーバ S.H. RubyWorld Conference 2024 Sponser
LT 2024-12-05
自己紹介 S.H. ESM, Inc 構文解析器研究部員 Mastodonの管理人(通称:鯖缶)
今日話すこと ActivityPub リレーについて 作った背景 作ったもの
ActivityPubリレー
ActivityPub リレーの仕組み リレーサーバに参加しているサーバの公開投稿を 受け取る 参加しているサーバ全てに受け取った投稿を転送 する
メリットとデメリット Fediverseのサーバ同士が連合しやすくなる 配送される投稿が増えるので参加サーバへの負 荷も増える リレーサーバ自体の負荷もそれなりにかかる
作った背景
現状のリレーサーバ サーバの数に対してリレーサーバの数が多くな いため、特定のリレーサーバに集中する リレーサーバ自体と参加したサーバへの負荷が かかりやすい RedisやDBなどを使うため建てるのに気合が いる
個人的な思い 小さい規模のリレーサーバを作れれば負荷も分 散できそう もっとリレーサーバを建てやすくするとよさそう
Rails8の存在 Kamal2でデプロイが簡単になる SolidQueueを使うのでRedisがいらない SQLite3を本番で使えるので楽そう Rails8で作るといいのでは?
作ったもの
ActivityPub Relay
機能 Mastodon/Misskeyのリレーに対応 Pleroma/Akkomaのリレーにも対応 購読サーバの管理画面 ジョブの管理画面
作ってみて Kamal2でのデプロイが非常に簡単 Thrusterが証明書の自動更新などがされるの で嬉しい SolidQueueを使っているのでRedisが不要で 良い SQLite3を使っているので別途DBを建てなく てよい