博客园翻车启示录

640

开发者的日常

640?wx_fmt=gif

作为一名996的开发者,我几乎每天只有两件事,制造bug和解决bug,这两件事,既替我解决了温饱问题、也替产品经理、测试工程师等一票人解决了吃穿问题。

嗯,有人为我这种程序员评了一个等级,我大概是第五等程序员。

       640      

但是。。。我是真的想写bug吗?。。。并不是。我也渴望能够编写更加优秀的代码,能够掌握更优秀的互联网技术框架、掌握更加优秀的开发方法,但是每天沉迷于搬砖之中不可自拔,哪怕每天认真阅读Robert大叔的《The Clean Code》,掌握好代码的速度也远远赶不上我写烂代码的速度。

(好吧,10个小时的写烂代码,却只有20分钟学习整洁代码。。。)

好吧,我的工作大概是这样的:

~溪源,你那个功能做完了吗?可以发布了么?

~可以发了,啥毛病都没有。

~那行,现在发吧。

~等下,我又发现了一个bug。

~那我等你五分钟。

~好的,只剩最后一个bug了,改完这个bug就可以发,就可以下班了。

-哎呀,卧槽,怎么天亮了。。

640?wx_fmt=jpeg

 ~你就不能做一个不写bug的程序员吗?

~对不起,我做不到啊。

~为毛啊。

~那天我去庙里上香,我虔诚的对菩萨说,菩萨,保佑我成为一个不写bug的程序员吧~

---然后我获得了永生。

以上内容纯属虚构,如有雷同,纯属巧合。

640?wx_fmt=jpeg

640?wx_fmt=gif

640

中国程序员的现状

640?wx_fmt=gif

中国的程序员大概是国内最苦逼的行业之一,每天996,下班还要回家学习各种新技术哪怕是BAT这样的大厂,优秀的开发者也不过是公司前进路上的一块砖石,无时无刻不面临着被牺牲的后果,如果未能在指定年龄之前,成为最拔尖的那一批人,那不管你多优秀,跟其他开发者没有任何区别。

“中年危机”,就像梦魇一般,既激发我们向前,更驱赶我们向鸭子一般,盲目的向前拼搏。或许我们可以逃出这座围城,但是围城之外却是留不住躁动心的舒适区。

无论如何,我们都得努力提高自己,先写更加优秀的代码,才能获得更多的机会,但是,bug却像魔咒一般。尤其是为了紧跟技术的步伐,我们会选择一些新技术,这就得迎接更加严酷的考验。

640?wx_fmt=gif

640

博客园翻车事件

640?wx_fmt=gif

例如,前不久,博客园就英勇而壮烈的翻车了。众所周知,博客园选择了一个构建在.NET平台之上的博客系统,而随着.NET Core的推出,博客园内部的许多系统也完成了从.NET FX到.NET Core的技术改造;而前不久,博客园也将博客系统升级到了.NET Core 3.0 Preview7,然后开始了挖坑、踩坑、填坑的过程。

前前后后,博客园进行了五次尝试,

【故障公告】发布 .NET Core 版博客站点引起大量 500 错误。

 https://www.cnblogs.com/cmt/p/11302666.html

【网站公告】.NET Core 版博客站点第二次发布尝试。

 https://www.cnblogs.com/cmt/p/11316324.html

暴风雨中的 online : .NET Core 版博客站点遭遇的高并发问题进展 。

https://www.cnblogs.com/cmt/p/11328141.html

Powered by .NET Core 进展:验证高并发性能问题嫌疑犯 docker swarm。

 https://www.cnblogs.com/cmt/p/11335456.html

同“窗”的较量:部署在 Windows 上的 .NET Core 版博客站点发布上线。

https://www.cnblogs.com/cmt/p/11347507.html

Powered by .NET Core 进展:第5次发布尝试(Windows部署)。

https://www.cnblogs.com/cmt/p/11357365.html

问题也从最开始的Docker swarm切换到Docker Compose的组件故障,到后来的.NET Core本身的一些故障,期间从博客园团队发布的一些内容来看,也似乎陷入了扯毛线扯掉了一件毛线衣的怪圈,不过最终还是发现了问题的核心,是来源于DbContextPool的线程池限制。

https://www.cnblogs.com/cmt/p/11355978.html

将这个对象去掉之后,终于尘埃落定,取得了短暂的平静,当然,即便如此也无法证明已经真正解决了所有问题,下周是否会重现本周的局面?不得而知。

640?wx_fmt=gif

640

问题分析

640?wx_fmt=gif

博客园对于.NET的执着,让无数优秀的.NET开发者钦佩,但是这些翻车事故,我个人认为,暴露了博客园的一些现存问题。

  • 1、使用还是处于预览版阶段的.NET Core Preview7,虽然已经属于go live,bug少不了,使用了非主流的容器编排技术Docker Swarm。

  • 2、未充分对业务进行大规模的压测和AB测试。

  • 3、将生产环境作为测试环境。

