在 NAS SMB 卷上用 Visual Studio 调试 ASP.NET + SQLServer 项目并部署到 IIS 服务

本文涉及的产品
对象存储 OSS,20GB 3个月
对象存储 OSS,恶意文件检测 1000次 1年
日志服务 SLS,月写入数据量 50GB 1个月
简介: 阿里云 NAS SMB 卷具有高可用高吞吐大容量等特点,可以很好地解决网站和数据库项目的存储问题。本文将介绍如何在 NAS SMB 卷上用 Visual Studio 调试 ASP.NET + SQLServer 项目并把项目部署到 IIS 服务作为正式服务开放出去。

阿里云 NAS SMB 卷具有高可用高吞吐大容量等特点,可以很好地解决网站和数据库项目的存储问题。本文将介绍如何在 NAS SMB 卷上用 Visual Studio 调试 ASP.NET + SQLServer 项目并把项目部署到 IIS 服务作为正式服务开放出去。用户可以用该方案直接在 NAS SMB 卷上进行编程调试和网站部署,不用担心本地盘的容量和可用性限制。

1. 安装 IIS 服务

安装 IIS 服务在文档 Windows IIS 服务挂载 NAS 共享文件存储 中有非常详细的叙述,用户可以参考该文档先安装好 IIS 服务。

2. 安装 Visual Studio Community 2019

可以在 Visual Studio 官网 下载 Visual Studio Community 2019。安装时记得选择 ASP.NET 工具。

安装时记得选择 ASP.NET 工具

3. 安装 SQL Server Express 2014

我们的实验中使用的是 SQL Server Express 2014,下载地址:https://www.microsoft.com/en-in/download/details.aspx?id=42299

下载时请选择 ExpressAndTools 64BIT\SQLEXPRWT_x64_ENU.exe。
下载时请选择 ExpressAndTools 64BIT\SQLEXPRWT_x64_ENU.exe

4. 编译调试 EnumSample 样例项目

为了方便演示如何用 Visual Studio 调试 ASP.NET + SQLServer,我们使用 ASP.NET 的一个样例项目 EnumSample 作为示例。

4.1. 下载 EnumSample 代码

可以在 ASP.NET 样例 Github 官网 上下载整个 ASP.NET 样例集 从而得到 EnumSample 代码。

ASP.NET 样例 Github 官网

4.2. 将 EnumSample 文件夹拷贝到 NAS SMB 卷上并用 Visual Studio 打开

下载完代码后解压并找到 EnumSample 项目并将其拷贝到本机挂载的 NAS SMB 卷上。
然后用 Visual Studio 打开。
会出现如下错误:
SQL Server Exception!

原因是在 NAS SMB 卷上的 EnumSample 的 Web.config 文件里的 connectionString 配置错误。
connectionString 配置错误

4.3. 通过 Visual Studio 建立 SQL Server 的 LocalDb

LocalDb 是 SQL Server 的一种轻量型引擎,可以用来调试程序和进行验证。

通过 Visual Studio 建立 LocalDb 的步骤如下:

4.3.1. Visual Studio 下选择 视图 -> SQLServer 对象管理器

Visual Studio 下选择 视图 -> SQLServer 对象管理器

4.3.2. 选择一个 LocalDb ,比如 (localdb)ProjectsV13 ,右键点击数据库,选择 添加数据库

选择 添加数据库

4.3.3. 填写数据库名称,比如 EnumSampleLocalDb

填写数据库名称,比如 EnumSampleLocalDb

注意:如果想要把数据库建立在 NAS SMB 卷上,可以参考 以 SYSTEM 身份挂载文件卷解决 SQLServer 使用 NAS SMB 文件卷等问题,让 SQLServer 可以看到 NAS SMB 文件卷,然后再在上面添加数据库的创建路径中选择 NAS SMB 盘作为存储位置。

4.3.4. 鼠标左键选择该数据库,然后找到右下角属性中的 连接字符串(ConnectionString),替换 Web.config 中的 connectionString 整个字段即可解决之前的 SQLServer Exception

找到并替换 连接字符串(ConnectionString)

4.3.5. 再次运行 EnumSample 网站,这次就可以正常显示网站了:

EnumSample 的正常网站

4.4. 通过 Visual Studio 建立 SQL Server 生产型数据库并连接到 EnumSample 项目

LocalDb 只是用来进行调试的数据库。在生产环境中我们应该在 SQL Server 中创建针对生产的数据库。步骤如下:

4.4.1. 连接上 SQL Server 的生产型数据库仓库

在 Visual Studio 中选择 视图 -> SQL Server 对象管理器,在 SQL Server 上选择 添加 SQL Server,选择 浏览 -> 本地,然后选择 SQL Server 安装时创建的数据库仓库,比如 iZrj92ofs1q1ixZ\SQLEXPRESS。

选择 SQL Server 安装时创建的数据库仓库

4.4.2. 在生产型数据库仓库下创建数据库,参考 4.3.2 到 4.3.5。可以看到正常显示的网站。

4.5. 打开 SQL Server 的 IP 访问功能

直接将 DataSource= 改成 IP,1433 然后用 Visual Studio 启动是无法连接数据库的。需要参考 How do I configure SQL Server Express to allow remote tcp/ip connections on port 1433?,将数据库 TCP 1433 端口开放出来。

重启 SQL Server 服务之后再用 Visual Studio 运行 EnumSample 项目就可以了
重启 SQL Server 服务

记得将 DataSource= 改成 IP,1433
将 DataSource= 改成 IP,1433

