从壹开始 [ Ids4实战 ] 之三║ 详解授权持久化 用户数据迁移

哈喽大家周三好,今天终于又重新开启 IdentityServer4 的落地教程了,不多说,既然开始了,就要努力做好?。

书接上文,在很久之前的上篇文章《二║ 基础知识集合 & 项目搭建一》中,我们简单的说了说 IdentityServer4 是如何调用和配置 Token 的,主要是一些入门的基础知识和概念,也算是第一次尝鲜了,其实 Ids4 本身没有那么神秘,我们只需要知道它是一个丰富的认证框架,又具有很好的可扩展性,核心就是如何配置某些客户端通过该授权服务来包括另一些资源服务器,供用户使用。因为中间隔了很长时间了,这里简单的回顾下上篇文章说了什么,下边这几个小问题,相信大家脑中都能很快的有一些概念,至少是脸熟了,如果不是很清楚,请翻看上边的链接,或者官网再看看:

1、什么是资源?什么是客户端?什么是令牌 ?

2、IdentityServer4 主要是授权还是认证 ?

3、OAuth 2.0、OpenID、OpenID Connect三者的关系 ?

4、Ids4 依赖的 Nuget 包是什么 ?

5、如何快速开发 UI ?

 今天这篇文章主要是操作和探索相结合的一篇,我看网上很多教程,基本上是按照官网概念的知识点,配合着 Github 开源地址,讲解一遍,知识是懂了,可是要是自己开发起来,还是有很多的疑惑,甚至是根本走不下去,我就从初学者的立场出发,换一个思路,简单的对其进行探索,希望能让初学者感兴趣,而不会失去学习的冲动,当然,这篇文章不会一下子就很完整,需要一段时间的沉淀和完善,我会不定时将学习到的感悟一一补充下来,然后也会和别人讨论的心得写下来,慢慢的将这篇文章逐渐完整起来。希望大家都积极评论,混个脸熟也会挺好,如果一直潜水,可能都不知道你的存在。?

之前的配置都是在内存中,下面将如何把这些数据存储到Sql Server数据库, 这样更符合生产环境的要求。好啦,马上开始今天的内容~~~

 

640?wx_fmt=gif

 (这是简单处理了下登录页,要用就要好看些)

1、安装依赖环境 ——基础

我们要把所有的数据都存储下来,采用接口进行建模,我们在 IdentityServer4.EntityFramework Nuget 包中提供这些接口的 EF 实现。

算上我们上篇文章中引用的 IdentityServer4 包,一共这三个 Nuget 依赖环境: 

640?wx_fmt=png

2、三个上下文 —— 核心

这一节大家如果看懂的话,一定会对 IdentityServer4 丰富性和可扩展性 有特别切身的了解和体会!?

Z、为什么要定义多个上下文?

为什么要多个上下文? 

还记得在第二个系列 DDD 中,我们说到了多个上下文的用途,单个数据库可以有多个上下文。例如, 如果您的数据库包含多个数据库架构, 并且您希望将每个架构作为单独的自包含区域处理, 则此功能非常有用。在使用多个上下文类型时,您还会看到其他问题, 例如共享实体类型及其从一个上下文传递到另一个上下文等。一般来说,设计多个上下文,会使您的设计更干净, 并分离不同的功能区域,但同时它的成本也增加了复杂性。框架之所以会设计成多个上下文,是为了更好的扩展,我们也可以部署到不同的物理机数据库中,更好的实现独立性。

在我们的 IdentityServer4-EF 框架中,有三个上下文,准确来说是 2+1 个上下文,为什么这么说呢 ?

因为第三个上下文不是官方定义的,是我们自己根据需要进行合理扩展的,比如我们可以使用 Asp.Net Core 自带的 Identity 身份认证机制来实现扩展,当然,你也可以自己定义相应的操作,如果你还不懂,就想象一下我们在 Blog.Core 项目中,我们不是自己定义的基于 JWT 的认证授权么( 用户表 + 角色表 + 关系表等等 ),但是如果你看我的 DDD 项目的话,应该可以看到我又使用了 Core 官方自带的 Identity 机制,毕竟结合 EFCore 我们可以很快的实现用户数据的管理,而不用自己造轮子了。