我也冒昧的提几点小建议:

  • 1、将这次环境切换过程的珍贵过程复盘,形成系统的.NET Fx互联网应用升级改造典型案例,让其他互联网开发者能够从中获益。

  • 2、将博客系统开源,让更多开发者参与其中来。

除此之外,也暴露了国内.NET技术圈存在的一些问题。

  1. 多如牛毛的学习资料,却显得不够系统,许多博客都是面向初级开发者,介绍的都是如何编写HelloWorld这样的知识。更高层次的开发者,往往只能借鉴于科学上网,从国外获取有用的学习资源。

  2. 由于国内基于.NET的互联网企业不多,使用容器技术构建互联网体系的更是少之又少,所以缺乏真正能够让企业快速借鉴的容器知识分享或社区交流氛围。

  3. NET技术圈对于大并发的经验不足,对类似的技术缺少分享。

  4. 闭塞的行业应用范围是.NET技术圈的硬伤,与其他技术社区很容易针对技术点发生讨论相比,.NET技术圈依然过于安静,例如当出现问题时,往往大部分开发者都只能看热闹,想插手都无能为力。

640?wx_fmt=gif

640

总结

在这样的大背景下,博客园的勇气依然值得赞赏,毫无疑问,博客园的初衷是渴望通过这次新版本的发布,成功的将.NET Core的优秀宣传出来,让更多开发者能够亲历技术的变革、加入.NET Core的转型之中,不过过程中遇到了太多坎坷。

这恰好跟我们平时开发过程中经常遇到的问题或我们采取的解决问题的办法一模一样。

所以,不要妖魔化博客园,也不必神化博客园,在技术这条道路上,每个人都需要更加努力的学习,并不是为了面子、也不是为了成为第一,而是为了打造更加优秀而完美的产品。

限于时间仓促,胡言乱语,还请诸君见谅。

640?wx_fmt=jpeg

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

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

相关文章

asp.net core 从单机到集群

asp.net core 从单机到集群Intro这篇文章主要以我的活动室预约的项目作为示例,看一下一个 asp.net core 应用从单机应用到集群部署需要做什么。示例项目活动室预约提供了两个版本,集群版和 单机版单机版方便部署,不依赖其他环境,数…

通过Blazor使用C#开发SPA单页面应用程序(3)

通过Blazor使用C#开发SPA单页面应用程序(1)通过Blazor使用C#开发SPA单页面应用程序(2)今天我们来看看Blazor开发的一些基本知识。Blazor中组件的基本结构可以分为3个部分,如下所示://Counter.razor//Directives section 指令部分page "/counter&qu…

ASP.NET CORE 2.* 利用集成测试框架覆盖HttpClient相关代码

ASP.NET CORE 集成测试官方介绍我的asp.net core 项目里面大部分功能都是去调用别人的API ,大量使用HttpClient,公司单元测试覆盖率要求95%以上,很难做到不mock HttpClient 达到这个指数。以下方法是我自己总结的在单元测试里 mock httpClien…

Let's Encrypt网站推出中文版

如今很多网站都强制使用 HTTPS 加密协议访问,安全性有了很大的提高,最起码在数据传输的初始阶段数据包不会被劫持,保证了客户端与服务器端的通讯安全性。说到 HTTPS 加密协议,就不得不提 Let’s Encrypt。Let’s Encrypt 是一家不…

使用WebDeploy部署远程IIS网站

