的字符串连接_Azure Web (三):切换ASP.NetCore连接字符串

一,引言

  上一篇文章讲到如何在Web App中创建 “Deployment Slot” 进行快速无停机部署新功能代码,也使用VS进行发布项目到创建的 Web App 中创建的新的部署槽位中,同时也引出了另外一个问题,环境变量怎么切换,切换槽位后,生产环境的的项目配置的数据库连接字符串怎么办。本篇文章,我会继续进行配置部署槽设置,同时在交换槽位的时候,测试环境/生产环境都能够准确的连接到对于的数据库。?????

--------------------我是分割线--------------------

Azure Web App 部署系列:

1,Azure Web App(一)布你的Net Core Web 项目

2,Azure Web App(二)使用部署槽切换部署环境代码

3,Azure Web App(三)切换你的Net Core Web 项目的数据库连接字符串

二,正文

1,新建Net Core Web 项目

832c4f6f905efa517673bfa73a69ac55.png

 项目名称 “CnBateBlogWeb”

28d1d9ade3a6341ef18f587d25c8ef49.png

 选择 “Web 应用程序(模型视图控制器)”,去掉 “为HTTPS 配置” 的勾选,点击创建

c8b1cc994de7dee5e358d044ed174fe2.png

删除 “launchSettings” 文件中 IIS 配置部分102c36c0e7253d8d1de846d13bd7c5ea.png

添加一个名叫 “appsettings.Production.json” 配置文件,里面当前项目的生产环境的数据库连接字符串。

 4a896c11c34116f18ca64c835ce56d6d.png

a7849b6d28ca282a1edef92ba02f38fb.png

”appsettings.Development.json“ 配置文件中配置我们开发环境的数据库连接字符串(测试环境使用相同的方法进行添加问题和配置,这里就不多说了)

19bb5a64742085c496f919b28cfaa8d8.png

 新建 Appsettings 的操作类

48dcefd349b3b2435602f1defbd57ef3.png

 Appsetting.cs 类代码

///     /// appsettings.json操作类    ///     public class Appsettings    {        static IConfiguration Configuration { get; set; }        static string contentPath { get; set; }        public Appsettings(string contentPath)        {            //string Path = "appsettings.json";            //如果你把配置文件 是 根据环境变量来分开了,可以这样写            string Path = $"appsettings.{Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT")}.json";            //Configuration = new ConfigurationBuilder()            //.Add(new JsonConfigurationSource { Path = Path, ReloadOnChange = true })//请注意要把当前appsetting.json 文件->右键->属性->复制到输出目录->始终复制            //.Build();            //var contentPath = env.ContentRootPath;            Configuration = new ConfigurationBuilder()               .SetBasePath(contentPath)               .Add(new JsonConfigurationSource { Path = Path, Optional = false, ReloadOnChange = true })//这样的话,可以直接读目录里的json文件,而不是 bin 文件夹下的,所以不用修改复制属性               .Build();        }        ///         /// 封装要操作的字符        ///         ///         ///         public static string app(params string[] sections)        {            try            {                var val = string.Empty;                for (int i = 0; i < sections.Length; i++)                {                    val += sections[i] + ":";                }                return Configuration[val.TrimEnd(':')];            }            catch (Exception)            {                return "";            }        }    }

HomeController 的 Index 方法 返回跟环境变量有关系的参数

d6eb05dcfb56d1262f8d81102bb93a31.png

 HomeController.cs 相关代码

使用构造函数注入  _env

 private readonly IWebHostEnvironment _env; public HomeController(ILogger logger, IWebHostEnvironment env)         {             _env = env;             _logger = logger;         }

Index 方法

 1 public IActionResult Index() 2         { 3             var environmentStr = string.Empty; 4             if (_env.IsDevelopment()) 5             { 6                 environmentStr += "开发环境"; 7             } 8             else if (_env.IsProduction()) 9             {10                 environmentStr += "生产环境";11             }12             else13             {14                 environmentStr += "未知环境";15             }16             ViewBag.Environment = $"当前系统处于:{environmentStr}";17             ViewBag.SqlServerConnection = $"{Appsettings.app("SqlServer", "SqlServerConnection")}";18             return View();19         }

 HomeController 控制器完整代码:

public class HomeController : Controller    {        private readonly IWebHostEnvironment _env;        private readonly ILogger _logger;        public HomeController(ILogger logger, IWebHostEnvironment env)        {            _env = env;            _logger = logger;        }        public IActionResult Index()        {            var environmentStr = string.Empty;            if (_env.IsDevelopment())            {                environmentStr += "开发环境";            }            else if (_env.IsProduction())            {                environmentStr += "生产环境";            }            else            {                environmentStr += "未知环境";            }            ViewBag.Environment = $"当前系统处于:{environmentStr}";            ViewBag.SqlServerConnection = $"{Appsettings.app("SqlServer", "SqlServerConnection")}";            return View();        }        public IActionResult Privacy()        {            return View();        }        [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]        public IActionResult Error()        {            return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });        }    }

F5运行看看,可以看到 当前appsettings 的配置文件获取的是 开发环境 的配置信息

a780e75219031c0e7032b0a342dc8190.png

切换 launchSettings.json 中的 “ASPNETCORE_ENVIRONMENT” 的参数 为 “Production”

616633c5b29f2072e0b46d4fdf54a0ab.png

F5再次调试运行看看

47ca838e40242fd9440b6bc4c9b1b000.png

 bingo,我们在VS的调试运行中通过环境变量来控制项目连接的是那种环境,并且通过这种环境变量也获取到不同的数据库连接字符串。

接下来,我们就可以在Azure Portal 中进行设置了

2,Web App 配置环境变量

Azure Portal 中找到 之前创建好的叫 “CnBateBlogWeb” 的 Web App,选择 “Settings” => "Configuration" 

我们可以清楚的看到图中圈起来的 Application settings 的解释,主要看后面的最后一句话:Application Setting 可以作为环境变量供应用程序在运行时进行访问

56452099d416e54075187721f6ad69ad.png

添加生产环境的环境变量 “ASPNETCORE_ENVIRONMENT=Production”,点击  “New application setting”。

5a238b9f7f205dcf7c1a8c7256b542d3.png

 Name 输入 "ASPNETCORE_ENVIRONMENT",Value 输入 “Production”,勾选 Deployment slot setting 后,点击 “Apply”

3e6524f315a2220d1fc675aee0393982.png

我们可以在 Configuration 页面的 应用程序设置的列表中看到刚刚配置好的 ASPNETCORE_ENVIRONMENT 的环境变量,同时我们可以点击列表上面的 “Show values”进行查看具体的环境变量的参数。

271155c0911fe4fe09b0347b6668803d.png

点击 “Show values” 后,我们可以看到我们具体设置到的一个具体的环境变量的参数的值。

 bad8db3fde95e6d0ffedf7220f1c41f2.png

同样的,我们在测试环境,或者集成测试环境中配置对于的环境变量的参数

选择 “Deployment” =》“Deployment slots”,点击 “cnbateblogweb-Integration-Testing” 的超链接,跳转到对于的我们之前设置好的集成测试环境的部署槽中

30b8b4c8381d34b1d1409a21f754932c.png

 可以看到,我们现在已经切换到 IntegrationTesting 环境的部署槽中4a44c77be88fd97e9f98c9be386c7ed4.png

 选择 “Settings” => "Configuration" ,点击 “New Application settings”,进行配置集成测试环境部署槽中的环境变量0fc9ac5c071eca6ef2bddb0199110167.png

Name 输入 “ASPNETCORE_ENVIRONMENT”,Value 输入 “Development”,勾选 “Deployment slot setting” 后,点击 “OK”

 ae8cd5a68f7827810914b7ad54300e39.png

 同样的,我们也可以查看到自己刚刚在集成测试环境中配置的叫 “ASPNETCORE_ENVIRONMENT” 的环境变量,以及它的参数,这里就不过多演示了,和上面的做法一样。1189e68c72c800c5ac25214fa44e4da0.png

 3,模拟场景,发布项目

 再次回到我们的VS之中,先直接发布项目到生产环境,模拟生产环境现在已有的项目在运行,以及测试生产环境连接到正确的数据库