640?wx_fmt=png

咱们这里先说说前两个上下文,在我们使用 Ids4 的时候,有两种类型的数据需要持久化到数据库中:

1、配置数据(资源、客户端、身份);//这里是对应配置上下文 ConfigurationDbContext 

2、IdentityServer在使用时产生的 操作数据(令牌,代码和用户的授权信息consents);//这里是对应操作上下文 PersistedGrantDbContext 

这两个上下文以及对应的数据模型,已经被 IdentityServer4 官方给封装好了, 我们不需要做额外的操作,直接进行迁移即可。

A:ConfigurationDb

ConfigurationDbContext (IdentityServer configuration data) —— 负责数据库中对客户端、资源和 CORS 设置的配置存储;

如果需要从 EF 支持的数据库加载客户端、标识资源、API 资源或 CORS 数据 (而不是使用内存中配置), 则可以使用配置存储。此支持提供 IClientStore、IResura Store 和 ICorsPolicyService 扩展性点的实现。这些实现使用名为 ConfigurationDbContext 的 dbcontext 派生类对数据库中的表进行建模。

更多内容请查看官网 :http://docs.identityserver.io/en/latest/reference/ef.html#configuration-store-support-for-clients-resources-and-cors-settings

具体在  startup 中如何配置,下面会说到。

B:PersistedGrantDb

PersistedGrantDbContext (IdentityServer operational data.) -—— 负责存储同意、授权代码、刷新令牌和引用令牌;

 如果需要从 EF 支持的数据库 (而不是默认的内存数据库) 加载授权授予、同意和令牌 (刷新和引用), 则可以使用操作存储。此支持提供了 IPersistedGrantStore 扩展点的实现。实现使用名为 PersistedGrantDbContext  的 dbcontext 派生类对数据库中的表进行建模。

C:ApplicationDb

ApplicationDbContext 继承 IdentityDbContext (Entity Framework database context used for identity.) —— 负责与 asp. net 标识相关的用户;

这个上下文,就是 IdentityServer4 体现 可扩展性 的关键点,为什么说是可扩展的,因为这是我们自己定义的,你可以在这里仅仅定义一个User表,也可以像我们的 Blog.Core 项目中,定义三个表。我们可以在这个上下文中,进行配置,来控制我们的用户数据,当然这里看着很简单,是因为继承了 NetCore 官方的 Identity 了,可以使用他们的那一套逻辑。

 public class ApplicationUser : IdentityUser
{
//可以在这里扩展,下文会说到
}


// 定义用户管理上下文,继承 NetCore 自带的 Identity 认证机制,也可以不继承而自定义表结构。
public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
{
public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options)
:
base(options)
{
}

protected override void OnModelCreating(ModelBuilder builder)
{
base.OnModelCreating(builder);
// Customize the ASP.NET Identity model and override the defaults if needed.
// For example, you can rename the ASP.NET Identity table names and more.
// Add your customizations after calling base.OnModelCreating(builder);
}
}

这个上下文,主要是用来处理我们的用户数据相关的部分:

1、有多少用户数据和角色数据;

2、哪些用户,又拥有什么角色,又对应哪些Claims 声明。

这一块更像是我们的平时的权限管理系统,就是在 User、Role、Claim 之间交互,文章下边会有一个数据模型图,会很清晰的看出来各自的对应关系。

我们既然需要用到这几个上下文,就需要添加他们所对应的服务,别着急,往下看。 

3、配置 EF-Ids4 相关服务 —— 必要

上边我们说到了三个上下文,如果我们直接执行迁移命令是会报错的,比如我们直接迁移 PersistedGrantDbContext 上下文:

640?wx_fmt=png

所以,就需要在项目中配置对应的服务,我们在 startup.cs 启动文件中,配置服务 ConfigureService :

