2024年的ASP.net Core_2024年的万年历日历表
haoteby 2025-10-08 17:07 6 浏览
简介
Ryan Nowak是asp.net Core的架构师和核心开发,在2019/11/6号的NDC大会上, 他介绍了开发团队眼中五年后的AspnetCore的样子, 我们拭目以待,看看微软的产品经理会怎么扭曲程序员的想法,最后端出一个什么怪物给大家。
现状
ASP基本上是和dotnet一起出现的, 到现在也快20年了,说的好听一点是一直屹立不倒, 现实状况是苟延残喘,web Server主流玩家慢慢都不以ASP为对手了,ASP还在努力蹭热点,求生欲十足。不过ASP有个有钱的爸爸,只要活得久,季羡林也可以成为大师(没有贬低的意思,活着就有一切可能性)
Kestrel 和 项目BedRock
以前dotnet项目只能用于IIS,无法跨平台, 所以core团队开发了kestrel, 一个跨平台的web服务器, 不过功能还是比较弱, 只能寄生在IIS,或者躲在nginx后面。听说kestrel有进化成跨平台的IIS的想法, 但是Ryan这次没说。我觉得躲在nginx后面挺好的。
kestrel刚开发的时候,nodejs正火热, 所以团队用了libuv作为基础,我记得aspnetcore1.0出来的时候出来就是号称不比nodejs慢。后来团队发现libuv有瓶颈, 重新改为 .net sockets作为基础,目前在主流webserver的排名约在第10名, 排在它前面的主要是Rust、Go和C开发的web Server。Ryan虽然有说要利用.net core的底层优化来改进性能,但是我没听到太多信心,哈哈。
在kestrel上面,团队主要想法其实是封装协议接口,开发者可以使用任何协议和后端服务通信,在不同环境下, 用websocket, tcp, udp,gRPC或者其它任何合适的协议,听起来像是WCF的复活,这个一直是微软的理想,我们就期待它能成功吧。
其它就是HTTP3、MQTT之类的协议支持了,所有webserver应该都会支持的。
中间件和MVC
MVC(ASP里面的MVC)越来越膨大,开发团队想把更多的功能移到平台级别,开发者想用就用, 而不是一定要按照MVC的方式来用。 MVC颜色会越来越淡,但是不会消失,MVC算是声明式(declare)开发了,这个很方便,几行代码就可以做很多事情,但是需要学习一大堆概念。命令式(imperative)开发虽然被人诟病,但是很多时候更容易理解,也就更容易维护。Aspnet Team想兼容这两种开发模式,MVC本身会存在,并且对SingalR/gRPC的支持也会更好, 同时很多MVC的功能会成为middleware(中间件),如果喜欢imperative开发(或者某些场景下,imperative更合适),则可以用MVC中的某些中间件,而不是被强制使用MVC。
自包含发布
目前asp.net core已经可以打包成一个文件发布了(当然,各个平台还是要分别打包)但是打包文件非常大, 一个没有任何功能的网站(helloworld)打包后也有100MB大,这个有一点过大了。asp.net 团队目前主要想把这个大小压缩到20MB左右。不要小看这个大小, 如果压缩到20MB左右,量变会引起质变,特别是Electron类的程序,后台就不用nodejs了,改成用asp.net core了。
这个主要通过移除不用的代码来实现,所谓Tree Shaking,这个听了好多年了,目前还在试验阶段,这个功能大概真的要五年的时间来实现了。
Blazor和Electron
Electron大家应该都知道是什么, asp.net team就是想把Electron后面的nodejs替换掉,改成kestrel,然后加上Blazor(socket.io)。听起来不错,做一个网页,稍作改动就可以用于网站和跨平台desktop应用(未来一定会到ios/andriod), 不过跨平台的desktop,难道不是未来的WPF吗?让子弹飞一会儿吧, 看看asp.net core团队能搞出一个什么东西来吧。
总结
开发人员的目光还是保守,听Ryan讲的这些功能,怎么也不用5年来实现啊,而且没什么特别创新的想法,都是已知的概念,我希望dotnet下一个版本就有,如果真的等五年才有,asp.net就是永恒的追赶者了。
相关推荐
- 如何为MySQL服务器和客户机启用SSL?
-
用户想要与MySQL服务器建立一条安全连接时,常常依赖VPN隧道或SSH隧道。不过,获得MySQL连接的另一个办法是,启用MySQL服务器上的SSL封装器(SSLwrapper)。这每一种方法各有其...
- k8s 证书问题排查_k8s dashboard 证书
-
从去年开始一些老项目上陆陆续续出现一些列的证书问题,(证书原理这里就不说了,官方文档一堆)多数刚开始的表现就是节点的kubelet服务起不来,节点状态NotReady表现日志如下failed...
- 企业级网络互通方案:云端OpenVPN+爱快路由器+Win11互联实战
-
企业级网络互通方案:OpenVPN搭建公有云+爱快路由器+Win11三地互联实战指南「安全高效」三地局域网秒变局域网实施环境说明...
- OpenV** Server/Client配置文件详解
-
Server配置详解...
- 接口基础认知:关键信息与合规前提
-
1.核心技术参数(必记)...
- S交换机通过SSH登录设备配置示例(RADIUS认证+本地认证独立)
-
说明:●本示例只介绍设备的认证相关配置,请同时确保已在RADIUS服务器上做了相关配置,如设备地址、共享密钥、创建用户等配置。●通过不同的管理域来实现RADIUS认证与本地认证两种方式同时使用,两...
- SSL证书如何去除私钥密码保护_ssl证书怎么取消
-
有时候我们在生成证书的时候可以加入了密码保护。然后申请到证书安装到了web服务器。但是这样可能会带来麻烦。每次重启apache或者nginx的时候,都需要输入密码。那么SSL证书如何去除私钥密码保护。...
- SSL证书基础知识与自签名证书生成指南
-
一、证书文件类型解析...
- S交换机通过SSH登录设备配置示例(RADIUS认证)
-
说明:本示例只介绍设备的认证相关配置,请同时确保已在RADIUS服务器上做了相关配置,如设备地址、共享密钥、创建用户等配置。假设已在RADIUS服务器上创建了用户名yc123,密码test#123。对...
- HTTPS是什么?加密原理和证书。SSL/TLS握手过程
-
秘钥的产生过程非对称加密...
- HTTPS TLS握手流程_进行tls握手
-
1.客户端向服务器发送`ClientHello`消息,包括支持的TLS版本、加密套件、随机数等信息。2.服务器收到`ClientHello`消息后,解析其中的信息,并根据配置选择一个加密套件。3....
- Spring Boot 单点登录(SSO)实现_spring boot 单点登录jwt
-
SpringBoot单点登录(SSO)实现全指南单点登录(SingleSign-On,SSO)是一种身份验证机制,允许用户使用一组凭证登录多个相关但独立的系统。在微服务架构和企业级系统中,SS...
- 源码分享:在pdf上加盖电子签章_pdf如何加盖电子公章
-
在pdf上加盖电子签章,并不是只是加个印章图片,。而是要使用一对密钥中的私钥对文件进行签字。为啥要用私钥呢?很简单,因为公钥是公开的,其他人才可以用公钥为你证明,这个文件是你签的。这就是我们常说的:私...
- 微信支付商户API证书到期 怎么更换
-
微信支付商户API证书到期更换是一个非常重要的操作,需要仔细按照流程进行。如果证书过期,所有通过API的支付、退款等操作都会失败,将直接影响您的业务。请按照以下详细步骤进行操作:重要前提:分清...