如何在 Raspberry pi 2 (Mono 4 + ARM proc) 上部署 npgsql?

how to deploy npgsql on Raspberry pi 2 (Mono 4 + ARM proc)?

我使用 Visual studio 2013 (Windows) 使用 Npgsql 和 Entity Framework 6.

构建一个小型 .NET 4.5 应用程序

在 windows 上它运行良好。 但是在 Raspbian,应用程序崩溃,提示找不到 npgsql 提供程序。

   Unhandled Exception:
System.Configuration.ConfigurationErrorsException: Failed to find or load the registered .Net Framework Data Provider 'Npgsql'.
  at System.Data.Common.DbProviderFactories.GetFactory (System.String providerInvariantName) [0x00000] in <filename unknown>:0
[...]

在我的 raspberry pi 2.

我已经手动安装了Mono v4.0.2

我复制了我的应用包括:

npgsql.dll v2.2.5.0

npgsql.entityframework同版本

mono.security v4.0.2

我的 app.config 包含:

  <?xml version="1.0" encoding="utf-8"?>
<configuration>
  <configSections>
    <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
  </configSections>
  <entityFramework>
    <providers>
            <provider invariantName="Npgsql" type="Npgsql.NpgsqlServices, Npgsql.EntityFramework" />
    </providers>
  </entityFramework>
  <connectionStrings>
    <add name="minitestEntities" connectionString="metadata=res://*/Model2.csdl|res://*/Model2.ssdl|res://*/Model2.msl;provider=Npgsql;provider connection string=&quot;PORT=5432;TIMEOUT=15;POOLING=True;MINPOOLSIZE=1;MAXPOOLSIZE=20;COMMANDTIMEOUT=20;COMPATIBLE=2.2.5.0;DATABASE=minitest;HOST=10.0.0.1;INTEGRATED SECURITY=True;PASSWORD=azerty;USER ID=theuser&quot;" providerName="System.Data.EntityClient" />
  </connectionStrings>
</configuration>

所以我想知道 npgsql 库是否正确加载,或者是否缺少引用。

我没有找到关于如何在最近的 mono + ARM 环境中使用 npgsql 的文档。 任何关于此的信息将不胜感激。

好的,我在另一个讨论中找到了解决方案。与此同时,我忘了记下它的 URL 所以这里是答案:

我们必须手动将提供商描述添加到 app.config 中:

<system.data>
  <DbProviderFactories>
    <add name="Npgsql Data Provider" 
         invariant="Npgsql" 
         support="FF" 
         description=".Net Framework Data Provider for Postgresql Server" 
         type="Npgsql.NpgsqlFactory, Npgsql, Version=2.2.5.0, Culture=neutral, PublicKeyToken=5d8b90d52f46fda7" />
  </DbProviderFactories>
</system.data>

版本和 PuclicKeyToken 必须与 npgsql.dll 匹配。 要获得 public 密钥令牌,您可以 运行 该代码:

typeof(Npgsql.NpgsqlFactory).AssemblyQualifiedName

现在我不知道为什么这一步在 windows 中不是必需的,但在 linux 中却必须这样做...