ヤマムギ

growing hard days.

*

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にしてコードをアップロードし直しました。
レイヤーにして呼び出したほうがいいのですが、ひとまずさっさと実行してみたかったので、コードと一緒にアップロードしました。

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つ削除(アンインストール)。

urllib3のみダウングレードして1.26.16になりました。
これでZipにしてコードをアップロードし直しました。

エラーなくLambda関数を実行できました。


最後までお読みいただきましてありがとうございました!

「AWS認定資格試験テキスト&問題集 AWS認定ソリューションアーキテクト - プロフェッショナル 改訂第2版」という本を書きました。

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

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

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

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

 - AWS , ,

ad

ad

  関連記事

AWS CloudWatch LogsエージェントでAmazon EC2上のNginxのaccess.log , error.log , php-fpm error.log , Linuxのmessages , secureログを収集する

参考ページ クイックスタート: 実行中の EC2 インスタンスに CloudWa …

ブログの画像を別アカウントのS3に移動するためにIAMロールでクロスアカウントアクセス

ずっと先延ばしにしていたのですが、このブログの画像はEC2から直接配信しています …

Amazon ECSサービスでAWS App Meshを使用

AWS App MeshユーザーガイドのAWS App Mesh とAmazon …

AWS Client VPNを設定しました

ユーザーガイドのクライアント VPN の開始方法に沿ってやりました。 AWSクラ …

S3バケットにWebフォントをアップロードしてCORSを設定する

Webフォントファイルは、モジワク研究さんのマメロンを使用させていただきました。 …

Developers Summit 2018 「AWSのフルマネージドな環境でCI/CDをやってみよう!AWS Cloud9からAWS Fargateへの継続的デプロイをご紹介」を聞きました

※写真は展示のAmazon Echoです。 以下は、思ったことや気になったことを …

Cloud9 Python3でpipも3にする

このブログは、2019/10/20に書いた、 Cloud9のAMIがCloud9 …

ヤマムギvol.23 Amazon RDS for MySQLとAmazon Aurora Serverlessの起動のデモをしました

ゴールデンウィーク毎朝デモ勉強会は終わったのですが、土曜日にやれるときがあれば、 …

AWS Backupで取得したAMIとスナップショットの削除

個人で使っているAWSリソースの断捨離をしてました。 Cloud9も複数アカウン …

Amazon API GatewayのIAM認証の動作を確認しました

API GatewayのIAM認証は、IAMユーザーが実行できるように認証する、 …