百度360必应搜狗淘宝本站头条
当前位置:网站首页 > SEO教程 > 正文

技术干货:我们的项目是如何技术选型的

gaoyangw 2025-03-02 17:11 15 浏览 0 评论

本文作者:上海驻云开发总监 陈昂

以下正文:

公司逐渐壮大,团队日趋稳定。作为一名陪着公司一块成长的一分子,我深感欣慰。蓦然回首,发现我们竟然有了诸多产出与成果。有平台,有工具,有产品,有项目。有些项目进行中,有些产品已夭折。但不管怎样,看着这么多已有成果,还是小小的骄傲了一下。然而骄傲之余,精心沉思,我们积累的太少,沉淀的不够。以前,我们就像是在打仗,为了生存,你死我活,兵贵神速,分秒必争。现在,我们多少可以喘一口气的时候,有必要回顾下,总结下,沉淀下了。

那么,今天就先回顾下我们之前这些项目的技术选型过程吧。

时间回到2013年,当时刚刚换了一份糊口的工作。一家广告公司,美女如云,帅哥成堆,有充足的时间和资源让你定位自己的性取向。然而胖子的一通电话让我没有时间再去思考性取向的问题了。他电话中对云计算一阵云里雾里的吹嘘,让我的小心脏顿时扑通扑通的久久不能平静啊。立马决定加入他的新公司,拥抱云计算,迎接新挑战。

一个月后,到了新公司,哦不,应该说到了兄弟公司,借位办公(新公司还没完全成立,办公地点也还没选好,这些都不重要了,重要的是新产品已经开始规划了)。挖了两个前同事立马开干,做一个可视化云设计平台,主要面向阿里云(国内云计算老大嘛,抱大腿嘛,当然要抱老大的大腿喽)。通俗的讲呢,通过这个产品,用户可以方便直观的设计出云资源架构。

产品有几个基本需求:

1.免安装

2.兼容iPad

3.拖拽操作

4.呈现的架构够直观

5.能够同步基础云资源(阿里云)

基本需求不多,但各个切中云计算痛点。发挥的余地还是比较大的。对于第一点,免安装,那么基本只考虑WEB方式了。

既然是WEB应用,就要先考虑五花八门的浏览器的兼容性。由于这个产品的客户比较面向技术,IE也就暂时不考虑兼容(不解释)。最后选了两款浏览器作为主要兼容目标:Chrome、Safari。

选好浏览器就是开发语言的选型了。JS肯定是必须的,另外,那么后端语言,零零总总一堆:PHP、NodeJS、Python、JAVA、ROR...

? PHP是WEB霸主,有很多成熟的WEB框架

? NodeJS是新贵,本身就是JS语言,前后端基本不存在兼容问题

? Python语法够优雅

? JAVA够厚重稳定,但是开发慢

? ROR够快,但是比较适合MES系统

? ...

我们这个产品有什么特点呢:

? 面向云计算的设计和同步平台

? 前端有大量复杂的逻辑和计算

? 后端不需要太负责的逻辑支持

? 能够快速开发和产出,因为当时如果不及时产出,公司可能就死掉了(QAQ)

既然这样,我们直接先排除了JAVA、Python、ROR。后来在PHP和NodeJS之间犹豫了好久。最后考虑到PHP恶心的语法,考虑到NodeJS完美支持JSON,最后考虑到我们需要实时同步而NodeJS领域有个Socket.io可以完美支持,就选择NodeJS了(其实那些都是为了说服自己的理由,PHP毕竟还是很成熟的)。

接下来的事情就是选几个已经有很多轮子的框架或工具,帮我们造车。

? 由于前端需要Canvas,最后找了一个很不错的Canvas框架KineticJS(其实我们是先看到了KineticJS,再定了Canvas),KineticJS封装了丰富的Canvas组件,让我们可以以组件的方式操作画布,方便开发。

? 模板层我们选了轻量的Handlebars。

? 后端NodeJS层面选用Express

? MongoDB层面选用Moogoose来操作数据

? 由于前后都是JS,为了提高开发效率,强制大家都用Coffeescript(js的转义语言)来编写代码(几乎所有项目沿袭至今)

? CSS用Less,就像Coffeescript一样

