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

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

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

MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

Q&A

解決済

1回答

2032閲覧

MongoDBのservice mongod statusでエラーが出てしまう

退会済みユーザー

退会済みユーザー

総合スコア0

MongoDB

MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

0グッド

0クリップ

投稿2018/06/25 15:14

編集2018/06/25 15:27

VPSを借りて、Linuxの勉強をしています。

Redirecting to /bin/systemctl status mongod.service ● mongod.service - High-performance, schema-free document-oriented database Loaded: loaded (/usr/lib/systemd/system/mongod.service; enabled; vendor preset: disabled) Active: failed (Result: exit-code) since 月 2018-06-25 23:54:08 JST; 6min ago Docs: https://docs.mongodb.org/manual Process: 21247 ExecStart=/usr/bin/mongod $OPTIONS (code=exited, status=100) Process: 21245 ExecStartPre=/usr/bin/chmod 0755 /var/run/mongodb (code=exited, status=0/SUCCESS) Process: 21243 ExecStartPre=/usr/bin/chown mongod:mongod /var/run/mongodb (code=exited, status=0/SUCCESS) Process: 21242 ExecStartPre=/usr/bin/mkdir -p /var/run/mongodb (code=exited, status=0/SUCCESS)

mongod.confのbind_ipをレンタルしたVPSのIPに設定し、restartをかけようと思い、statusを確認しようとしたら上記のエラーが発生していました。
service mongod restartをかけると

Job for mongod.service failed because the control process exited with error code. See "systemctl status mongod.service" and "journalctl -xe" for details.

と表示され実行できません。
statusコマンド時に記載されている下から4行目のエラーが原因ではないかと思っています。
エラーコード:100は致命的なエラーと公式のマニュアルに記載されており、自分なりに色々と探ってみたのですが、さっぱりわからずどうして良いものかと、、、。
もしよろしければ、お教えいただければ幸いです。

環境は以下になっています(関係あるかわかりませんが)
ディストリビューション:CentOS7
httpd:nginx1.15

[追記]
VPS mongoDBで検索し、インストール方法に問題がないか調べていたところ、
起動に必要なディレクトリ/data/dbを作成していないことがわかり、早速作成し、statusを確認したところ、

Redirecting to /bin/systemctl status mongod.service ● mongod.service - High-performance, schema-free document-oriented database Loaded: loaded (/usr/lib/systemd/system/mongod.service; enabled; vendor preset: disabled) Active: failed (Result: exit-code) since 火 2018-06-26 00:22:36 JST; 1min 9s ago Docs: https://docs.mongodb.org/manual Process: 21523 ExecStart=/usr/bin/mongod $OPTIONS (code=exited, status=48) Process: 21521 ExecStartPre=/usr/bin/chmod 0755 /var/run/mongodb (code=exited, status=0/SUCCESS) Process: 21519 ExecStartPre=/usr/bin/chown mongod:mongod /var/run/mongodb (code=exited, status=0/SUCCESS) Process: 21518 ExecStartPre=/usr/bin/mkdir -p /var/run/mongodb (code=exited, status=0/SUCCESS)

エラーstatusが100(mongodプロセスがキャッチされない例外をスローしたときに返されます。<公式マニュアル参照>)から48(エラーにより、新規接続を開始したmongodかmongos、着信接続を待機できませんでした。)に変わりました。

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

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

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

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

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

guest

回答1

0

ベストアンサー

一つの推測はフォーク前の親プロセスはあの新しいIPのバインド待ち状態でsystemctlのタイムアウトを超えた。

親プロセスはバインドとlistenができない場合に子プロセスをフォークしない。
https://github.com/mongodb/mongo/blob/v3.6/src/mongo/db/db.cpp#L1041-L1045

まずstdoutをよく隠しているsystemctlでじゃなくシェルで実行することが勧めたいんです。多いいrpmパッケージの設定によるとこの「sudo -u <ユーザ>」とコンフィグファイルでできる。

shell

1sudo -u mongod mongod -f /etc/mongod.conf

親プロセスのシェル出力の中で真実が現れるかな。

投稿2018/07/19 11:50

akira_kurogane

総合スコア48

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問