本文作者:程序员鱼皮
大家好,我是鱼皮。前段时间,我不是做了一个面试刷题网嘛,现在这个网站可以说是 危在旦夕 ,估计是别想活着了。
但没关系,它背后的技术还是非常值得学习的,今天就简单分享一下。
这也是我自己很喜欢的一套技术栈,百试不爽,想 快速 做个网站的话,非常值得参考。
B 站发过视频,文字版补充了更多链接,方便查看。
前端就是给用户操作的界面:
先说开发,最基本的技术就是 HTML、CSS、JavaScript
三件套。
可以通过 FreeCodeCamp 免费学习:https://chinese.freecodecamp.org/
为了提高开发效率,我使用主流开发框架 React
代替原生 JS DOM 操作,支持组件化开发,用习惯之后会非常爽:
React 代码
然后搭配 Umi
框架快速搭建项目、实现路由等功能:
我使用 Dva
来对用户信息、权限等数据进行全局状态管理。Dva 是一个基于 redux 和 redux-saga 的数据流方案(作用类似 Vuex),然后为了简化开发体验,Dva 还额外内置了 react-router 和 fetch,所以也可以理解为一个轻量级的应用框架。
Dva 的数据流
为了减少开发成本,我使用 Less
代替原生 CSS,可以通过定义变量来复用代码,比如把经常用的宽高值单独提取出来:
通过引入现成的组件库 Ant Design、Ant Design Components
,可以大大节约工作量,并且保证网站风格的统一:
Ant Design:https://ant.design/index-cn
Ant Design Components:https://procomponents.ant.design/
现成的组件
为了提高项目代码的规范,预防屎山。我使用 TypeScript
来约束变量类型、使用 ESLint
检查 JS 代码、使用 StyleLint
检查 CSS 代码,使用 Prettier
来一键格式化代码。
TypeScript:https://www.tslang.cn/
ESLint:https://eslint.bootcss.com/
StyleLint:https://stylelint.docschina.org/
Prettier:https://prettier.io/
ESLint 检查代码
写好代码后,需要通过打包工具进行编译、打包、构建。我这里用的是经典的 Webpack
,它的作用就是帮你把零散的代码文件组织好,变成可运行的网站文件包:
Webpack:https://webpack.docschina.org/
这里肯定有同学觉得,这么多技术太复杂了!说实在的,写到这里我自己都觉得累。
但其实没那么麻烦!使用 Ant Desgin Pro
提供的脚手架,开箱即用,一行命令生成初始项目代码,直接把上面的所有技术全都整合好了:
Ant Design Pro:https://preview.pro.ant.design/
自动整合
甚至还提供了一套现成的后台管理界面,并能通过点击的方式快速创建页面:
现成的后台管理页面
真心牛皮啊!
写好代码后,怎么发布给别人看呢?
这里我 “没有” 使用服务器,而是用 Docker 容器
封装了 Nginx
Web 服务器,并部署在 云托管平台
上,实现了弹性伸缩(访问量大时,容器数量自动增加、抗住更大并发;访问量小时,容器数量减少,节约成本)以及负载均衡(分配请求到不同容器上,从而降低单个容器的压力):
至于网页文件之类的静态资源呢,直接 “扔” 到了 CDN
上。CDN 即内容分发网络,能够把你的文件分发到全国各地的节点,使得用户就近访问,提高加载速度。
CDN 内容分发网络
简单来说,后端的作用是为前端提供数据和服务。
对于增删改查之类的业务逻辑处理,我原本选用 云函数
,用 Node.js
编写代码,每个功能一个函数,以 serverless
的形式独立部署,互不影响。
serverless 架构
但随着系统的越发庞大,函数数量太多,管理不便。因此我选用 Node.js 的后端框架 Express
对云函数进行重构,糅合成了整体系统。
Express:https://www.expressjs.com.cn/
重构为整体系统
Express 用起来非常简单,几行代码,监听个端口,服务就跑起来了:
我选用云开发提供的 MongoDB
文档数据库来存储数据,而不是 MySQL 之类的关系库,因为它的读写性能更高、字段更容易扩展,更适合初期项目。
MongoDB 文档数据库
为了提高数据查询速度,我使用 Redis
这一高性能的内存数据库实现了缓存。同时利用 Redis 实现登录会话、限流、分布式锁等功能。
Redis 的使用
为了提高题目搜索的准确性和灵活性,我会定期将题目数据同步到 Elasticsearch
集群上,这玩意不仅能帮你存数据,还会自动对内容进行分词、实现高性能检索。
我的 Elasticsearch 集群
为了实现点击公众号菜单登录的功能,我单独开发了一个 Java SpringBoot
的小服务来和公众号对接。
为什么这里突然用 Java 了呢?不为别的,现成的 WxJava
库实在是太香了!
封装了微信接口的库
写好代码后,所有的后端服务都和前端一样,使用 Docker 容器技术,放到 微信云托管
平台进行部署,除了天然支持负载均衡、打通微信外,什么自动发布、版本控制、灰度发布、日志检索、实时监控,各种能力基本都一手操办了。
用了容器技术后,用户图片等静态资源就不能存到本地了(其他容器可能缺失文件),而是使用 OSS 对象存储服务
进行存储,配合 CDN 实现访问加速。
对象存储服务
为了性能和安全性,我在云托管的上层又套了 ECDN 全站加速网络
,通过智能分配网络链路,动态的接口也能加速。
它的原理如下:
老实说,效果还是很明显的,但就是要产生额外的费用, 慎用 !
此外呢,为了让网站更好地被搜索引擎收录,我还搞了个 Prerender
服务。它的原理有点像 SSR(服务端渲染),如果识别到访问者是搜索引擎的小蜘蛛,Prerender 服务会将数据完整地拼接到页面后,再返回给它。
这里我用的是现成的 prerender 镜像,不用自己封装了:
以上这些就是我的小破站用到的技术。最后强调一下:不是所有网站都得用这么多技术 ,也不是这些技术都要学习! 有一套自己喜欢、用的顺手的技术栈,就完全足够了,后面再慢慢积累。
最后放一张面试鸭网站的架构图,随便画的,仅供参考:
面试鸭网站架构图
该架构图是用 Draw.io 画的,如果你想以这个图为模板画出自己项目的架构,可以在俺的公众号【程序员鱼皮】后台回复【架构】获取源文件:
最后,提前给大家拜个年哈,祝各位朋友们新春快乐,阖家幸福安康!