配置 EF 操作数据库,很简单,这个就按照平时我们使用的正常的方法即可:

1、获取数据库连接字符串:

640?wx_fmt=png

( 我这里使用的是读取文件的形式,其实就是字符串放到文件里了,大家自己根据需要做相应调整即可,我这么是防止密码泄露。)

2、配置数据库服务:

    var builder = services.AddIdentityServer(options =>
{
options.Events.RaiseErrorEvents
= true;
options.Events.RaiseInformationEvents
= true;
options.Events.RaiseFailureEvents
= true;
options.Events.RaiseSuccessEvents
= true;
})

    // Configures IdentityServer to use the ASP.NET Identity implementations of IUserClaimsPrincipalFactory,
    // IResourceOwnerPasswordValidator, and IProfileService. Also configures some of
    // ASP.NET Identity's options for use with IdentityServer (such as claim types to
    // use and authenticaiton cookie settings).

     .AddAspNetIdentity<ApplicationUser>()
// 添加配置数据(客户端 和 资源)
.AddConfigurationStore(options =>
{
options.ConfigureDbContext
= b =>
b.UseSqlServer(connectionString,
sql
=> sql.MigrationsAssembly(migrationsAssembly));
})
// 添加操作数据 (codes, tokens, consents)
.AddOperationalStore(options =>
{
options.ConfigureDbContext
= b =>
b.UseSqlServer(connectionString,
sql
=> sql.MigrationsAssembly(migrationsAssembly));
// 自动清理 token ,可选
options.EnableTokenCleanup = true;
});

 然后是我们的用户数据存储,其实我们可以根据自己的需要,自己建立对应的表,比如我们 Blog.Core 项目中,我们定义了用户、角色和关系表等数据库接口,但是这样的话,可能少一些情况,所以一般情况下,都是采用的 asp.net core 自带的 Identity 身份验证,而且对扩展性很友好,就比如下文我们就对用户主表做了自定义扩展,继承了 IdentityUser, ApplicationUser : IdentityUser 

 // 数据库配置系统应用用户数据上下文
services.AddDbContext<ApplicationDbContext>(options =>
options.UseSqlServer(connectionString));
// 启用 Identity 服务 添加指定的用户和角色类型的默认标识系统配置
services.AddIdentity
<ApplicationUser, IdentityRole>()
.AddEntityFrameworkStores
<ApplicationDbContext>()
.AddDefaultTokenProviders();

4、Migrations 迁移 —— 结果

我这里提供了两种方法,至于哪种更好,大家可以自己都试试,我都用过,可能第二种稍微多了一点,不过原理都是一样的。

方式一:在包控制台

 一、迁移项目( 使用 Package Manager Console ):
1、add-migration InitialIdentityServerPersistedGrantDbMigration -c PersistedGrantDbContext -o Data/Migrations/IdentityServer/PersistedGrantDb
2、add-migration InitialIdentityServerConfigurationDbMigration -c ConfigurationDbContext -o Data/Migrations/IdentityServer/ConfigurationDb
3、add-migration AppDbMigration -c ApplicationDbContext -o Data
4、update-database -c PersistedGrantDbContext
5、update-database -c ConfigurationDbContext
6、update-database -c ApplicationDbContext

 640?wx_fmt=png

640?wx_fmt=png

最后成功的生成了我们需要的数据库:

640?wx_fmt=png

方式二:在命令窗口

判断是否支持命令行迁移,你可以在项目所在的目录下打开一个命令 Power shell 并运行命令 dotnet ef, 它应该是这样的:

 640?wx_fmt=png

我是在 PowerShell 中操作的:

//1.dotnet ef migrations add InitialIdentityServerPersistedGrantDbMigration -c PersistedGrantDbContext -o Data/Migrations/IdentityServer/PersistedGrantDb
//2.dotnet ef migrations add InitialIdentityServerConfigurationDbMigration -c ConfigurationDbContext -o Data/Migrations/IdentityServer/ConfigurationDb
//3.dotnet ef migrations add AppDbMigration -c ApplicationDbContext -o Data
//4.dotnet run /seed

