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

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

新規登録して質問してみよう
ただいま回答率
85.35%
AWS Lambda

AWS Lambdaは、クラウド上でアプリを実行できるコンピューティングサービス。サーバーのプロビジョニングや管理を要せず複数のイベントに対してコードを実行します。カスタムロジック用いた他AWSサービスの拡張やAWSの規模やパフォーマンスを用いたバックエンドサービスを作成できます。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

AWS(Amazon Web Services)

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

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

Q&A

解決済

1回答

1202閲覧

じっさキュー方式で、一部の処理をメインとは別に実行したい。

yuki_90453

総合スコア326

AWS Lambda

AWS Lambdaは、クラウド上でアプリを実行できるコンピューティングサービス。サーバーのプロビジョニングや管理を要せず複数のイベントに対してコードを実行します。カスタムロジック用いた他AWSサービスの拡張やAWSの規模やパフォーマンスを用いたバックエンドサービスを作成できます。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

AWS(Amazon Web Services)

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

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

0グッド

0クリップ

投稿2020/07/04 05:22

編集2020/07/04 05:54

概要

POSTで受信したデータを元に処理行うAPIを作っています。
POST送信側へ5秒以内に応答する必要があるため、時間のかかる処理を書けず悩んでいます。

#試したこと

callback(null, { statusCode: 200, headers: {'Access-Control-Allow-Origin':'*'}, body:'Done' }) (実行したい関数)

下記のようにcallbackの後ろに実行したい関数を書いてみましたが、やはり処理が完全に終わるまでcallback処理してくれない為、結局実行時間は同じでした。

質問

このように実行時間が限れている環境で、時間のかかる処理をバックグラウンドまたはキュー方式で処理を予約するにはどのようにすれば良いのでしょうか?
簡単なアドバイスや、そういった時に使えるサービスがありましたら教えて下さい。

宜しくお願い致します。

追記 非同期処理について

サンプルコードになりますが、下記にようになります。
heavyMetodというのが処理に時間のかかるのメソッドになります。

export const handler=async(event:any, context:Context, callback:Callback)=>{ const order = JSON.parse(event.body) await heavyMetod(order) callback(null, { statusCode: 200, headers: {'Access-Control-Allow-Origin':'*'}, body:'Done' }) } const heavyMetod = async(data) =>{ const browser = await chromium.puppeteer.launch({ args: chromium.args, defaultViewport: chromium.defaultViewport, executablePath: await chromium.executablePath, headless: chromium.headless, }) let page = await browser.newPage(); await page.goto(data.url); const elem = await page.$x("//input[@name='auth']") if(Array.isArray(elem)){ await Promise.all([ elem[0].click(), page.waitForNavigation() ]) console.log(await page.title()) }else{ await Promise.all([ elem.click(), page.waitForNavigation() ]) console.log(await page.title()) } await browser.close() }

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

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

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

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

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

guest

回答1

0

ベストアンサー

投稿2020/07/04 05:29

y_waiwai

総合スコア88042

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

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

yuki_90453

2020/07/04 05:41

非同期処理について、完全に理解出来ていないのですが、以下質問お願い致します。 処理に時間かかる関数(以下、関数A)をayncで囲いPromiseで返すようにしているので、この関数Aは非同期処理に対応した関数かと思います。 しかし、メインフローから関数Aを呼んだ後、同期を待たずにメインフロー関数が完了してしまった場合、関数Aはそのタイミングで途中で終了してしまいますよね。。。? 非同期に関数を実行する場合、下記のように単純 awaitを書かずに関数を実行すれば良いのでしょうか? Brefore) await 関数A After) 関数A 宜しくお願い致します。
y_waiwai

2020/07/04 05:43

具体的なコードが提示されてないのでなんとも言えませんが、 非同期処理の終了を待つ手段は用意されてますよ
yuki_90453

2020/07/04 05:55

追記致しました。処理に時間のかかるメソッドはheavyMetodという部分になります。 この部分を非同期で実行したいのですが、アドバイス頂けないでしょうか?
y_waiwai

2020/07/04 05:59

提示のコードを実際に動かしてみて、不具合があるなら、その旨質問してください。 その場合は、ここの質問の趣旨とかけ離れすぎてるので、別の質問として挙げていただければいいかと思います
yuki_90453

2020/07/04 06:01

承知致しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問