質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.44%
Discord

Discordは、ゲーマー向けのボイスチャットアプリです。チャット・通話がブラウザ上で利用可能で、個人専用サーバーも開設できます。通話中でも音楽を流したり、PC画面を共有できるなど多機能な点が特徴です。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

1回答

1414閲覧

AWS上で常時DiscordのBotを動かし、Botを常にログイン状態とする

lyzmfeqpxs54

総合スコア237

Discord

Discordは、ゲーマー向けのボイスチャットアプリです。チャット・通話がブラウザ上で利用可能で、個人専用サーバーも開設できます。通話中でも音楽を流したり、PC画面を共有できるなど多機能な点が特徴です。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2023/01/23 07:13

前提

AWS上で常時DiscordのBotを動かし、メンバーのロールの管理を行おうとしています。
プログラム自体はできており、フォアグラウンドでbotを起動し動作の確認は問題ないのですが「常時起動する」という部分で詰まっております。

実現したいこと

AWS上で常時DiscordのBotを動かし、Botを常にログイン状態とする。

発生している問題・エラーメッセージ

エラーは特にないので、試したこと部分にやったことを記載します。

該当のソースコード

Ruby

1# bot.rbファイル(プロジェクト内に配置) 2clas 3 4 # BOT情報 5 BOT_TOKEN = "XXXXXXXX" 6 BOT_CLIENT_ID = YYYYYYYYYY 7 BOT_CLIENT_SECRET = "ZZZZZZZZ" 8 9 def initialize 10 @bot = Discordrb::Commands::CommandBot.new( 11 token: BOT_TOKEN, 12 client_id: BOT_CLIENT_ID, 13 prefix: '!' 14 ) 15 end 16 17 def start 18 settings 19 @bot.run 20 end 21 22 def settings 23 ## この中にロール管理についていろいろ 24 end 25 26end 27 28discordBot = DiscordBot.new 29discordBot.start 30 31 32

試したこと

エラーはないのですが、「該当のソースコード」のようにプロジェクト内にbot.rbを配置し、
$ bundle exec rails runner bot.rb

で起動すると
Running via Spring preloader in process 24196
[INFO : websocket @ 2023-01-23 06:52:22.182] Discord using gateway protocol version: 6, requested: 6

となり、Botが起動、ログイン状態となります。

これをデーモンで動かしたいので、
$ bundle exec rails runner bot.rb &

としてバックグラウンドで動かしても、テラタームを切断した1時間後くらいにBotはログアウトしてしまいます。

nohupを付けるという記事も見かけたのですが
$ nohup bundle exec rails runner bot.rb &

で動かそうとすると、
Running via Spring preloader in process 24196
[INFO : websocket @ 2023-01-23 06:52:22.182] Discord using gateway protocol version: 6, requested: 6

のメッセージが出ずbotが立ち上がりません。

また
https://www.codereading.com/nb/ignore-sighp-with-disown.html
を参考に

$ bundle exec rails runner bot.rb &

で起動後
$ disown -h [jobspec]

でテラタームとの切り離しもやってみたのですが、やはり1時間後くらいにログアウト状態となってしまいます。

適切な方法をご教示いただけますと幸いです。
以上、よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yu_1985

2023/01/23 07:38

>メッセージが出ずbotが立ち上がりません バックグラウンドで実行するとメーセージもバックグラウンドになるので表示されないのが正しいのでは。 psコマンドなり、ログなりで確認してはどうでしょうか。 また、以下のあたりは調べてみましたでしょうか。 https://qiita.com/DQNEO/items/0b5d0bc5d3cf407cb7ff
lyzmfeqpxs54

2023/01/23 09:43

ご指摘ありがとうございます。 フォアグラウンドの際には $ ps aux | grep bot rails 26294 4.1 0.5 230028 22124 pts/1 S+ 09:38 0:00 /home/rails/.rbenv/versions/3.1.3/bin/ruby bin/rails runner bot.rb rails 26309 0.5 4.2 1139196 170256 ? Ssl 09:38 0:00 bot.rb rails 26327 0.0 0.0 119432 992 pts/2 S+ 09:38 0:00 grep --color=auto bot となっており nohup時には $ ps aux | grep bot rails 26379 1.5 0.5 230036 21824 pts/1 S 09:39 0:00 /home/rails/.rbenv/versions/3.1.3/bin/ruby bin/rails runner bot.rb rails 26406 0.0 0.0 119432 940 pts/2 S+ 09:40 0:00 grep --color=auto bot で一つプロセスが少ない状態となっています nohup.outには特にログは出ていません
lyzmfeqpxs54

2023/01/25 07:08

yu_1985様にご指摘いただいたLinexのサービスとして起動する方法で無事実現できました。 本当にありがとうございました。
guest

回答1

0

自己解決

ご教示いただいた下記URLを参考に、linuxのサービスとして登録し起動したら、Botを常時起動することができました。

https://qiita.com/DQNEO/items/0b5d0bc5d3cf407cb7ff

投稿2023/01/25 06:18

lyzmfeqpxs54

総合スコア237

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.44%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問