这里我就不一一操作了,就是普通的命令执行,生成的数据库一模一样的。

但是要注意下,上边我们在包管理控制台,仅仅是迁移了数据库,还没有进行数据 Seed 生成,不过你看 PowerShell 的命令中的第四步,我使用  dotnet run /seed 的命令,和上边的不一样,没错,是因为下边我用了另一种方法,通过代码的方法进行 Migrate 了,并且同时还 Seed 了数据,那具体如何操作呢,别慌,第三节我会说到了,现在这个时候,我们已经把数据库的所有表都已经生成好了,先不着急同步数据,我们先看看到底生成了哪些数据表。

1、整体数据模型图

我简单的做了下整个数据库的数据模型图,不同模块用不同的颜色区分,大家也能很清楚的看出来各自对应的关系,一目了然,其中配置数据又有三个部分,分别对应的是 客户端 + 资源 + 身份 。

640?wx_fmt=png

 接下来,咱们针对这三个模块简单的说一说,因为这里还没有数据,说起来可能会比较抽象,这里先留一个坑,等配合 Vue 客户端使用了以后,再把完整数据展示出来,可能更好的理解了。

2、三个模块表

操作数据模块

 640?wx_fmt=png

这是 Ids4 官方封装的第一部分——操作数据。PersistedGrants的数据,在登陆时当你同意请求许可的时候,就会在这个表里面添加一条数据。

举个栗子,我在 Blog.Vue 项目点击登录,跳转到 BlogIdp 授权中心,认证成功后,跳转回来,就会在这个表中多了一条数据(这个功能我下次会开放出来,代码已经写好):

MMD4TtLkVH7sXIwFS/DLZRfLQnUga0XMrBDVuQZWfOw=user_consentc2841087-1b35-4ab4-afd6-f27f80c94e6cblogvuejs2019-05-08 03:35:30.0000000NULL{"SubjectId":"c2841087-1b35-4ab4-afd6-f27f80c94e6c","ClientId":"blogvuejs","Scopes":["openid","profile","roles","blog.core.api"],"CreationTime":"2019-05-08T03:35:30Z","Expiration":null}

 640?wx_fmt=png

配置数据模块

 640?wx_fmt=png

这一大块,是 Ids4 官方定义的第二模块 —— 配置数据,从这里我们可以看出来 IdentityServer4 的另一个特性——丰富性,上边咱们说到了可扩展性,它提供了丰富的配置数据结构,从三个方面来给我们定义好了这些数据,而不用我们再去一个一个的去设计,去思考。

我们可以通过这些表结构来存储我们的服务数据,比如有哪些API资源(Blog.Core.API),哪些客户端资源,还有用到了哪些资源等等,如果你还不清楚的,可以想想上篇文章中,我们讲内存模式的 Ids4 的配置,就是这些数据,在下边的文章中,我们会进行 Seed Data,那个时候我们再进一步看下。

640?wx_fmt=png

具体的数据大家可以看看,截个图:

640?wx_fmt=png

用户数据模块

 640?wx_fmt=png

这一块我们就很清楚了,因为这是我们自定义的用户数据(当然本项目是直接继承的 NetCore 的 Identity) ,光从数据库表名上,我们就知道其中的含义了,就是用户角色管理。

上边咱们也简单的说了下数据库表结构,然后再结合三个上下文,大家应该都能明白各自的含义了,好啦,现在就是万事俱备,只欠数据了,是时候动手了!


还记得我们上边在生成数据库的时候,我采用了两个方法,第一种很常规,那接下来就说说第二种中第四步( dotnet run /see ),是如何操作的。

1、定义 SeedData 类

首先,需要定义一个 SeedData 类,主要是用来 update-database  和  Seed Data 这两个作用,因为篇幅的原因,具体的代码在 Github 上,大家自行下载查看即可:

 640?wx_fmt=png

