.net - 在 Linux 上从 .NET Core 连接到 Informix
问题描述
我们正在尝试找出一个将 a 连接.NET Core Microservice
到 Informix DB 的好策略。在.NET Core Microservice
RHEL Linux 上运行。
我们当前的实现使用OdbcConnection
.NET Core 类来尝试连接。无论我尝试了什么,我也得到了相同的结果。它无法连接。
这是我们正在使用的示例连接字符串:
Dsn=;Driver=/opt/HCL/informix/4.10/lib/cli/iclis09b.so;Host=redactedip;Server=redactedserver;Protocol=olsoctcp;Database=redacted;LogonID=redacted;Uid=redacted;Pwd=redacted; Client_Locale=en_US.CP1252;Db_Locale=en_US.819;
我尝试了一个odbc.ini
包含 DSN 的文件。这适用于命令行中的 isql,但不适用于我们的 .NET Core 应用程序。(我们也使用上述相同的设置在 odbc.ini 中设置 DSN)
我还尝试了许多不同方式的连接字符串。没有哪个有效。
可以在没有 odbc.ini 的情况下连接到 Linux 上的 Informix 吗?(仅使用连接字符串?)
.NET Core 是否有其他包/解决方案可能比原始 ODBC 连接更好、更健壮?我见过IBM.Data.DB2.Core
应该能够访问 Informix 的软件包。有没有人成功使用过这个?
即使是 .NET Core 应用程序的任何类型的工作 Linux 配置的源示例也会有所帮助......
有任何想法吗?
解决方案
好的,很高兴地说我找到了解决方案。正如 jsagrera 提到的 UNICODE=UCS-2 设置似乎非常重要。以下是一些配置错误的东西,一旦我修复了,它们就真的很有帮助:
1) 权限 - 确保您对 informix 驱动程序目录具有适当的权限。
2) 权限 - 确保您对 odbcinst.ini 具有适当的权限
3) 确保您在连接字符串或 odbc.ini 中引用的任何驱动程序在 odbcinst.ini 中作为匹配项存在
4) 您可以使用连接字符串,但仍必须为该 UNICODE 设置引用 odbc.ini 文件。我尝试了一些不同的方法来解决它,方法是将其作为 ENV 变量或连接字符串本身包含在内。它似乎不起作用。
5) 以下是我在连接字符串中使用的一些属性:Dsn=;Driver=Informix;Host=redactedIP;Server=redactedsqlhost;Protocol=olsoctcp;Database=redacted;Uid=redacted;Pwd=redacted;Client_Locale=en_US.CP1252 ;Db_Locale=en_US.819; 6) 我还必须为我的进程定义以下环境变量:INFORMIXDIR、INFORMIXSQLHOSTS、ODBCINI、LD_LIBRARY_PATH
祝你好运!我仍在研究 unicode 的解决方案,因此我不必在我的 odbc.ini 文件中包含该条目。
更新:在对 DB2 .NET Core Provider 进行了额外的实验之后,我也能够与之连接。(在我为 informix 启用 DRDA 协议之后)。如果您正在寻找一种简单的方法来测试 .NET Core Provider,我建议您下载 Informix Docker Container。它已经启用了 DRDA,您可以通过 localhost 连接进行实验。
推荐阅读
- android - Android 中的 TagManager:无法加载容器。未找到资源 ID -1 的默认容器资源
- python - 为什么我的带有平铺地图的 pygame 游戏滞后?
- java-8 - 返回可选
或 Optional.empty() - kotlin - 不断调用 recylerview notifyDataSetChanged 块 UI
- c# - 超时在 HttpWebRequest 中不起作用 - C#
- ffmpeg - Ffmpeg 2单输出中的输入摄像机
- bokeh - 无法使用带有自定义 HTML 的 Bokeh Hovertool 格式化日期时间
- python - 在 Python 中导入自定义模块 [虽然它在 PyCharm 中有效]
- jupyter - Jupyter Notebook 无法在 Mac (.zsh) 上打开
- firebase - 如何为 Firestore 进行增量备份