Skip to content

さくらインターネットからご提供して頂いた計200台のサーバー申請フォームです。README に沿って申請すると、Dojo 向けのサーバーをご利用いいただけます。

License

Notifications You must be signed in to change notification settings

coderdojo-japan/dojopaas

Repository files navigation

DojoPaaS ~ CoderDojo のためのサーバー利用申請手続き

Build Status

このプロジェクトはさくらインターネット様からご提供いただいた「さくらのクラウド」上の各インスタンス及び、それぞれのサーバーアカウントを管理するためのプロジェクトです。

servers.csv に記載された情報に基づいて GitHub Actions 経由で自動的にサーバーが起動します。

Note

本システムの背景と概要、および活用例などについては以下の SAKURA internet のレポート記事・動画からご確認いただけます。

DojoPaaS のシステム概要


📹 DojoPaaS の使い方

サーバーを申請する準備から利用申請・削除までの手順を説明する動画を作りました! 「文章だけだと分かりにくい」といった場合にご活用ください ;)

DojoPaas 解説動画へのリンク

下記の手順を説明する動画となっておりますので、GitHub や公開鍵認証などに慣れている場合は、下記の手順を読みながら直接進めていっても問題ありません 🆗

Tip

公開鍵認証がよくわからない場合は「よく分かる公開鍵認証」~初心者でもよくわかる!VPSによるWebサーバー運用講座を読んでみてください 📑👀


1. サーバーがほしい方へ

以下のリンク先にあるCSVに対して必要事項を記入したプルリクエストをお願いします。

https://github.com/coderdojo-japan/dojopaas/blob/master/servers.csv
プルリクエストの例: #1

Note

代表者の代理で別の担当者が申請する場合は、代表から代理人に移譲された旨をプルリクエストにコメントしていただけると幸いです (参考: 代理申請の例)。

各項目の説明

  • name: サーバーの名前。他のものと重複しないようにしてください。FQDNとかがいいかもですね。これはインスタンスの名前に使用されます。
  • branch: 道場の名前。アルファベットの小文字でお願いします。これはインスタンスのタグにも使用されます。
  • description: サーバーの用途など、後からわかりやすいものをお願いします。
  • pubkey: SSHで接続するための公開鍵。秘密鍵とまちがえないようくれぐれもお願いします。

公開鍵のサンプル: https://github.com/miya0001.keys

Important

秘密鍵と公開鍵を間違えない ようお願いします! git pushする前によーくご確認ください。


2. SSHの接続方法

プルリクエストがマージされてから1時間ほど経つと、以下のURLにIPアドレスのリストがコミットされます。その中からご自身が申請したサーバーを探して、そのIPアドレスをSSHコマンドで指定してください。

https://github.com/coderdojo-japan/dojopaas/blob/gh-pages/instances.csv

上記ファイル内に当該サーバーの行が追加されたら、次のような形式で接続できるようになります

$ ssh ubuntu@<ip-address>

または

$ ssh -i <path-to-privatekey> ubuntu@<ip-address>
  • ユーザー名はすべて ubuntu です。
  • プルリクエストの際にご連絡をいただいた公開鍵に対応する秘密鍵がないと接続できません。
  • ポート番号は22 (SSH), 80 (HTTP), 443 (HTTPS) のみが空いている状態になります。 詳細は、サーバー生成時に実行されるスタートアップスクリプトをご参照ください。

3. サーバーが不要になったとき

さくらインターネット様からご提供いただいているサーバーの台数には限りがあり、みなさんで共同利用するカタチとなっております。サーバー申請の流れと同じで、申請時に追加した行を servers.csv から削除することでサーバーの使用を停止できます。


よくある質問と回答

Q. サーバーでどんなことができるの?

例えばマインクラフト用のサーバーを立てることができます!CoderDojo 三島・沼津が用意したマイクラサーバー構築スクリプトがあるので、サーバーに詳しくない方でも手順に沿って進みやすくなっています。興味あればぜひ! 😉

:octocat: マインクラフトサーバー構築方法 (DojoPaaS利用者向け) - GitHub


Q. サーバーを初期化したい場合はどうすればよいですか?