5. 使用 IIS 来生产化部署该项目

使用 IIS 配置 EnumSample 项目进行生产化部署也很简单。添加一个网站然后路径指向 EnumSample 的文件夹,然后配置好用户身份即可。
添加一个网站然后路径指向 EnumSample 的文件夹,然后配置好用户身份即可

对于 IIS 服务,连接字符串(ConnectionString)可以用 IP,1433 的方式,也可以用机器名的方式,比如 iZrj92ofs1q1ixZ\SQLEXPRESS,作为数据库连接方式。

注意,可能会出现615错误,
615错误

或者Cannot Drop Database 错误。
Cannot Drop Database 错误

这时候参考 SQL SERVER – FIX : Error : 3702 Cannot drop database because it is currently in use.,在 SQL Server 中运行

USE Master;
GO
DROP DATABASE EnumSampleDb;
GO

即可解决。

6. 总结

本篇文章详细介绍了如何利用 NAS SMB 卷搭建好 ASP.NET + SQLServer 服务,叙述了如何使用 Visual Studio 调试以及如何使用 IIS 做生产部署。使用 NAS SMB 卷之后用户再也不用担心云盘的存储空间限制,服务的吞吐能力、可用性和稳定性也都会得到提高。

7. 参考文档

7.1. Windows IIS 服务挂载 NAS 共享文件存储:https://help.aliyun.com/document_detail/54986.html

7.2. Visual Studio 官网:https://visualstudio.microsoft.com/vs/community/

7.3. SQL Server Express 2014 下载地址:https://www.microsoft.com/en-in/download/details.aspx?id=42299

7.4. ASP.NET EnumSample 样例:https://github.com/aspnet/samples/tree/master/samples/aspnet/MVC/EnumSample

7.5. ASP.NET 样例 Github 官网:https://github.com/aspnet/samples

7.6. ASP.NET 样例集:https://github.com/aspnet/samples/archive/master.zip

7.7. 以 SYSTEM 身份挂载文件卷解决 SQLServer 使用 NAS SMB 文件卷等问题:https://yq.aliyun.com/articles/715687

7.8. SQL SERVER – FIX : Error : 3702 Cannot drop database because it is currently in use:https://blog.sqlauthority.com/2007/12/07/sql-server-fix-error-3702-cannot-drop-database-because-it-is-currently-in-use/

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
3月前
|
安全 API 数据安全/隐私保护
【Azure App Service】通过Visual Studio部署Azure App Service 遇见 401 'Unauthorized'错误
【Azure App Service】通过Visual Studio部署Azure App Service 遇见 401 'Unauthorized'错误
|
24天前
|
安全 Java 网络安全
Android远程连接和登录FTPS服务代码(commons.net库)
Android远程连接和登录FTPS服务代码(commons.net库)
21 1
|
1月前
|
开发框架 .NET API
Windows Forms应用程序中集成一个ASP.NET API服务
Windows Forms应用程序中集成一个ASP.NET API服务
89 9
|
3月前
|
存储 NoSQL Redis
【Azure Developer】一个复制Redis Key到另一个Redis服务的工具(redis_copy_net8)
【Azure Developer】一个复制Redis Key到另一个Redis服务的工具(redis_copy_net8)
【Azure Developer】一个复制Redis Key到另一个Redis服务的工具(redis_copy_net8)
|
3月前
|
敏捷开发 设计模式 开发者
【揭秘终极利器】AgileEAS.NET:服务定位器模式的魔法,如何让企业级软件开发瞬间提速?揭秘背后的技术奥秘与实战指南!
【8月更文挑战第16天】AgileEAS.NET是基于DotNet的企业级敏捷开发平台,其服务定位器模式助力构建高度解耦系统。通过全局服务目录动态查找服务,避免硬编码依赖。在AgileEAS.NET中,服务定位器以静态类形式封装服务注册与检索功能。示例展示了如何注册与获取服务实例,如在`UserController`中通过服务定位器使用`IUserService`。此模式整合到框架生命周期管理,便于各处获取服务实例,提升开发效率。然而,应适度使用并考虑依赖注入容器以增强代码可维护性和可测试性。
69 4
|
3月前
|
开发框架 JSON .NET
ASP.NET Core 标识(Identity)框架系列(三):在 ASP.NET Core Web API 项目中使用标识(Identity)框架进行身份验证
ASP.NET Core 标识(Identity)框架系列(三):在 ASP.NET Core Web API 项目中使用标识(Identity)框架进行身份验证
|
3月前
|
缓存 开发框架 .NET
看看 Asp.net core Webapi 项目如何优雅地使用内存缓存
看看 Asp.net core Webapi 项目如何优雅地使用内存缓存
|
3月前
|
安全 Java 网络安全
Android远程连接和登录FTPS服务代码(commons.net库)
很多文章都介绍了FTPClient如何连接ftp服务器,但却很少有人说如何连接一台开了SSL认证的ftp服务器,现在代码来了。
100 2
|
3月前
|
开发框架 .NET 编译器
【Azure Developer】使用Azure PubSub服务示例代码时候遇见了.NET 6.0的代码转换问题
【Azure Developer】使用Azure PubSub服务示例代码时候遇见了.NET 6.0的代码转换问题
|
3月前
|
Linux C# C++
【Azure App Service For Container】创建ASP.NET Core Blazor项目并打包为Linux镜像发布到Azure应用服务
【Azure App Service For Container】创建ASP.NET Core Blazor项目并打包为Linux镜像发布到Azure应用服务

相关产品

  • 文件存储 NAS