私のnode.jsサーバーから別のサーバーにエラーを記録します。私はelasticsearch、logstashとkibanaの使用を考えています。自分のノードサーバーでELKを設定する方法を知りたい。node.jsでELKを設定するには
答えて
以前の組織ではまさにこの使用例でした。あなたのnodejsアプリはエラー/警告/情報などの異なるフォーマットでファイルにログインします(bunyanはこれを使用できます)。これは基本的にBeats + ELKのスタートアップの基本的なチュートリアルです - ELK - https://www.elastic.co/guide/en/beats/libbeat/current/getting-started.html
Filebeatはこれらのログファイルの末尾にあり、logstashサーバーにメッセージを送信します。 Logstash input.confには入力フィルタがいくつかあります(あなたの場合はエラーフィルタになります)。いずれかのログメッセージがこれらのフィルタを通過すると、logstashはoutput.confファイルで決められたように、それを何らかのエンドポイントに転送します。ここで
は、私たちが何をしたかである -
初期アーキテクチャ - 尾にnodejsサーバー上のログをfilebeat(以前の私たちはlogstashフォワーダを使用)、クライアントをインストールし、マシンをlogstashするためにそれを転送します。 Logstashは入力ログに対して何らかの処理を行い、それらをESクラスタに送ります(Logstashと同じマシン上にある可能性があります)。キバナはこのESの視覚化に過ぎません。
最終的なアーキテクチャ - 小規模なトラフィックでは初期セットアップがクールでしたが、logstashは単一障害点となり、トラフィックが増加するとログが失われる可能性があることがわかりました。そこで、カフカとLogstashを統合し、システムのスケールをスムーズに行えるようにしました。ここに記事があります - https://www.elastic.co/blog/logstash-kafka-intro
これは役に立ちます!
アプリケーションからログを収集するエージェントを実行しないでlogstashを使用することは可能です。 Logstashには入力プラグイン(https://www.elastic.co/guide/en/logstash/current/input-plugins.html)があります。これは、パイプラインで設定できます。 1つの基本的な設定は、TCP(https://www.elastic.co/guide/en/logstash/current/plugins-inputs-tcp.html)またはUDP(https://www.elastic.co/guide/en/logstash/current/plugins-inputs-udp.html)inputプラグインを設定することです)Logstashは、プラグインで設定されたポートでリスンすることができます。 その後、アプリケーションはlogstashサーバにログを直接送信できます。耐久性があることがLogstashパイプラインを構成することによりES。 、データの損失を回避することができます。このアプローチは、アプリケーションサーバーが(コンテナのように)短命あるときに優れている。nodejsについては
、https://www.npmjs.com/package/winston-logstashはかなり有効であるパッケージです。この要点https://gist.github.com/jgoodall/6323951は、他の言語での全体的なアプローチの良い例を提供します。
これは、サンプル(最小)TCPインプですプラグインの設定
input {
tcp {
'port' => '9563'
}
}
- 1. Elk Elasticsearch logstashの設定
- 2. フラスコサーバーでELKを設定する方法は?
- 3. Docker ELK内のLogstash設定ファイル
- 4. Node.jsを再設定するには?
- 5. Node.jsでファイルエンコーディングを設定する方法
- 6. Node.jsのAWSでELBを設定する
- 7. Linux:nginxにnode.jsを設定する
- 8. Node.jsグローバルプロキシ設定
- 9. node.js jade - jadeでコンテンツタイプを設定するには
- 10. node.js httpクライアントでソケット接続のタイムアウトを設定するには
- 11. Node.jsにクッキー値を設定します
- 12. node.jsのクロムレスページ設定
- 13. WebStorm Node.js Vagrantインタプリタを設定する
- 14. トップビート(ELK)の電子メールアラートの設定方法
- 15. Node.js、エラー344は、設定された後にヘッダーを設定できません。
- 16. node.js(simple-sshモジュール)でSSHエージェントフォワーディングを設定する方法は?
- 17. Winston/Node.jsでログレベルを設定する方法は?
- 18. Node.js DNSルックアップ - タイムアウトを設定するには?
- 19. node.jsプロセスでv8のメモリ管理をスマートに設定する
- 20. node.jsのクエリーストリングでエンコーディングをfalseに設定する
- 21. ロッキングドライバを設定することにより、ドッキング用コンテナログをELKスタックに送信する - 簡単な方法
- 22. ELKアナライザを理解する
- 23. Javascript node.js、別のページで使用するCookieを設定する
- 24. Nginx.confとNode.jsの設定シナリオ
- 25. Nginx + PHP、Node.js、jQueryの設定
- 26. 設定ファイルのベストプラクティスnode.js
- 27. node.jsのセッション記憶設定
- 28. 私の 'portfolio'サイトでexpress.jsでNode.jsを設定する
- 29. ELK - Logstashでデータをフィルタリングする
- 30. elasticsearchでインデックスを再インデックスする - ELK
返信ありがとうございます。セットアップ、confファイル、node.js層からのログの記録に必要な基本的なインストール手順を順を追って説明できますか? –
各コンポーネントとステップについてのチュートリアルで答えを編集しました:) –
それは助けましたか?それとも他の助けが必要ですか? –