🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
AWS Lambda

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

並列処理

複数の計算が同時に実行される手法

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

2263閲覧

pythonでthread処理を走らせたい

pokemonta

総合スコア170

AWS Lambda

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

並列処理

複数の計算が同時に実行される手法

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/01/28 02:59

編集2021/01/29 07:23

大量のmap型が格納されているitems(リスト)を
parseしてdynamodb(データベース)に書き込みたいです。

実装してみましたが、いまいち性能効果が見られません。
どのように改善すべきでしょうか?
(そもそもマルチスレッドがうまく実装できているのかもわかりません)

python

1"""This is sample program.""" 2import logging 3import boto3 4from concurrent.futures import ThreadPoolExecutor 5 6LOGGER = logging.getLogger() 7LOGGER.setLevel(logging.INFO) 8DYNAMO = boto3.resource('dynamodb') 9 10def lambda_handler(): 11 12 items = [ 13 { 14 'user_name': 'user1', 15 'blog': 'blog1', 16 'count': '111', 17 }, 18 { 19 'user_name': 'user2', 20 'blog': 'blog2', 21 'count': '112', 22 }, 23 { 24 'user_name': 'user3', 25 'blog': 'blog3', 26 'count': '113', 27 } 28 ] 29 """ 30 DynamoDB put item 31 """ 32 try: 33 table_name = "test-batch" 34 35 # put items (use Batch Writing) 36 table = DYNAMO.Table(table_name) 37 38 process_list = [] 39 with ThreadPoolExecutor() as executor: 40 with table.batch_writer(overwrite_by_pkeys=['user_name', 'blog']) as batch: 41 for item in items: 42 process_list.append(executor.submit(batch.put_item(Item=item))) 43 for process in process_list: 44 print(process.result()) 45 return "end" 46 except Exception as error: 47 LOGGER.error(error) 48 raise error 49 50if __name__ == "__main__": 51 lambda_handler()

for i in range(3):みたいに
配下の関数を3回実行するような処理の場合の
並列処理はイメージできますが、リンク内容
上記の1つのitems に対して1000以上オブジェクトがぶらついているときに
どのように分割して処理させるものでしょうか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

マルチスレッドなどの並列処理を行って性能が上がるかどうかは、コーディング以前に、そのアプリケーションの性質によります。
チューニングをするのならば、性能測定ツールを使ってどこで待たされているのかをチェックするべきです。

ただ、一般的には、データベース関連のアプリケーションはデータベースアクセスがボトルネックになって、多くの場合は並列化しても性能が上がりません。なぜならば、CPU内の計算処理や主記憶のメモリアクセスに比べて、ハードディスクやSSDなどのストレージは遅い上に、データベースの整合性維持のための排他制御が行われるのでさらに遅いためです。

投稿2021/01/28 03:42

ppaul

総合スコア24670

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

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

pokemonta

2021/01/28 04:22

table.batch_writerで配列分DB書き込みしている部分で時間がかかっています。 (全体の95%以上を占める。) この書き込み処理部分を並列化したいです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問