? 项目构建采用Grunt

其实这些技术选型还是很盲目的,然而技术永远不可能有最好的,只有最适合的。虽然是盲目的选型,但是选型和推广的过程的确是痛苦的,不管团队是人多还是人少。世界上最难得的事情莫过于说服别人改变自己的习惯。比如推广coffeescript,有一个开发很排斥,一开始死活不愿用coffee写js,感觉这样不够正宗,他的一句话还让我快吐血了,是男人就不该戴套。不过私下里他还是尝试了coffee,也很发现了coffee带来的快感。

后来的事实也证明我们的技术选型带来了很大的优势。三个人,两个月就出了第一版,并参加了阿里云开发者大会,收获也不同凡响。后来又经过几个月雕琢,出了好几个版本。奈何当时阿里云API尚缺稳定,也不够丰富(当然我们也是对API深度使用了),我们只发布了一个设计版。

这里有必要发一下我们这个产品的简单部署架构。

架构很简单,同时,这个架构也是我用我们这个产品画出来的。其实这个产品还是有很多bug的,以及体验上的缺陷。

然而,这些都不重要了。我们度过了生存期,而且还带来了个意外的项目,为阿里云做一个VPC的可视化平台(这个平台现在你已经看不到了,放个图吧)

有时候事情的发展就是这样,做好了自己的本职工作,幸运就会降临,就像国足这次进入12强,赢得了牵动亚洲的计算题一样。

这个项目的技术选型和上面那个产品差不多,就不赘述了。需要提一下的是这个项目在部署阶段遇到拦路虎了。因为是阿里云的项目,部署环境理应是用阿里云资源,一开始的架构是这样的:

前面还是负载均衡,挂载两台机器,缓存服务采用阿里云的OCS,数据库我们尝试用OTS。

在部署的过程中,发现SLB无法透传Websockets,也就无法支持Socket.io工作,而Socket.io在这个项目中起了很大的作用。我们尝试着SLB从HTTP换成TCP模式(毕竟SLB对TCP模式是直接转发的IP),但也不行,当时没搞清楚是阿里云产品的问题还是我们配置问题(当然现在的阿里云SLB已经很完美了)。后来经过多次尝试,终于曲线救国,socket.io 改用polling的方式,不用websockets。另外为了充分发挥多核的性能,NodeJS也开启多个进程。但是为了满足Socket.io,要保证Session在同一进程,Nodejs每个进程就开启了不同的端口,前面通过Nginx 配置 IP Hash并反向代理到不同的NodeJS端口。如下图所示

再后来,发现OCS的Node SDK不稳定,就启用了OCS,直接换成了ECS搭建Memcached。

经过几个月的奋战,这个项目成功上线,来不及喘息,新项目又来了。

这次要做一个云管理平台,典型的MES系统。项目开始,技术选型这块就出现了矛盾。基本明确的是基础语言不变,后端还是NodeJS,数据库换成RDS。

但是前端的框架起了争执。之前的那些框架或工具明显不适用了,得选一个能够快速开发并且方便维护管理的前端框架做支撑,这时候AngularJS和EmberJS进入了我们的选择。一个是Google出品,上手快,但深入难。一个是社区项目,更面向生产,但不够轻盈。我坚持选择EmberJS,因为更加面向生产,也更加面向团队协作,不像AngularJS引入了很多新概念,学习成本更低。一个同事坚持Angular,他之前就用过,而且Angular更火一点。最后我做了妥协,毕竟不管哪个,对我来说都是新的。而如果团队里有一个有经验的人在,会更加可靠一点。

后来的情况是这样的,Angular配合着NodeJS带来了极速开发,项目一个多月就上线了(你没看错,是一个多月)。这个框架在公司也就火起来了(虽然开发还是不多)。这期间,我个人也对Angular上手了,感觉框架本身的理念还是很超前的,开发非常快,特别适合MES系统,如果你的系统是管理系统,BOSS系统,或是信息系统,用它,绝对没错。