选择之前创建的 “CnBateBlogWeb” 的 Web App,点击 “发布”,详细发布步骤请移步:Azure Web App(一)发布你的Net Core Web 项目

0b1cbc63b146ce3b687d9b6062299f39.png

 发布进行中

52135ad46d4f2bcd16b76070b8255c07.png

 发布完成

c3ce3ff2a92b477c6a10a23a02292a62.png

 发布完成后,浏览器会自动打开,直接跳转到当前发布的 Web App 对应的二级目录,测试成功4591ad205cfff2b03fdd0e5edff04d91.png

 或者,复制VS 发布页面的 站点URL 

3337d069845e1da5094fa9ba03f15ccc.png

 在或者在Azure Portal 中找到项目对应的Web App 点击 “Browse”

09719c10ab448220503856d595fd7641.png

 4,将集成环境测试好的新功能的代码部署到生产环境

再次回到VS,我们修改首页,添加上一些 “新功能”

d88bac9c68132fbc28297c58afa33424.png

 F5运行看看,成功的显示出,我们新加的 “功能”

77e07d2f7b181aeb51f567e785bf8810.png

 发布项目,选择之前创建的 ”cnbateblogweb-IntegrationTesting“ 的部署槽,详细发布步骤请移步:Azure Web App(一)发布你的Net Core Web 项目

dc53815ad50543212be60e48f25b0d78.png

发布完成后,浏览器会自动打开,直接跳转到当前发布的 Web App 的集成环境的部署槽对应的二级目录,当前环境也是集成测试环境,新功能也有了(这里要说明一点,这里的开发环境指的就是集成测试环境)

成功。接下来,我们进行完集成测试后,就可以发布到正式环境。

 d0823a783a764507a77cd5b1afbe592e.png

 切换部署槽,将 “集成测试环境” 的代码切换到 “生产环境” 中去,点击 “Swap”

a84713246dd616cdd0fca6824c0d6bb4.png

 点击 “Swap”

25586469eeea5a390b0184df5702cb3d.png

 我们访问生产环境部署的项目的url,显示 数据库链接正常,“新功能”也加上了4f4324bf253f0b044ab002b3480ca54f.png

 回过头,我们看看集成测试环境的访问显示情况

 40c08611e1ebb7b6f0dbf630885817a1.png

 bingo?????

今天成功的通过环境变量的控制访问不同环境的数据库链接字符串,也通过部署槽交换的方式,减少了传统项目的停机中断,做到无缝切换环境,发布。

--------------------额外话题--------------------

今天顺便演示一下使用FTP发布项目代码到Azure Web App

下载发布的配置文件

a3ca2d1e0d680c1728233b3d0dc85f9d.png

 使用notepad++ 打开这个文件,我们可以在这个文件中找到 FTP 上传的 publishUrl,userName,userPWD 

fdc82e13e41741440a28c366ce6862fb.png

 使用FTP工具,输入相应的参数

c2b3041146cafce7916ca1ad3a6e9d5d.png

点击 “连接”,连接成功后,我们就可以通过FTP工具看到,对应的 Azure Web App 的 远程路径,我们就可以把本地 VS publish 好的项目的文件上传上去

74cba1357912b833548254564cc9492f.png

 我们在azure portal 中项目对于的 Web App 点击 “Restart” 重启一下,最后点击 “Browse” 进行测试

ed4c774ea34b4636ae08283024c025d8.png

 ok,使用FPT上传的方式部署项目代码的分享到此结束。

三,总结

今天我们演示了一下,如何在 Web App 切换槽位后,通过环境变量的方式来加载不同环境的数据库连接字符串,以及生产环境/集成测试环境部署槽交换,再一个捎带讲了一下使用FTP上传部署项目到Azure Web App

作者:Allen 

项目代码:https://github.com/yunqian44/CnBateBlogWeb.git

版权:转载请在文章明显位置注明作者及出处。如发现错误,欢迎批评指正。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值