前端与后端的思维专注点很不相同,前端聚焦在如何把内容以可视化的方式展现给用户,后端聚焦在如何利用it基础设施实现业务逻辑。所以前端参与后端开发时(全栈工程师必备!)首先需要理解后端会做哪些事,其次才是如何才能做好这些事。
所谓“利用it基础设施实现业务逻辑”,意味着以下几个概念:
it基础设施有哪些?
数据库一定是最重要的,这里特指关系数据库,例如mysql。因为前端所用的数据库往往非常简单,浏览器或者app毕竟只服务于一位用户,而后端的数据库需要服务于全部用户,这不是一个量级。在现实世界中,一旦量级发生改变,需要用到的技术就完全不一样了。数据库的基本操作acid、事务、关联查询、索引都是完成业务逻辑的必备品。
缓存也是前端必须理解的概念。后端可以直接操作sata磁盘,ssd磁盘,内存等不同的存储介质,而这些介质的存取速度差异巨大。cpu操作l1和l2缓存只有3个纳秒以内,到了l3缓存(可以以mb为单位计量了)就得10纳秒以上了,而到了内存就得100纳秒以上,通过网卡访问远端则需要数百微秒,访问机械硬盘则要几十毫秒。为了能够让用户的请求尽快获得响应,必须使用缓存。很少的场景下才会直接编写缓存,通常后端都在使用的缓存服务包括redis、memcached等,其中前者使用更多。
如何正确的分析业务逻辑?
uml图是一个非常好的手段!类图、时序图、状态图可以帮助后端理清先做什么、再做什么、不会漏掉什么。这是因为后端的程序需要整年的运行不能宕机,而前端是没有这种要求的。因此,后端必须全面的考虑各种异常情况,防止一个用户(请求)引起的意外把整个服务宕机,影响了全部用户。
业务逻辑如何与it设施结合?
了解mvc模型!前端有许多模型,例如mvvm等,这些名词不重要,因为它们的关注点各不相同。对于后端,通常m意味着关系数据库,所以后端的web框架一定围绕着m进行。我们分析任何一个web框架,一定先要看它的数据库模型,即如何将数据库中的表、行映射到编程语言中。另一方面,http协议有许多特性,它会导致mvc框架试图以此解耦,将url的配置与业务处理代码分开。最后,web框架由于处理场景的复杂,通常以可插拔的方式将许多插件串行的组合起来处理一个请求。前端在学习web框架时,把握这三点即可快速掌握。
前端做后端时最容易犯2个错误:
日志打得很少
后端的复杂场景会导致bug难以复现(相比前端更难),且一个应用服务可能跑在多个服务器上,所以error、info、debug等级日志的输出显得尤为重要!没有日志,问题很难定位!
资源没有即用即放!
因为服务是7*24小时运行的,所以一点点资源泄露(如打开了句柄却未关闭)都会被时间放大!最后导致严重后果。
后端的代码如何更高效?答案一定是算法!
好的算法在我看来就是3点:
不做重复的事;
充分利用已知信息或者中间计算结果;
充分利用it基础设施的特性。比如多核、cpu亲和性、存储介质的性价比、网络报文的收发等。
为了达到这一点,我们必须学习:
算法复杂度;
分而治之的思想,这可能是所有算法思想中最有用的了;
计算机体系的特点,如cpu架构、网络通讯成本等;
常用数据结构,如树、哈希表、图等。
本文出现的原因是团队中有前端同事想在后端试试水,我当然非常欢迎,于是尽量从我对前端的理解上阐述后端开发的要点,或者更准确的说,是后端web应用开发工程师的开发要点。全栈工程师的要求高得多,这里虽然有些标题党嫌疑,但好在标明了基础版,进阶版在好好谈谈前端转全栈工程师的其他要求。
激光雷达如何挽救低迷的汽车产业?
基于uC/OS-II的变频器结构控制系统设计
串行比并行接口快的四大原因分析及提高单线传输速率的三种方案
保时捷与西门子合作开发合成燃料
GB 31241-电芯重物冲击试验机在不同标准要求下的试验步骤
前端程序员怎样转型全栈工程师
贴片射频电容与贴片电容的区别
小米路由器3怎么样:小米路由器3入手体验
算力供求优化:助力数字经济腾飞
DIY一个移动电源的过程分享
fft算法以及c语言实现详情解答
分析师称苹果服务业务第四季度仍将保持两位数增速
锂离子电池和锂聚合物电池的区别在哪
ICT技术连接城市与乡村 从特岗教师的需求金字塔 重新理解乡村、教育和科技
用于仿生机器人中的机械原理
中线安防保护器安装使用注意事项
GSMArena分享了即将推出的Realme Race旗舰手机的泄露图像
华为云 828 营销季正式开启,打造中小企业“上云嘉年华”
计算微波电路的并行算法详解
传感器系统的增加便利性和增加意识的用途介绍