ASP.NET+MSSQLLocalDB发布于IIS管理器时遭遇“在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器......”问题的解决方案

当在IIS中部署使用MSSQLLocalDB的应用时,由于IIS用户权限问题可能会遇到无法连接到SQLServer的错误。解决方法是通过IIS管理器,更改应用程序池的身份认证模式为特定用户,并设置正确的密码,然后重启应用池以解决问题。
摘要由CSDN通过智能技术生成

问题描述:
使用MSSQLLocalDB时,在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider: 命名管道提供程序, error: 50 - 无法打开到 SQL Server 的连接)

环境:SQL SERVER(MSSQLLocalDB)+VS2017+ASP.NET MVC+IIS(10.0)

问题原因:LocalDB的访问权限是根据访问者来变化的。在开发模式下,LoacalDB的创建一般是Administrator用户,开发工具VS的权限也是Administrator用户,所以访问LocalDB没有出现问题。当部署到IIS后,访问LocalDB的用户变成了IIS对应的用户,即‘IIS Pool\Your APPPoolName’,这时候由于IIS没有对应的访问权限,所以会报无法登陆的错误。

解决方案:
(1)打开IIS管理器,应用层程序池,找到对应引用,并且选择高级设置

在这里插入图片描述
(2)这两项如下设置
在这里插入图片描述
(3)重启后问题解决

参考文献:https://www.z01.com/item/3609

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值