2、扩展用户主表数据

 上边咱们也说到了,我们通过继承使用 Identity 机制,来扩展了用户管理,很自然的,我们需要用到 IdentityUser ,但是它的这个用户数据肯定不能满足我们的需求,所以,这里又一次体现了 Ids4 可扩展性的优点,我们可以自定义用户主表:

  // Add profile data for application users by adding properties to the ApplicationUser class
public class ApplicationUser : IdentityUser
{
// 自定义属性
public string name { get; set; }
public string RealName { get; set; }
public int sex { get; set; } = 0;
public int age { get; set; }
public DateTime birth { get; set; } = DateTime.Now;
public string addr { get; set; }
public bool tdIsDelete { get; set; }
}

3、获取 Blog 项目用户数据

 这个功能是一个充分不必要的条件,主要是为了解决某些项目先用了自身一套认证系统,然后又上了 IdentityServer4 项目的情况,就比如我们的 Blog.Core 项目,就是这个情况。

那用户的数据从哪里拿到呢,很巧,大家还记得我在某一篇文章《 42 ║支持多种数据库 & 快速数据库生成》中,自动生成数据库的方案,就是这么使用的,从 Github 上直接拉取数据即可,这里整个派上用场,感觉很不错,

private static string GitJsonFileFormat = "https://github.com/anjoy8/Blog.Data.Share/raw/master/Blog.Core.Data.json/{0}.tsv";


// 远程获取 Blog.Core 数据库的三表数据
var BlogCore_Users = JsonHelper.ParseFormByJson<List<sysUserInfo>>(GetNetData.Get(string.Format(GitJsonFileFormat, "sysUserInfo")));
var BlogCore_Roles = JsonHelper.ParseFormByJson<List<Role>>(GetNetData.Get(string.Format(GitJsonFileFormat, "Role")));
var BlogCore_UserRoles = JsonHelper.ParseFormByJson<List<UserRole>>(GetNetData.Get(string.Format(GitJsonFileFormat, "UserRole")));

4、执行Seed方法,查看数据

经历了定义上下文 -> 数据库迁移 -> 获取数据 -> Seed Data 的过程后,就剩下最后一步了,执行操作:

很简单,我在 Blog.Core 项目中,采用的是 appsettings.json 文件配置的方法,这里换另一种方法,Program.cs 控制台参数的形式

