私はRDSのMySql経由でデータにアクセスするラムダマイクロサービスを構築しています。私の地元のユニットテストはうまく動作しますが、私はAWSに公開するときに、私は次のエラーを取得する:ここでAWS Lambda、.Net Core、&MySql:ファイルまたはアセンブリのSystem.Diagnostics.TraceSourceを読み込めませんでした。バージョン4.0.0.0
{
"TypeName": "MySql.Data.MySqlClient.MySqlTrace",
"Message": "The type initializer for 'MySql.Data.MySqlClient.MySqlTrace' threw an exception.",
"Data": {},
"InnerException": {
"Message": "Could not load file or assembly 'System.Diagnostics.TraceSource, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a'. The system cannot find the file specified.\n",
"FileName": "System.Diagnostics.TraceSource, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a",
"Data": {},
"InnerException": {
"Message": "'System.Diagnostics.TraceSource, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' not found in the deployment package or in the installed Microsoft.NETCore.App.",
"FileName": null,
"Data": {},
"InnerException": null,
"StackTrace": " at AWSLambda.Internal.Bootstrap.LambdaAssemblyLoadContext.Load(AssemblyName assemblyName)\n at System.Runtime.Loader.AssemblyLoadContext.ResolveUsingLoad(AssemblyName assemblyName)\n at System.Runtime.Loader.AssemblyLoadContext.Resolve(IntPtr gchManagedAssemblyLoadContext, AssemblyName assemblyName)",
"HelpLink": null,
"Source": "Bootstrap",
"HResult": -2147024894
},
"StackTrace": null,
"HelpLink": null,
"Source": null,
"HResult": -2147024894
},
"StackTrace": " at MySql.Data.MySqlClient.MySqlTrace.LogError(Int32 id, String msg)\n at MySql.Data.MySqlClient.MySqlPool.TryToGetDriver()\n at MySql.Data.MySqlClient.MySqlPool.GetConnection()\n at MySql.Data.MySqlClient.MySqlConnection.Open()\n at HealthStats.Functions.GetLocationTypes(APIGatewayProxyRequest request, ILambdaContext context)",
"HelpLink": null,
"Source": "MySql.Data",
"HResult": -2146233036
}
は私のproject.jsonファイルです。私はSystem.Diagnostics.TraceSource
ライブラリを標準的なプロジェクトの依存関係(図示せず)とフレームワークの依存関係(下記参照)として追加しようとしました。私の思考は、おそらく自分のコードでTraceSourceを直接使用していなかったので、アセンブリを追加していなかったことを公開していたのかもしれません。しかし、いずれの試みも問題を解決しませんでした:
{
"version": "1.0.0-*",
"buildOptions": {
"emitEntryPoint": false
},
"dependencies": {
"Amazon.Lambda.APIGatewayEvents": "1.0.1",
"Amazon.Lambda.Core": "1.0.0",
"Amazon.Lambda.Serialization.Json": "1.0.1",
"Amazon.Lambda.Tools": {
"type": "build",
"version": "1.1.0-preview1"
},
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.0"
},
"MySql.Data": "7.0.6-IR31"
},
"tools": {
"Amazon.Lambda.Tools" : "1.1.0-preview1"
},
"frameworks": {
"netcoreapp1.0": {
"dependencies": {
"System.Diagnostics.TraceSource": "4.0.0"
},
"imports": [
"dnxcore50",
"portable-net45+win8"
]
}
}
}
アイデアはありますか?
これで解決しましたか?私はmysqlのためにsapientguardian nugetパッケージでef coreを使用していますが、同じことをやっています。 –
同様の問題を解決しました。私がしなければならなかったのは 'dotnet publish'でしたし、\ publish \ runtimes \ unix \ lib \ netstandard1.3サブフォルダからdllをパブリッシュフォルダにコピーしてください。公開フォルダ(ランタイムフォルダは含まれていません)の内容を圧縮し、ラムダにアップロードします。あなたが@xonと@SnOrfusの両方で動作するかどうかを教えてください –
@JonPetersonあなたが回答として投稿したいのであれば、私はそれを投票したいと思います。それは私のために働いた。アセンブリをパブリッシュフォルダにコピーしてから、ビジュアルスタジオからパブリッシュを使用して(コピーされたアセンブリをピックアップすると思っていましたが)動作しませんでした。だから私は正しい道を歩いていた。ヒントをありがとう! –