はじめに
Herokuの無料枠が11月いっぱいで終わっちゃう! みんなのbotをホストしてくれていたのに!
まあ無料なのでそんなこともあります。問題は、次どこにしようってことなんだが……。
色々探した結果、Oracle Cloudの無料枠が良さげだったのでここに記録しておきます。
Herokuほどお手軽ではないですが、どうせ一度セットアップしてしまえば放置するものなので頑張りましょう。
なおこの記事ではpython環境のdiscord.py前提とします。jsの方はわからん。
あとlsとかcdとか最低限のLinuxコマンド知識があるものとします。
用意するもの
わかる人向けの概略
- Oracle CloudでOracle Linuxのインスタンスを1つ作ります。
- teratermとかで接続します。
- Pythonのバージョンが古いので3.9とかに上げます。
- gitとかWinSCPとかでbotのファイル一式をアップロードします
- nohupでプロセスを開始します。完了!
詳細手順
Oracle Cloudを用意する
Oracle Cloudはその名の通りOracleが提供しているクラウドプラットフォームです。Oracle Linuxとかいう独自のLinux環境をホストできます。
まずは公式ページにアクセスしてアカウントを作ります。
アカウント作成は見ればわかると思うので省略します。
メルアドの他に地域とか支払情報とか色々求められます。無料枠のためにクレカ教えるのはなんか腹立ちますがまあしょうがないですね。
地域選択のところで東京地域は需要が高いので云々みたいな警告が出ますが、私は東京を選んで今のところなんも問題ないです。
晴れてアカウントが作られるとダッシュボードにアクセスできるようになります。
「インスタンス1」をクリックしてインスタンス一覧を出します。
ここの読み込みは10秒くらい待たされがちなのでページ変わってしばらく真っ白でも焦らず耐えてください。
作りたてなので一覧は空だと思います。「インスタンス作成」ボタンを押します。
「名前」のところにbotの名前を付けておくとよいです。
他はデフォルトのままでよいです。
「配置」と「イメージとシェイプ」それぞれに「Always Free対象」と出ていれば無料枠です。
SSHキーはわかる人はよしなにしてください。
わからない人は、「キー・ペアを自動で生成」を選んでおいて、「秘密キーの保存」をクリックして.keyファイルをダウンロードしておいてください。
※このファイルをなくすとアクセスできなくなるので注意してください。
キーの用意ができたら「作成」ボタンを押してください。
インスタンス一覧に戻ると今作ったインスタンスが出現しています。
スクショだと実行中になってますが、作った直後だと準備中とかになってると思います。すぐ終わるのでしばし待ちましょう。
Oracle Linuxに接続する
わかる人は読み飛ばしてください。
シェルってなんじゃいという人はteratermをインストールしてください。
まずはインスタンスの接続情報を確認します。
インスタンス一覧で先ほど作ったものを選択すると、こんな画面が出ます。
右上にあるIPアドレスとユーザー名がログイン情報です。
さて、teratermを起動するとこんな画面が出ますので、ホストにインスタンスのIPアドレスを入力し、接続方法でSSHを選択します。
続けて認証画面が出ますので、ユーザー名にインスタンスのユーザー名、
秘密鍵(秘密キー)にはインスタンス作成時にダウンロードしておいた秘密鍵ファイルを指定します。
秘密鍵がパスワードなのでパスワード欄は空欄のままで大丈夫です。
秘密鍵ファイル選択時、デフォルトだと.keyファイルが表示されてないので右下で「すべてのファイル」を選択してください。
OKを押してこんな感じで接続できれば成功です。
python環境を構築する
Oracle Clouldは親切なのでなんとPython環境は最初から構築されています。
ただしバージョンが3.6.8です。discord.pyの要件が3.8以上なので古すぎです。有難迷惑……っ!
このままでは使えないので新たに3.9をインストールすることにします。
以下のコマンドを実行します。
sudo yum install python3.9
2
パスワードを聞かれたらOracle Cloudアカウントのパスワードを入力します。
コンソールにしばらく色々出た後で完了のメッセージが出ます。
完了したら次のコマンドを実行してください。
python3.9 --version
次のようにバージョン表示が出ればインストール完了です。
Python 3.9.7
このままだと素のpythonしかないのでここから色んなパッケージを追加するわけですが、素すぎてpipが入ってないのでまずpipを入れます。
以下のコマンドを実行してget-pip.pyをインスタンス上にダウンロードします。
wget https://bootstrap.pypa.io/get-pip.py
「‘get-pip.py’ saved」と出ればダウンロード完了です。
次に以下のコマンドでpython3.9にpipをインストールします。
python3.9 get-pip.py
なんやかんやとログがいっぱい流れた後に、インストールが完了します。
普通のpythonガイドだとpythonの実行コマンドはまんま「python」または「python3」になってると思いますが、この環境では既にインストール済みの3.6.8が実行されてしまうので毎回「python3.9」とバージョンまで指定してあげてください。
もっとスマートなやり方があるのかもしれないけどbotごときにそこまでがんばりたくないし……。
botをセットアップする
python環境ができたので、最後に必要なパッケージをインストールしていきます。
まずはbot本体のソースコード一式を用意します。Herokuを使っていた方は多分githubとかにアップロードしてあったと思うので、直接cloneできます。
まずは以下のコマンドでgitをインストールしておきます。
sudo yum install git
次にgit用のSSH鍵を用意します。これはOracle Cloud用の鍵とは別なので注意してください。
解説はググればいっぱい出るので割愛します。これとか。
gitにSSH接続できたら、以下のコマンドでcloneします。
git clone botのリポジトリ.git
gitを使いたくないとかコマンドわからんになった人はWinSCPなどのSFTPソフトからもファイルを転送できます。
シェルの時と同様IPアドレスとユーザー名、SSH秘密鍵があれば接続できます。
/home/[ユーザー名]
というディレクトリがホームなので、そこにファイルを配置すればOKです。
次にログインに使うトークンです。Herokuの場合はGUIで環境変数を設定してましたが、めんどくさいのでdotenvを使いましょう。
botの.pyファイルと同じディレクトリに「.env」というファイルを作って、こんな感じでトークンを保存しておきます。
DISCORD_BOT_TOKEN=YOUR_BOT_TOKEN_HERE
変数名はソースコードに合わせてください。
そしてbotのソースコードの先頭らへんにこんな感じで.envの読み込み処理を追加しておきます。
from dotenv import load_dotenv
load_dotenv()
これで.envに設定したトークンを環境変数として読み込めるようになります。
実行ファイルが出揃ったらいよいよ実行です。
cdコマンドでbotの.pyファイルがあるディレクトリに移動して、以下のコマンドでbotを開始します。
python3.9 [botのmainファイル名.py]
最初は多分、なんかのパッケージがないみたいなエラーが出て止まると思います。
pythonが素すぎるせいなので、順次インポートしましょう。
ないと言われたパッケージ名を元に以下のようにコマンドを実行します。
python3.9 -m pip install パッケージ名
たとえばdiscord.pyが無いと「discordがない」みたいなエラー(詳しい本文忘れた)が出るので、以下のようにします
python3.9 -m pip install discord
これをエラーがなくなるまで繰り返します。他の設定がちゃんとできてればそのうち動きます。
botをデプロイする
botが動くようになったら、最後にこれを常時起動できるようにします。
普通にpythonコマンドで実行するとシェルを切断した時にbotも停止してしまいます。
切断後もbotが動き続けるようにするには、以下のコマンドを実行します。
nohup python3.9 [botのmainファイル名.py] &
nohupは切断時に強制終了させなくするコマンドです。これに続けてbot実行のコマンドを実行することで常時起動状態にします。
シェルを切断してもbotが動いていることを確認してください。
やったー。
メンテなどでbotを停止したいときは、PIDを特定してkillコマンドを使います。
まずは以下のコマンドを実行します。
ps -ef | grep python3.9
3
結果が2行くらい出ると思います。右端がプロセス名です。
プロセス名が「python3.9 [botのmainファイル名.py]」になっている行の、左から2番目の数値をコピーしてください。画像で言うと「907451」の箇所です。これがPID(プロセスID)です。
そして、このプロセスIDを使って以下のコマンドを実行します
kill -9 PID
実行すると直ちに終了します。オンラインステータスが少しの間オンラインのまま残ることがありますが、すでに反応はなくちゃんと死んでいるはずです。
おしまい。
おわりに
やっぱり本格的なサービスなのでできることが多い反面DIY度が高いですね。
でもLinuxでなんやかんやしたことのある人にとっては特に新しく勉強することもなく使える類だと思います。使えた。
雰囲気でやってる人は……がんばれ。超がんばれ。
ところでdotenvじゃない正規の方(?)の環境変数設定法を調べたけど全然出ん。
.bash_profileに書いてsourceしても無視されるし英語でも情報がない。何これ。知ってる人はコメント頂けると誰かを救えるかもしれないし救えないかもしれない。
-
Oracle Cloudでは仮想のLinuxマシンをユーザーに割り当てて使ってもらうのだが、この仮想マシンが実際に動いているその1つ1つを指してインスタンスという。「実体」みたいな訳語が使われる。「インスタンスを作る」とはつまり「この設定のマシンを仮想環境上に構築する」みたいな意味。 ↩
-
違うかも。ここで試行錯誤して手間取ったから結局どれが正解だったかわかんなくなっちゃった。sudoはよくないぜみたいなWarningが出たのは覚えてるのだが……だめだったらコメントで教えてください ↩
-
どーでもいいですがこのgive_me_promptとかいう珍名botの正体はAI生成画像に特定絵文字でリアクションするとメタデータからpromptを拾ってDMしてくれるやつです。内輪用ですが欲しいという方にはお譲りしておりますのでtwitterでDMなどください。 ↩