640?wx_fmt=png

 在上一讲中,我们用到了官方的 快速启动 代码,里边已经包含了基本的页面,当然你也可以根据自己的情况去自定义,甚至采用静态的Ajax 来实现,我这里还是使用的 MVC 结构,只不过套用了下一个简单样式(样式版权是http://www.uimaker.com/ 网站的,请不要做商业用途,注意产权),至少看起来好看了一些。

 640?wx_fmt=gif

 具体的登录操作就不演示了,等下次把 增删改查 都做好了,再统一做下动图展示吧,具体如何设计,请听下回分解。

 今天我们简单的实现了对 IdentityServer4-EFCore 的相关配置,概念不是很难,为了加深印象,还是提几个小问题,请大家多思考:

1、Ids4 一共用到了几个上下文,分别的用处是什么?

2、在迁移中,数据库生成了多少表,各个模块又是干什么的?

3、Ids4 的良好扩展性,体现在哪里?丰富性又体现在哪里?

4、ApplicationUser 类是起到什么作用的?

5、思考1:如果同一个用户有多个角色如何处理?

6、思考2:如果不使用 NetCore 自带的 Identity 认证,如何自定义上下文?

https://github.com/anjoy8/Blog.IdentityServer

原文地址:https://www.cnblogs.com/laozhang-is-phi/p/10660403.html

.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com 
640?wx_fmt=jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315999.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微软XAML Studio - WPF, UWP, Xamarin等技术开发者的福音

最近在继续倒腾WPF的项目&#xff0c;继续使用Caliburn.Micro和Xceed来堆代码。每次调试xaml上的binding&#xff0c;都有种要疯的赶脚。今天路过 https://channel9.msdn.com/ 浏览 WPF相关的学习视频时&#xff0c;遇到微软推荐的相关视频 - XAML sutdio简介https://channel9.…

AddMvc 和 AddMvcCore 的区别

目录本文出自《从零开始学 ASP.NET CORE MVC》目录 视频课程效果更佳&#xff1a;从零开始学 Asp.Net Core MVC ASP.NET Core 为什么有 AddMvc 和 AddMvcCore 他们是什么关系&#xff1f;在本视频中&#xff0c;我们将讨论 AddMvc()和 AddMvcCore()方法之间的区别。要在 ASP.NE…

浅谈容量规划

俗话说&#xff0c;”人无远虑&#xff0c;必有近忧”&#xff0c;容量规划就是”远虑”。所谓容量规划&#xff0c;是一个产品满足用户目标需求而决定生产能力的过程。当产品发展到一个较为稳定成熟的阶段&#xff0c;产品的整体处理能力的把控自然是不可或缺&#xff0c;尽管…

CF1063C Dwarves, Hats and Extrasensory Abilities

CF1063C Dwarves, Hats and Extrasensory Abilities 题意&#xff1a; 首先题目会给出 n &#xff0c;表示要输入多少点。 然后你输出n 个点的坐标&#xff0c;每输出一个点会告诉你这个点的颜色是黑色或者白色。 最后你需要输出两个点的坐标代表一条直线&#xff0c;这条直线…

Blazor——Asp.net core的新前端框架

Blazor是微软在Asp.net core 3.0中推出的一个前端MVVM模型&#xff0c;它可以利用Razor页面引擎和C#作为脚本语言来构建WEB页面&#xff0c;如下代码简单演示了它的基本功能&#xff1a;和Angular JS和VUE的模型非常类似&#xff0c;Blazor 支持大多数应用所需的核心方案&#…

CF1149B Three Religions

CF1149B Three Religions 题意&#xff1a; 给定长度为 n 的母串和三个子串s1,s2,s3s_1,s_2,s_3s1​,s2​,s3​ 。初始时子串均为空。有 q 次询问。你需要支持两种操作&#xff1a;向某个子串末尾添加一个字母&#xff0c;或者删去某个子串末尾的字母。在每次操作后&#xff…

【译文】领域模型的五个特征

我在这篇博客文章中&#xff0c;我试图给领域模型下一个非常合适的定义&#xff0c;我发现我的这些定义都不太妥当&#xff0c;不过&#xff0c;我们还是可以先来看一下wiki百科对领域驱动模型下的定义&#xff1a;问题解决和软件工程中的领域模型可以被认为是感兴趣的领域&…

使用ASP.NET Core 实现Docker的HealthCheck指令

写在前面HealthCheck 不仅是对应用程序内运行情况、数据流通情况进行检查&#xff0c; 还包括应用程序对外部服务或依赖资源的健康检查。健康检查通常是以暴露应用程序的HTTP端点的形式 实施&#xff0c;可用于配置健康探测的的场景有 &#xff1a;容器或负载均衡器 探测应用状…

VS Code 中有哪些好用的 Azure 插件?

在之前的文章中&#xff0c;我们提到了 Amazon、Google、IBM、Red Hat、Salesforce、Pivotal 等大厂都在 VS Code 中有提供相应的开发工具&#xff1a;亚马逊上了 VS Code 的船&#xff0c;还有哪些大厂也上了船&#xff1f;微软必定更是把 VS Code 作为其最重要的开发者平台了…

邀请 | 关于微软容器服务,你需要知道的二三事

容器是近年来特别火的话题&#xff0c;那么&#xff0c;什么是容器&#xff1f;为什么我们需要容器服务&#xff1f;微软容器服务特点是什么&#xff1f;今天我们用一种特殊的方式为大家介绍这三大话题。什么是容器这个部分&#xff0c;我们用一个故事进行开场。很久以前&#…

UWP 推荐 | 限时免费的RSS阅读器《RSS 追踪》登录 Windows 10

前不久&#xff0c;本公号作者 Bravo Yeung 写了一篇不错的关于 RSS 的文章 .Net开发者必知的技术类RSS订阅指南。RSS 现在用的人很少了&#xff0c;而且就算是我&#xff0c;也不过是在一周前才开始正视 RSS 。只因为接触到了一个很好很强大的社区 RSS Hub &#xff0c;当时看…

常见跨域解决方案以及Ocelot 跨域配置

常见跨域解决方案以及Ocelot 跨域配置Intro我们在使用前后端分离的模式进行开发的时候&#xff0c;如果前端项目和api项目不是一个域名下往往会有跨域问题。今天来介绍一下我们在Ocelot网关配置的跨域。什么是跨域跨域:浏览器对于javascript的同源策略的限制,例如a.cn下面的js不…

解读大内老A的《.NET Core框架本质》

老A说的一句话让我很受启发&#xff0c;想要深入了解框架&#xff0c;你要把精力聚焦在架构设计的层面来思考问题。而透彻了解底层原理&#xff0c;最好的笨办法就是根据原理对框架核心进行重建或者说再造。看起来没有捷径&#xff0c;也是最快的捷径。相信很多读者已经看过老A…

Mono和.NET Core 从比翼双飞到合体

.NET 开源之路就是 Mono和.NET Core 从比翼双飞到合体&#xff1a;2001年12月-2002年2月。一个新的平台诞生了。与惠普、英特尔和其他公司一起, 创建了 ECMA-335 标准, 该标准定义了支持多种编程语言的公共语言基础结构&#xff0c;C# 和 Visual Basic. Net。 F # 于2007年晚些…

Skywalking部署常见问题以及注意事项

Skywalking部署常见问题以及注意事项IntroSkyWalking 创建与2015年&#xff0c;提供分布式追踪功能。从5.x开始&#xff0c;项目进化为一个完成功能的Application Performance Management系统。他被用于追踪、监控和诊断分布式系统&#xff0c;特别是使用微服务架构&#xff0c…

GitHub推出包管理服务,npm与Nuget全支持

GitHub 今天推出了一项名为 GitHub Package Registry 的新产品&#xff0c;它提供了软件包管理服务&#xff0c;开发者通过它可发布公共或私有软件包。官方介绍&#xff0c;GitHub Package Registry 完全集成在 GitHub 中&#xff0c;因此和 repo 一样&#xff0c;用户可以使用…

发布dotNetCore程序到Kubernetes

上一篇《Mac中搭建Kubernetes》介绍了怎样在Mac中搭建单节点的Kubernetes&#xff0c;本文将编写一个dotNetCore的示例程序&#xff0c;并发布到Kubernetes中。环境基本步骤创建dotnetCore示例项目&#xff1b;本地搭建私有registry&#xff0c;或者使用DockerHub&#xff0c;本…

[Cake] 2. dotnet 全局工具 cake

在上篇博客[Cake] 1. CI中的Cake中介绍了如何在CI中利用Cake来保持与CI/CD环境的解耦。当时dotnet 2.1还未正式发布&#xff0c;dotnet 还没有工具的支持&#xff0c;使得安装cake非常麻烦。不过随着 dotnet tool 的加入&#xff0c;这一问题得到了很好的解决。目前安装cake&am…

官博翻译 | .NET Core 即 .NET 的未来

点击上方蓝字关注“汪宇杰博客”文 / Scott Hunter译 / 汪宇杰我们在2014年11月推出了.NET Core 1.0。.NET Core 的目标是借鉴我们过去12年构建、发布和服务.NET Framework的经验去构建更好的产品。这些改进如&#xff1a;并行安装&#xff08;您可以安装新版本&#xff0c;而…

微软发布ML.NET 1.0,可一键添加机器学习模型

今天&#xff0c;我们很高兴宣布发布 ML.NET 1.0。ML.NET 是一个免费的、跨平台的开源机器学习框架&#xff0c;旨在将机器学习&#xff08;ML&#xff09;的强大功能引入.NET 应用程序。ML.NET GitHub&#xff1a;https://github.com/dotnet/machinelearning入门 http://dot.…