コード実行
Last updated
Last updated
コードノードは、Python / NodeJSコードを実行してワークフロー内でデータ変換を行うことをサポートします。これにより、Arithmetic、JSON変換、テキスト処理などのシナリオでワークフローが簡素化されます。
このノードは開発者の柔軟性を大幅に向上させ、ワークフロー内にカスタムPythonまたはJavascriptスクリプトを埋め込んで、事前設定されたノードでは達成できない方法で変数を操作することができます。設定オプションを使用して、必要な入力変数と出力変数を指定し、対応する実行コードを記述できます。
他のノードの変数をコードノードで使用する必要がある場合は、入力変数
で変数名を定義し、これらの変数を参照する必要があります。変数参照を参考にしてください。
コードノードを使用して、以下の一般的な操作を実行できます:
ワークフローでは、しばしば非構造化データの処理が必要です。例えば、JSON文字列の解析、抽出、変換などです。典型的な例として、HTTPノードのデータ処理があります。一般的なAPI応答構造では、データが多層のJSONオブジェクトにネストされていることがあり、特定のフィールドを抽出する必要があります。コードノードはこれらの操作を支援します。以下は、HTTPノードから返されたJSON文字列からdata.name
フィールドを抽出する簡単な例です:
ワークフロー内で複雑な数学計算を行う必要がある場合、コードノードを使用できます。例えば、複雑な数学公式の計算やデータの統計分析です。以下は、配列の平方差を計算する簡単な例です:
時には、複数のデータソースを結合する必要がある場合があります。例えば、複数の知識検索、データサーチ、API呼び出しなどです。コードノードはこれらのデータソースを統合するのに役立ちます。以下は、2つのナレッジベースのデータを結合する簡単な例です:
ローカルデプロイのユーザーである場合、悪意のあるコードが実行されないようにするためのサンドボックスサービスを起動する必要があります。このサービスを起動するにはDockerサービスを使用します。サンドボックスサービスの詳細はこちらから確認できます。また、docker-compose
を使用してサービスを直接起動することもできます:
PythonとJavascriptのいずれであっても、その実行環境は安全性を確保するために厳密に隔離(サンドボックス化)されています。これにより、ファイルシステムへの直接アクセス、ネットワークリクエストの実行、OSレベルのコマンドの実行など、システムリソースを大量に消費する可能性がある機能を使用することはできません。これらの制限により、コードの安全な実行が保証され、システムリソースの過剰消費が防止されます。
失敗後の再試行
ノードで起きる例外的な状況の中には、そのノードをもう一度試すだけで対応できるものがあります。エラーが発生した際に自動的に再試行をする機能が有効になっていれば、事前に設定された方針に従って再試行が行われます。再試行の最大回数や再試行間の時間を調整することで、再試行の方針を設定することが可能です。
再試行は最大で10回まで可能です
再試行の間隔は最長で5秒まで設定できます
エラー処理
プログラムを実行する際、コードが予期せぬエラーに直面することがあります。開発者は、エラーが発生した場合に備えて、エラー処理の手順を設定することで、ワークフローが中断されるのを防ぐことができます。以下のステップでエラー処理を設定できます。
コードノードのエラー処理を有効にする
エラー処理の方法を選択し、設定する
エラー処理に関するさらに詳細な情報は、エラー処理のガイドを参照してください。
コードを入力した後、なぜ保存できないのでしょうか?
安全上の問題を引き起こすコードがないか確認してください。例として以下のようなコードがあります:
このコードは次のような問題を含んでいます:
不正なファイルアクセス: コードが"/etc/passwd"ファイルを読み込もうとしています。これはUnix/Linux システムでユーザーアカウント情報を保持する重要なシステムファイルです。
秘密情報の漏えい: "/etc/passwd" ファイルにはシステムユーザーの重要な情報が含まれています。例えば、ユーザー名、ユーザーID、グループID、ホームディレクトリのパスなどです。これに直接アクセスすると情報漏えいのリスクがあります。
セキュリティリスクがあるコードは Cloudflare WAF により自動的にブロックされます。ブロックされたかどうかは、Webデバッグツールのネットワークタブで確認できます。