公司这时候也逐渐壮大了起来,产品和项目也多了起来。一个产品或项目再也不是只有一个两个人奋战的情况了。团队成员之间的协作也变得日趋重要和紧密,程序需要解耦,团队协作同样也需要“解耦”。敏捷开发时代,前端程序是不可能等后端API都调试好了再进行开发的。这个时候就有人提出了“前后分离”这个词。这个词当下很火,阿里也在做这样的事情,只不过业务不同罢了。几个人坐下来一合计,感觉这事靠谱,做吧。接口规范定义清除,数据格式定义清除。后端无需关心前端的业务逻辑,只要保证好什么样的接口应该具有什么样的权限,应该如何传参,返回什么样的数据就行。校验不通过,按照既定的数据格式返回给前端。前端业务只需要根据后端的API返回数据做进一步的逻辑处理就行。前后端同步进行,没有完成的接口,前端通过Mockup调试,完成了就联调。直到现在,我们的前端妹子,还在说,“前后分离”大法好啊。

? 永远没有一招鲜的技术

永远没有一招鲜吃遍天的技术,也没有一招鲜的选型。因为业务的需求,我们接了一个外包。对方公司要求做一个CMS系统 + 开发者平台。如果不考虑其他因素,CMS系统我们可能就直接上Drupal啦,开发者平台就通过Angular +NodeJS实现。可是对方还有一个需求就是开发完成3个月内能够接手代码,而对方公司技术人员大多数是JAVA背景。为了能够让对方快速接手,我们做了如下的技术选型。

在这个模型中JAVA层只负责和客户的TOP数据接口打交道,然后通过提供RESTful风格接口为前端系统提供接口服务。其中CMS和开发者平台都是基于Angular打造。由于网站直接面向公众,更多也是静态页面,需要有更好的加载性能和SEO友好,所以通过NodeJS进行渲染,而NodeJS又和JAVA进行数据交换。

开发的过程,其实并不是太顺利。一方面因为对于CMS系统(业务复杂性很高)的不了解,我们等于说是从0打造,没用太多的轮子可用。另一方面,项目存在三方协作的问题,协调效率并不是太高。但不管怎样,项目还是顺利完成了。

? 新的挑战

随着业务的发展,公司想要对最早的架构云重新打造,让其上升到一个更高的高度。如果要用数字1表示一个产品是完整的,那么之前的架构云只能说是0.8。毕竟是公司初期的产品,也有很多产品外的压力因素导致我们没有做到1。不过公司今非昔比了,有充分的时间让我们静静思考下产品,我们有了更高的目标和要求,那就是把产品从0.8做到1,再做到5。基于这个目标,经过团队人员的讨论和商量,老产品维护成本太高,基础选型也不够成熟,我们打算对其进行重构。重构的第一关就是技术选型啦。结合之前的经验,我们认为,轻量级的框架会给我们带来更高的掌控性和稳定性。后端选了NodeJS,数据库采用Mysql。更多的工作是在前端。经过Demo尝试,SVG性能更好,开发起来也更加舒服。基于SVG选了Snap.svg(比较轻量的SVG工具)。在渲染层面,选了鼎鼎大名的ReactJS。ReactJS的VirtualDOM对于画布的渲染有着非常高的性能和可维护性,也能方便的做到组件化和模块化,进一步降低开发成本。以下就是我们新的架构云技术选型

新的架构云已经如火如荼的进行中了,几个月后,大家将会看到漂亮的第一版。敬请期待~~~

好啦~本文到这里就结束了,同时,如果喜欢我们的话就赶紧订阅我们吧~~~每天定时推送新鲜干货~~~也可以关注我们的微信公众号:架构云专家频道 每天同步更新哟~~~

相关推荐

工业品短视频推广/工业品短视频推广,搞懂2点让客户主动找上门

工业品短视频推广/工业品短视频推广,搞懂2点让客户主动找上门。为什么你拍了那么多短视频都没有效果,我们陪跑了几百家客户,发现没效果的账号基本就这3种情况,一种是把短视频当成朋友圈,晒日常生活,账号标签...

流程优化,其实是一场管理变革(流程优化的三个原则)

“信息化”一词,相信大家都不会感到陌生,但什么是信息化?企业信息化要做些什么?对此的理解真是仁者见仁智者见智。...

引爆中小卖家免费流量入口关键词梯形架构

