如何在 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="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"" 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 中却必须这样做...
我使用 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="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"" 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 中却必须这样做...