A. こちらのフォームから依頼してもらえれば! 角カッコ 【】 に依頼する道場名、申請者名、IPアドレスをそれぞれ入力してください。

初期化処理が開始したらステータスが Closed になるので、2. SSHの接続方法を参考に当該サーバーに接続してみてください。

Warning

⚠️ 初期化すると IP アドレスが変わる点にご注意ください。


Q. SSH で接続できなくなりました。どうすればよいですか?

CoderDojo Japan では各サーバーの管理までは対応しておりません。ただし、サーバーの初期化であれば対応できますので、必要であれば前項にある手順に沿って初期化依頼を出していただけると幸いです。


Q. サーバーの知識があまりないです。どうすればよいですか?

@manzyun さんが書いてくれた簡易ハンドブックがあります。基本的なポイントだけを押さえておりますので、必要に応じてご参照ください。


Q. 作成されるサーバーの仕様を教えてください

  • OS: Ubuntu 24.04.2 (LTS)
  • CPU: 1コア
  • メモリ: 1GB
  • HDD: 20GB
  • リージョン: 石狩第二ゾーン

Q. ooo.coderdojo.jp のようなサブドメインは使えますか?

以前、実験的にサブドメインを各 Dojo に提供した期間がありましたが、DNS の更新・管理コストが肥大化し他の業務に支障が出てしまったたり、Subdomain Takeover などのセキュリティ上の課題解決が難しいため、現在は原則としてサブドメインの提供には対応しておりません 🙇


Q. 開発に貢献する方法を教えてください

ローカルでテストするには以下の要領でお願いします。

環境変数を設定

さくらのクラウドのAPIへの接続に必要な情報を環境変数で設定してください。

export SACLOUD_ACCESS_TOKEN=xxxx
export SACLOUD_ACCESS_TOKEN_SECRET=xxxx

実行

$ gem install
$ bundle exec rake test # 単体のテスト
$ bundle exec ruby scripts/deploy.rb # 本番環境でインスタンスを作成

開発時の注意事項

  • 本システムで作成されたすべてのインスタンスには dojopaas というタグをつけ、そのタグを利用しています。他の方法で起動したインスタンスにこのタグを付けないでください
  • CSVのフォーマットに対してもテストを行っています。CI の結果に赤いバツ印がある場合はエラーが出ているということなので、マージする前に原因を調べていただけると幸いです

開発者向け: サーバー初期化依頼への対応方法

サーバー初期化依頼の Issue は、以下の手順で対応できます。

  1. 依頼対象のサーバーを確認
ruby scripts/initialize_server.rb --find https://github.com/coderdojo-japan/dojopaas/issues/XXX
  1. サーバー削除を実行
# 削除するサーバーを確認してから削除する場合(推奨)
ruby scripts/initialize_server.rb --delete [IPアドレス]

# 削除するサーバーを確認せずに、削除する場合
ruby scripts/initialize_server.rb --delete [IPアドレス] --force
  1. 空コミットでCI実行
    削除後、空コミットを push し、GitHub Actionsで新しいサーバーが再作成されます。
git commit --allow-empty -m "Fix #XXX: Empty commit to run CI/CD again to initialize server"  
  1. 完了確認
ruby scripts/initialize_server.rb --find [道場名]
ruby scripts/initialize_server.rb --find [IPアドレス]

# 例: サーバー名「coderdojo-japan」の状況を確認する場合
ruby scripts/initialize_server.rb --find coderdojo-japan  

Caution

注意事項

  • サーバー削除は取り消せません。必ず削除対象をご確認ください
  • 使い方の詳細は ruby scripts/initialize_server.rb --help で確認できます
  • 原則としてIPアドレスが変わる点にご注意ください (稀に同じになる場合もあります)

DojoPaaS 関連記事


開発・運営

Copyright © 一般社団法人 CoderDojo Japan (@coderdojo-japan).

About

さくらインターネットからご提供して頂いた計200台のサーバー申請フォームです。README に沿って申請すると、Dojo 向けのサーバーをご利用いいただけます。

Topics

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

 

Packages

No packages published

Contributors 84