Lambda関数をPython3.6から3.9に変更
CodeGuru ProfilerでLambda関数(Python 3.9)のパフォーマンスを確認したでPython3.8と3.9が対象なので、それまで3.6で実行していたLambda関数のランタイムを3.9にしました。
「 [Action Required] AWS Lambda end of support for Python 3.7」のメールも2023/9/9に来てますし、いつまで3.6のままなんだとお叱りを受けそうです。
エラー対応を記録しておきます。
まずそのままランタイムをPython 3.9に変更しました。
目次
cannot import name ‘is_ipaddress’ from ‘urllib3.util.ssl_’
[ERROR] Runtime.ImportModuleError: Unable to import module ‘lambda_function’: cannot import name ‘is_ipaddress’ from ‘urllib3.util.ssl_’ (/var/task/urllib3/util/ssl_.py)
requestsモジュールを使用しているLambda関数です。
3.6のときと同じモジュールだとエラーになりました。
そりゃそうです。
ということで、ローカルのPython 3.9環境でrequestsモジュールをインストールしなおしてZipにしてコードをアップロードし直しました。
レイヤーにして呼び出したほうがいいのですが、ひとまずさっさと実行してみたかったので、コードと一緒にアップロードしました。
1 2 |
pip3 install requests -t . |
Unable to import module ‘codeguru_profiler_agent.aws_lambda.lambda_handler’: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the ‘ssl’ module is compiled with ‘OpenSSL 1.0.2k-fips
[ERROR] Runtime.ImportModuleError: Unable to import module ‘codeguru_profiler_agent.aws_lambda.lambda_handler’: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the ‘ssl’ module is compiled with ‘OpenSSL 1.0.2k-fips 26 Jan 2017’. See: https://github.com/urllib3/urllib3/issues/2168
エラーメッセージが変わりました。
エラー対応しているときにランタイムをPython 3.8に変更していたことがまず1つの原因でしたので、Python 3.9に戻しました。
cannot import name ‘DEFAULT_CIPHERS’ from ‘urllib3.util.ssl_’
[ERROR] Runtime.ImportModuleError: Unable to import module ‘codeguru_profiler_agent.aws_lambda.lambda_handler’: cannot import name ‘DEFAULT_CIPHERS’ from ‘urllib3.util.ssl_’ (/var/task/urllib3/util/ssl_.py)
エラーメッセージが変わりました。
“cannot import name ‘DEFAULT_CIPHERS’ from ‘urllib3.util.ssl_'”の原因を参考にさせていただいて次の対応をしました。
Zipを作っているディレクトリで、urllibから始まるディレクトリを2つ削除(アンインストール)。
1 2 |
pip3 install 'urllib3<2' -t . |
urllib3のみダウングレードして1.26.16になりました。
これでZipにしてコードをアップロードし直しました。
エラーなくLambda関数を実行できました。
最後までお読みいただきましてありがとうございました!
「AWS認定資格試験テキスト&問題集 AWS認定ソリューションアーキテクト - プロフェッショナル 改訂第2版」という本を書きました。

「AWS認定資格試験テキスト AWS認定クラウドプラクティショナー 改訂第3版」という本を書きました。

「ポケットスタディ AWS認定 デベロッパーアソシエイト [DVA-C02対応] 」という本を書きました。

「要点整理から攻略するAWS認定ソリューションアーキテクト-アソシエイト」という本を書きました。

「AWSではじめるLinux入門ガイド」という本を書きました。


開発ベンダー5年、ユーザ企業システム部門通算9年、ITインストラクター5年目でプロトタイプビルダーもやりだしたSoftware Engineerです。
質問はコメントかSNSなどからお気軽にどうぞ。
出来る限りなるべく答えます。
このブログの内容/発言の一切は個人の見解であり、所属する組織とは関係ありません。
このブログは経験したことなどの共有を目的としており、手順や結果などを保証するものではありません。
ご参考にされる際は、読者様自身のご判断にてご対応をお願いいたします。
また、勉強会やイベントのレポートは自分が気になったことをメモしたり、聞いて思ったことを書いていますので、登壇者の意見や発表内容ではありません。
ad
ad
関連記事
-
-
Amazon EC2 インスタンスメタデータサービス(IMDS) v2のみにしました
今さらながらですが、EC2 インスタンスメタデータサービス(IMDS) v2を確 …
-
-
Amazon Connectで電話を転送する
かかってきた電話を転送するようにしました。 問い合わせフローで[終了/転送]から …
-
-
AWS X-Ray SDK for PythonをOrganizations組織内にLambda Layersで共有しました
ローカルでパッケージ作成 インストールコマンドはこちらAWS X-Ray SDK …
-
-
AWSアカウント内のすべてのS3バケットを削除するLambda(Python)
やりたいこと 特定アカウント内のS3バケットを全部削除したいです。 バケット内の …
-
-
slackのbotに天気を教えてもらう(Python on AWS Lambda + API Gateway)
slackのbotにAPIの定番ともいえる天気情報を教えてもらいました。 環境は …
-
-
Intel 82599 VF インターフェイスで拡張ネットワーキングが有効なEC2インスタンスで帯域幅を確認してみました
拡張ネットワーキングが有効なEC2インスタンスとそうではないインスタンスの2セッ …
-
-
Amazon SageMaker AIのクイックセットアップ
Amazon SageMaker AI のクイックセットアップを使用するに記載の …
-
-
AWS DeepLensセットアップの儀
AWS DeepLensのセットアップを開始します。 AWS DeepLensを …
-
-
slackのbotにWikipediaを調べてもらう(Python on AWS Lambda + API Gateway)
slackのbotに少しでも役に立ってもらおうと、Wikipediaを調べてもら …
-
-
JAWS-UG Osaka 第14回勉強会 「DIY」 〜自社内システムを作る側からの物申す〜に参加、運営、登壇しました
先日、JAWS-UG Osaka 第14回勉強会 「DIY」 〜自社内システムを …