目录 使用WebDeploy部署远程IIS网站后台服务部署服务器配置本地WebDeploy发布文件配置前端页面部署WebDeploy服务端配置WebDeploy发布文件配置使用WebDeploy部署远程网站后台服务部署服务器配置打开IIS管理器(开始->控制面板->管理工具->IIS管理器)添加网站(右键网站…

CF436F Banners(分块/凸包/单调队列)

CF436F Banners 首先有n个物品分别有ai和bi,然后定义价值为 c∗wp∗(ai大于p且bi小于c的用户个数)c*wp*(ai大于p且bi小于c的用户个数)c∗wp∗(ai大于p且bi小于c的用户个数) 然后我们需要求解对于每一个c的最大价值和对应的p 首先我们先枚举c,然后每次加…

译 | 改进 Visual Studio 及 Windows 上 .NET Core 的安装体验

点击上方蓝字关注“汪宇杰博客”原文:Lee Coward翻译:Edi Wang导语Visual Studio 2019 16.3 和 .NET Core 3.0 Preview 7 改进了 Windows 上 .NET Core 的安装体验。目标是减少计算机上可能存在的 .NET Core 版本的数量。这些改进基于客户反馈和我们自己…

SonarQube系列三、Jenkins集成SonarQube(dotnetcore篇)

来源:https://www.cnblogs.com/7tiny/p/11348785.html【前言】本系列主要讲述sonarqube的安装部署以及如何集成jenkins自动化分析.netcore项目。目录如下:SonarQube系列一、Linux安装与部署SonarQube系列二、分析dotnet core/C#代码SonarQube系列三、Jen…

CF198D Cube Snake(三维空间/增量构造)

CF198D Cube Snake n<50 显然是一个构造题&#xff0c;然后很容易想到增量构造&#xff0c;可以考虑每次保证一层值域连续&#xff0c;然后再增加一个值域连续的层&#xff0c;就会产生两个值域连续的正方体&#xff0c;但是只移动头是不够的&#xff0c;所以我们还需要移…

发布ABP v0.19包含Angular UI选项

ABP v0.19已发布,包含解决的~90个问题和600次提交.新功能Angular UI终于,ABP有了一个SPA UI选项,使用最新的Angular框架.Angular的集成不是简单地创建了一个启动模板.创建了一个基础架构来处理ABP的模块化,主题和其他一些功能.此基础结构已部署为NPM包.为帐户,身份和租户管理等…

P4151 [WC2011]最大XOR和路径(线性基应用)

P4151 [WC2011]最大XOR和路径 思路 如果单纯的只是树形图&#xff0c;那么答案显然易见只有一种&#xff0c;也就是从头到尾的路径从头到尾的异或值&#xff0c;但是这里不同的就是有可能在道路上有许多的环。 题目有一个重点提示的一句话 理解这句话之后那么我们可以显然…

Docker(一)-CentOS7中安装Docker视频教程

一、前言Docker的使用越来越多&#xff0c;安装也相对简单。本文使用视频的方式展示在CentOS7系统中安装Docker&#xff0c;本文更适合于准备入门学习Docker的童靴&#xff0c;同时也欢迎各路大神给我们指点提建议。二、环境CentOS7三、安装Docker确认Linux内核版本# uname -a卸…

CF773E Blog Post Rating(推导min的通项/线段树)

CF773E Blog Post Rating 现在有一个值F&#xff0c;每次如果序列加入一个数后重新排列&#xff0c;每次如果F小于期望值&#xff0c;就会1&#xff0c;如果等于就不变&#xff0c;如果大于就-1&#xff0c;求解每一次加入后F的最大值。 这道题的确是非常的巧妙&#xff0c;尤…

用Keras.NET 做一个图像识别的训练

.NET Core 的应用场景越来越广&#xff0c;开源社区也不断壮大&#xff0c; .NET Core在机器学习领域不断发展ML.NET外&#xff0c;也通过结合Tensorflow.NET去完善ML.NET在深度学习领域的功能&#xff0c;在ML.NET 1.3开始迈出了非常重要的一步。这不仅是微软拥抱开源的策略&a…

「数据ETL」从数据民工到数据白领蜕变之旅(六)-将Python的能力嫁接到SSIS中...

前一篇推文中&#xff0c;给大家演示了在SSIS上使用dotNET脚本&#xff0c;实现一些原生SSIS难以实现的功能&#xff0c;并冠以无限可能的说法。充分复用python的现有优势python的确是一门非常优秀的编程语言&#xff0c;特别是在数据领域&#xff0c;网络爬虫、数据处理、分析…

.NET Core玩转爬虫系列之借助正则表达式入门篇

接下来一段时间&#xff0c;我会花些时间研究C#玩转爬虫的方法及其实践。话不多说&#xff0c;开始吧~一般来说:设计并实现一个爬虫的步骤是:模拟登录 -> 模拟发送request请求 -> 取回response数据 -> 提取所需信息并将其进行重新组织 -> 存入DB或文件中 -> 后期…

ASP.NET Core on K8S深入学习(5)Rolling Update

本篇已加入《.NET Core on K8S学习实践系列文章索引》&#xff0c;可以点击查看更多容器化技术相关系列文章。01—What is Rolling Update?为了服务升级过程中提供可持续的不中断的服务&#xff0c;K8S提供了Rolling Update机制&#xff0c;它可以使得服务近乎无缝地平滑升级&…

依赖注入在 dotnet core 中实现与使用:1 基本概念

关于 Microsoft Extension: DependencyInjection 的介绍已经很多&#xff0c;但是多数偏重于实现原理和一些特定的实现场景。作为 dotnet core 的核心基石&#xff0c;这里准备全面介绍它的概念、原理和使用。这里首先介绍概念部分。1. 概念该项目在 GitHub 的地址&#xff1a;…

【LOJ#572】Misaka Network 与求和(莫比乌斯反演/杜教筛/min_25筛)

【LOJ#572】Misaka Network 与求和 https://www.cnblogs.com/cjyyb/p/10170630.html 看到次大质因子就可以想到是min_25筛了&#xff0c;然后只需要做莫比乌斯反演&#xff0c;然后预处理整除分块点的前缀和&#xff0c;然后再结合杜教筛即可。

软件设计的第一性原理:结构化抽象

软件设计的第一性原理&#xff0c;是结构化抽象。术生于道&#xff0c;技术生于原理。引语所谓的第一性原理&#xff0c;就是无论使用什么方法论&#xff0c;都无法绕过的那最最基础的部分。无论是 DDD 设计&#xff0c;还是面向模式的架构设计&#xff0c;或 微服务架构&#…