我想测试数据库可以在很短的时间内连接,例如我想在3秒内测试它.
我写了这些代码.
我写了这些代码.
bool IsCanConnectioned = false; string connStr = connectionString + ";Connection Timeout=3000"; sqlConnection sqlConnection = new sqlConnection(connStr); try { sqlConnection.open(); IsCanConnectioned = true; } catch { IsCanConnectioned = false; } finally { sqlConnection.Close(); sqlConnection.dispose(); } return IsCanConnectioned;
我打破了我的网络到这个测试的数据库,
但是设置连接超时3000或3无效.
它将在很长一段时间后超过15秒抛出异常.
(我猜这是因为网络超时)
我想在3秒内测试它.所以有一个很好的方法来做到这一点.
可能是它可以启动一个新的线程连接数据库,我等待线程3秒,当它没有响应或返回false时,我说数据库无法连接,但是有更好的方法吗?
解决方法
您说您为此测试打破了网络,但是当您可以访问安装了sqlServer的服务器时,会应用ConnectionTimeout.否则涉及TCP超时,默认为15秒.
如果您想要超时,即使网络已关闭,您应该设置tcp连接并尝试连接.有关如何操作,请参阅this answer.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。