“在我从代运营做天猫转到自己去经营自己的C店的时候,我终于知道,原来这个世界上做淘宝的,并非每一个人多那么有钱可以去砸直通车,也不是每一个人多可以请得起薪酬十来万的设计的,近两年我一直在摸索一种适合小...

百度搜索2015移动大事记:优化、流量追查等

站长之家(Chinaz.com)注:纵观2015这一年,百度搜索的关键词不外乎“移动”二字。为了响应移动互联网的大势,百度不遗余力的在移动搜索上下足了功夫。从搜索引擎算法、到站长平台工具都做出了许多改...

百度站搜带你玩转站内流量(百度站长app)

先给大家看几张效果图:图1图2图3这3种激发用户搜索需求的牛B武器你的站点“武装”了么?使用效果如何?现在让我们来看看一下网站使用后的心得以及效果:比特网:由于比特之前有自己的站内搜索工具,所以百度刚...

继PC端后 百度移动搜索也将取消refer关键词显示

站长之家(Chinaz.com)12月4日消息今年6月25日,百度搜索正式取消了referer中关于关键词的显示。近日,百度站长平台在公告中表示“百度移动搜索中也将逐步取消referer关键词的显示”...

知己知彼,百战不殆--六个方法帮你分析对手网站

好的推广专员对竞争对手的网站进行分析是必不可少的,根据竞争对手每个阶段及时做好SEO的调整。做好知彼知己才能对后期的优化有所帮助。下面小编就分享分析竞争对手网站的六大SEO方法。1、网站年龄网站时间...

百度站点属性功能升级 全面取消referer关键词显示

站长之家(Chinaz.com)6月30日消息近日,百度站长平台发布公告称已对“站点属性”功能进行升级,此功能已作为独立工具展示于工具导航栏中。站长可通过“站点属性”功能对站点中文名、站点类型、以及站...

大连关键词优化推广公司(大连seo推广优化)

关键词挖掘与关键词分析提高网站权重的方法最重要的一步就是挖掘有质量的关键词。然后根据关键词的情况进行标题创作和内容的创作。关键词分析分类:1.有指数的关键词2.没有指数的关键词关键词挖掘分类:品牌关...

如何实现AI文章免费优化,轻松提升网站排名?

你是否觉得,尽管文章内容已经写得很棒,网站的流量却始终无法突破瓶颈?是不是常常觉得自己做了很多优化工作,却依旧难以提高文章的搜索排名?其实,很多人忽略了一个关键问题,那就是“如何优化AI文章”。尤其是...

AI搜索SEO优化排名公司推荐(seo搜索引擎优化排名)

AI搜索SEO优化排名公司推荐,随着AI的平民化,越来越多的人开始通过AI寻找自己的需求,例如通过问AI助手,广州哪家火锅好吃?深圳家政服务哪家公司好?北京全屋定制哪家靠谱?如果这时候AI推荐了你的...

构建可以查找相似图像的图像搜索引擎的深度学习技术详解

在本文中将介绍如何查找相似图像的理论基础并且使用一个用于查找商标的系统为例介绍相关的技术实现,本文提供有关在图像检索任务中使用的推荐方法的背景信息。阅读本文后你将有能够从头开始创建类似图像的搜索引擎...

搜索引擎语法,教你高格逼利用搜索引擎!

百度语法1.site把搜索范围规定在特定的站点中。但是有时候你需要找一些特殊的文档,特别是针对于专业性比较强的网站合理使用site可以让你取得事半功倍的效果。举例说明:site:sina.com(不...

Off-eBay搜索引擎下,listing和店铺 SEO技巧

雨果网从外媒近日报道中了解到,eBay正在举行一系列促进销售增长的专家网络研讨会(ExpertAdviceGrowthWebinars),第一场在3月3日举行。外媒为未参加网络研讨会的卖家,挑出...

搜索引擎原理系列教程:收录、索引、排名

《搜索引擎原理系列教程》这个虽然称不上书籍,但由于里面信息量以及内容比较实用,也弥补了百度白皮书的一些短板——话语浮于表面,另外值得鼓励的是,这个教程完全是由一个民间的SEO爱好者总结,这份精神值得称...

取消回复欢迎 发表评论: