尤雨溪对 2022 Web前端生态趋势是这样看的

文章目录

  • 前言
  • 开发范式&底层框架方面趋势
    • 基于依赖追踪范式
    • 基于依赖追踪范式—共同点
    • 基于编译的响应式系统
    • 统一模型的优势和代价
    • 基于编译的运行是优化
    • Vue Vapor Mode(input)
  • 工具链
    • 原生语言在前端工具链中的使用
    • 工具链的抽象层次
    • 基于 Vite 的上层框架
  • 上层框架 Meta Frameworks
    • JS全栈的意义是什么 ?
    • 数据的前后端打通
    • 类型的前后端打通
    • JS全栈的代价
    • 社区探索的方向
  • 写在最后

前言

7/22 尤大大在直播中就 2022 Web前端生态趋势 做了分享,本博主作为尤大大的忠实粉丝,也决定将这些干货通过文字形式呈现出来,传播给更多前端爱好者、从事者!

在这里插入图片描述

随着主持人的一句“欢迎尤雨溪先生“ 尤大大又一次以线上的方式与大家见面。

在这里插入图片描述

尤大大从下面的三个前端领域的不同层次来展开了介绍:

  • 开发范式&底层框架(注:大家比较熟悉的Vue、React这些框架层面)
  • 工具链(注:像webpack这样的构建工具)
  • 上层框架(注:例如Next.js、Nuxt.js)

正式分享之前,尤大大提出声明:“本分享只代表讲着个人观点,因为自己是框架和构建工具的作者,肯定会包含利益相关和个人的偏见,但是分享中会尽可能做客观的看法,大家多多多包涵”,下面就让我们饱享这顿“美味”吧!

下面的内容是本博主根据尤大大的分享进行了一定的抽离和少许的个人总结,如果内容出现歧义可以在评论区留言指点!

开发范式&底层框架方面趋势

过去几年中影响最大的开发范式层面的变化肯定就是我们的 React Hooks 随着他的推出可以说是启发了很多组件逻辑表达和逻辑复用的新范式,在 React 生态中彻底取代了 Class Components ,包括现在其实很少能够在 React 中看到 Class Components 了,不仅如此,其实在其他的框架中 React Hooks 也产生了很大的影响,比如说我们 Vue 推出的 Vue Composition API 组合式API,还包括受到 React Hooks 的启发的 Svelte3 ,更有 SolidJS 他是语法上相似于 React Hooks 实现上更相似于 Vue Composition API

在这里插入图片描述

随着 React Hooks 的推广和开发者对其的广泛使用,他开发中的一些体验问题也逐渐被正视,这里不可回避的一些体验问题的根本原因有以下几点:

  • Hooks 执行原理和原生JS的心智模型的差异:因为 React Hooks 是通过把组件的代码每一次更新都进行重复调用来模拟一些行为,从而导致反直觉的一些限制;
  • 不可以条件式的调用 React force
  • Stale Closure 的心智负担:如果你不传正确的依赖数组,那么就会产生过期闭包;
  • 必须手动声明 use Effect 依赖;
  • 如何‘正确’使用 use Effect 是个复杂的问题;
  • 需要 useMemo/useCallback 等手动优化,否则的话就会不知不觉的导致一些性能问题;

尤大大表示作为竞争框架的作者,对 React Hooks 框架的看法可能相对更直接一些,但这些也并非尤大大一个人的看法,而是近年来 React 社区和 React 团队也已经意识到的问题,当然 React 团队针对这些问题也在做改善的努力,据代表性的改善从下三个方面:

在这里插入图片描述

基于依赖追踪范式

在上面的这些改进之前,其实很多 React 的社区成员也包括一些本身就不适用 React 的用户来说,虽然 React Hooks 产生了重大的影响但是大家也意识到了他的一些问题,反而是一些跟 React Hooks 相似的一些逻辑组合能力,另一方面基于依赖追踪的范式开始重新得到了重视;比如在 React 内部的 Recoil ,当然在社区之外就有更多了比如:

在这里插入图片描述

我们可以看一下就基于依赖追踪的范式而言上面三个方案的代码:

SolidJS

//状态
const [count,setCount] = createSignal(0)
//副作用
createEffect(() => console.log(`${count()`}
//状态更新
setCount(count() + 1)

能够看出其实 SolidJS 和 React Hooks 非常相似

-副作用中的 createEffect 跟 React 中的 use Effect 其实是类似的,但是 createEffect 并不需要去声明依赖,在调用 count 函数的时候其实帮你收集了依赖;

-状态更新的时候我们也并不需要用到 useCallback 这种额外的方式去创造函数来去传递给我们的事件侦听器;这些都是非常符合直觉的;

Vue Composition API

//状态
const count = ref(0)
//副作用
watchEffect(() => console.log(count.value))
//状态更新
count.value++

其实 Vue 中使用的 Composition APISolidJS 本质上的内部实现几乎是一样的,只不过 SolidJS 看起来更像是 React ,而 Vue 是通过一个 ref 对象,对象上的 value 机可以读也可以写,在读和写之中就会自动的追踪和更新依赖。

Ember Starbeam

//状态
const count = Cell(0)
//副作用
DEBUG_RENDERER.render({
render: () => console.log(count.current)
})
//状态更新
count.set(prev => prev + 1)

Ember Starbeam 中的这个 Cell 其实就和 Vue 中的 ref api 几乎是一样的,暴露出 count 为当前的值和 set 方法来进行状态的更新

基于依赖追踪范式—共同点

上面提到的三种基于依赖追踪的范式他们的共同点有什么呢?

在这里插入图片描述

同时以依赖追踪为一等功名概念的框架中,本身组件的设计肯定也是跟依赖追踪有紧密的结合,所以组件的更新渲染也会有自动的依赖追踪,也就是说组件的更新会更精确,而不再依赖于一个状态从父组件到子组件一层层传递下去,而是每一个即使是深层嵌套的组件也可以自发的更新,整体上的性能会更好。

react 生态中的 Recoil 这样的方案,虽然也提供了依赖自动的依赖追踪和一定程度的逐渐的更新优化,但是因为他们仍然是需要在 React Hooks 的这个大的体系中使用的,所以在很多其他的方面依然会受制于 hooks 的问题,那么 Hooks 本身在这些方案之外,还是会存在过期闭包等等 user fact 这些问题。

React Hooks 确实是启发了一个新范式的时代,但是慢慢的我们也发现他自己自身存在的一些问题,当然 React 团队正在试图解决这些问题,同时在 React 体系之外,开始有一些其他的具有同等的逻辑组合能力,但同时避免了 React Hooks 这些问题的这些方案存在,也渐渐的收到了前端社区的重视。

基于编译的响应式系统

在这里插入图片描述

不过即使是基于依赖追踪的方案,我们也可以进行一些基于编译时的这个优化,那这里首当其冲的就是 Svelte3

Svelte

在这里插入图片描述

Svelte3 从一开始就是一个编译时优化方案,上面就是 Svelte 组件中的一个使用状态的代码,我们看到他跟他的状态就是这个 javaScript 的这个 let 这样声明一个变量,就是一个响应式的状态,那么你要更新这个状态就直接去操作这个变量就可以,副作用是用一个神奇的编译式的魔法,也就是这个 $ ,这个 $ 的一个label,这其实是 javaScript 的一个label语法来声明, $ 之后的这个语句会自动去追踪count这个变量的变化,当count变化的时候,这个语句就会自动重新执行,那么我们可以看到这个跟我们之前的这个几个代码范例,他所达成的目标其实是一致的,只是他使用编译的手段使代码变的更加简洁,但也正是因为简洁所以存在下面的限制:

在这里插入图片描述

Vue Reactivity Transform

也正是受到上方的限制的启发,Vue 在3.2的时候引入了一个实现性的功能 Vue Reactivity Transform 响应式转换 ,下面就是 Vue 转化后的一段代码:

在这里插入图片描述

还是一个简单的变量声明,但是我们用一个 $ref 这样的一个函数,这个函数其实是一个编译时的一个宏的概念,这个函数并不是真实存在的,只是给编译一个提示,那编译器通过编译之后就会把它转化成我们之前看到的基于真实的 ref 的代码。但是在使用时候,体验就变成了只是声明一个函数,然后使用这个变量和更新这个变量就跟使用一个普通 javaScript 变量没有区别。同时这个语法因为在声明的时候会显式的声明,说哪个变量是响应声,哪个变量不是响应式。所以这个语法可以在嵌套的函数中使用,也可以在 TS/JS 文件中使用,他并不限制于 Vue 文件,所以这是一个更加朴实的编译响应式模型。

Solid -labels

在这里插入图片描述

Solid 的生态中,其实也受启发于 Vue Reactivity Transform ,他的社区用户做的一个 Solid-label,也是基于 Solid 的响应式方案,然后再做一层编译式的优化,那么可以看到跟 Reactivity Transform 能够达成的效果是非常相似的。那最终的目的就是让大家可以用更简洁的代码去表达组件逻辑,同时又不放弃这个逻辑组合,像 React Hooks 那样进行自由的逻辑组合的这些能力啊。所以说这也是一个很有意思的探索方向。

统一模型的优势和代价

在这里插入图片描述

优势:
Svelte相比,Vue的 Reactivity TransformSolid -labels 都属于统一模型,也就是他不受限于组件上下文,它可以在组建内使用,也可以在组建外使用,优势就是有利于长期的重构和复用,因为很多时候我们的大型项目中的逻辑复用都是在我们一个组件写着写着发现这个组件变得很臃肿,很大的时候我们才开始考虑要把逻辑开始重新组织抽取复用,那么由于 Svelte 的语法只能在组件内使用,就使得把逻辑挪到组件外成为一个代价相当大的一个行为,并不是一个简单把文把这个逻辑拷贝复制出去,而是需要进行一次彻底的重构,因为组件外用的是完全一套不同的系统,但是像用 Reactivity TransformSolid -labels 这样的方案呢,我们就可以把组件内的这些逻辑原封不动的直接拷贝到组件外,然后把它包在一个函数里面,抽取就完成了,那么这样重构时的这个代价就非常小,也就更鼓励团队的这样的优化,对于长期的维护性更有帮助。

代价:
因为我们需要显示的去声明响应式的变量,所以它会有一定程度的底层实现的抽象泄露,也就是说,用户其实是需要先了解底层的响应式模型的实现,然后才能更好地理解这个语法糖是如何运作的,而不像 Svelte 组建中的这个语法,即使你完全不了解他底层如何运作的也可以,几乎可以零成本的上手,这就是一个长期的可维护性和一个初期的上手成本之间的一个平衡和取舍。

基于编译的运行是优化

在这里插入图片描述

讲完了状态管理,我们在还可以聊一聊关于基于编译的运行时优化,编译的运行时优化又是三个主要的代表,如上图所示,那首先我们可以看一下不同的这个策略:

在这里插入图片描述

Svelte 的这个代码生成策略相对更更繁琐一些,而 Solid 是基于先生成一个基本的HTML字符串,然后在里面找到对应的 DOM 节点进行绑定,而 Svelte 是通过生成一这个命令式的一个一个节点,然后把节点拼接的这些 javaScript 代码,但这个策略就导致掉同等的这个组件源码之下 Svelte 的每个组件的编译输出会更臃肿,所以虽然大家感觉 Svelte 是以轻量出名的,但其实我们会发现在相对大型的项目中,在项目中组建超过15个之后,Svelte 的整体的打包体积优势就已经几乎不存在了,那么当组建超过50个,甚至是达到100个的时候,所有的体积会越来越越来越臃肿。而相对于而言,我们可以看到 VueSolid 的编译这个输出啊,整体的这个曲线就平缓很多,所以其实在越大型的项目中。反而是 Svelte 的体积优势反而是一个劣势,据我所知,Svelte 团队也有在想要优化这一方面的,可能会在下一个大版本中才能实现,那么我们也会拭目以待。

同时尤大大提出 Solid 的编译性能确实是非常的猛,其实在我们的 Vue 引入了很多编译时的优化以后我们的性能已经比 Svelte 好了,但是离 Solid 还是有一定的距离。

Vue Vapor Mode(input)

就上面提及到的编译时性能优化,其实我们的 Vue 在早期的时候也做了这方面的探索,如还在试验中的一个项目 Vue Vapor Mode

在这里插入图片描述

那同样的这个只有单文件组件输入,我们现在是通过把模板编译成虚拟DOM 的一个渲染函数来进行运行时的实现。但是因为模板是一个编译源,所以我们也可以选择在另一个模式下把它编译成不同的输出,也就是一个更类似于 Svelte 输出。

在这里插入图片描述

这里这个输出的代码只是一个示例代码。并不一定是最终的代码,也不是你需要书写的代码,它完全是一个编译器的输出啊,它的整体的思路就是一次性生成这个模板的静态结构、静态节点,然后再去生成命令式的,找到动态节点,并对把它跟状态进行响应式的绑定的这样一些代码,这个策略本质上就是 Solid 所采用的策略,那么其实呢,这个策略可以被所有的模板引擎所使用,我们也在探索某个版本的 Vue 当中会引入一个可选的这样的一个模式,把模板编译成这样的,性能更优的,运行时的这个体积也更小的一个模式,当然这不会是一个破坏性更新,因为我们的目标是可以让你渐进式的去使用这个功能。

工具链

原生语言在前端工具链中的使用

在这里插入图片描述

关于原生语言在前端工具链中的使用尤大大提出下面几个见解:

在这里插入图片描述

工具链的抽象层次

在这里插入图片描述

最早的打包工具,包括 brow/webpack/rollup 他们都是专注于打包的,他们的抽象层次相对低,当你想要用这些工具去做一个真正的应用的时候,你需要使用大量第三方插件,以及大量的配置来达到一个满足你自己要求的最终的形态。

那么在这个基础上就产生了像 Parcel/Vue-cli/CRA ,这样的一些所谓的脚手架,更高抽象层次的这些工具,这些工具的特点是他们的抽象层的高,也就说他们专注于应用,专注于解决一个完整的应用方案呢,它的相对而言的缺点就是它是一个比较复杂、比较庞大的一个黑盒儿。当你需要去进行自定义的定制的时候,你就会不可避免的遇到一些问题,比如说你跟他默认的功能产生一些意见上的冲突的时候,你就会比较痛苦。

那么我们现在做的这个新项目 Vite 其实可能有一些同学已经在用了,其实我们是在思考过这个抽象层次的问题之后才决定的他要走一个怎么样的路线,也就是说 ViteCLI 它是专注于应用层次啊,它的抽象层次高,它有很多的开箱记,就是事先帮你寄配置好的功能,那么大部分的情况下,你开箱即用就可以达到跟 Parcel/Vue-cli/CRA 几乎同等的这些功能啊,但是我们的API层面啊,这个可能用到的同学会少一些,但是它的API层面其实是专注于支持上层框架,我们这个抽象层次会更低一点,我们只解决一些所有的够 meta framework 都必须要解决的问题,但是对于上层框架,你用什么,我们并不会做过多的限制,反而是要做的更尽可能的灵活,能够支持任何上层框架的用例,所以这也是为什么 Vite 现在几乎成为了下一代的meta framework 共同的一个基底层选择。

基于 Vite 的上层框架

在这里插入图片描述

我们看到上面这么多的上层框架都在基于 Vite 说明我们 Vite 走的路线还是相对成功的。

上层框架 Meta Frameworks

JS全栈的意义是什么 ?

如果我们讲到这个 Meta Frameworks,也就是最典型的例子,也就是NextJS 、NuxtJS、以及现在React社区中的新秀 Remix 等等,那么当我们思考这样类型的JS全栈的时候,我们做全栈的意义是什么?那么相信在国内很多大企业的朋友都知道,因为我们可以用同一个语言去做前后的连接,我们可以做一些纯前端和纯后端都各自做不到的事情,或者说之前需要很复杂的联调才能达成的一些事情,那么JS全栈可以更好的去完成一个语言让我们可以把前后打通。那么我们能够打通什么呢?

数据的前后端打通

在这里插入图片描述

类型的前后端打通

在这里插入图片描述

JS全栈的代价

在这里插入图片描述

一些新的全栈框架,现在在试图去改善的一些问题首先。我们现有的这些前端框架,比如说像主流的像 React、Vue 我们在做了服务端渲染之后,还需要在前端要进行一次所谓的注水,也就是 Hydrate 在追寻的过程中,我们要确保在客户端和前端有同样的数据,所以其实虽然我们的数据已经用于渲染HTML,这些数据理论上在HTML里面已经都用过了,但是我们还得再把这个数据再发送一次,一起发送到前端,让前端去进行 Hydrate 这样一个过程。因为没有这个数据,我们在前端就没有办法保证 Hydrate 的正确性啊。

在客户端,有些组件它可能在客户端是不,需要交互的是静态的,但是他在服务端用到了动态的这个数据,但这个组件依然会被发到服务端,它依然会可能产生这个javascript 运行时的代价啊,以及缓慢的这个 Hydrate 会影响页面的交互指标,也就是 time to interactive。有一些比较复杂的庞大的项目,他可能这个注水的过程会把页面卡顿,以至于虽然能看到页面,但是没法交互,要等个一秒钟才能交互等等,会产生这样的问题。

社区探索的方向

在这里插入图片描述

社区现在新一代的这些全栈框架都在试图解决这些问题啊,比如说像 React 提出了 server only components 其实从这个定义上,我们就发现他是没有一个全栈框架,围绕一个全栈框架去做,其实用户是没有办法简单地使用的一个概念,所以 React server only components 其实是一个必须要全站才能做的概念,Next 当然也会去做,然后,其实 Nuxt 最近也开了一个 server only components 的一个提案,所以说这个已经就是说 server only components 其实不仅仅是一个 React 独有的概念,在很多其他的框架中,我们可能慢慢都会出现类似的这个类似的东西。

还有一个方向就是减少注水,hydration 的这个成本,那么也就是局部的注水,或者也叫 island architecture 就像大海中一个小岛,只有这些小岛去对他进行注水,让他交可交互啊。那么比较代表性的就是 astro、isles 和生态里面的 fresh 这些框架。

然后呢,还有一个探索方向,就是所谓的 fine-grained+resumabl hydration,就是细粒度懒加载,这个数据其实是Qwik这个框架所发明的,Quick 的作者就是 Misko Hevery,也就是 Angular 的原作者,离开Google之后,现在新开发的这个框架啊,那么 Qwik 它主打的就是说它的特点就是不需要再把数据重新发送一遍。他是直接在生成的渲染的html里面嵌入所需的数据从而使得客户端的js可以直接在html里面获得所要的数据,甚至是可以跳过一些需要执行的js步骤,直接跳到一个已经完成的状态上面去,这就是所谓的resumable ,也是一个比较值得关注的一个方向。

以及我们的 Vue 生态里面生态里面有一个我们的 VitePress,我们其实探索的是一个在我们页面的核心内容:其实是静态的MD文件的前提下如何做高效率的 hydration 那么我们做的是所谓的 hydration 就是整个的外部的这个一个框架内容外包着的这一层ui是动态的,然后呢在内部静态的里继续进行局部的注水,然后这样的话,我们依然可以获得一个单页应用的体验,但又获得很好的客户端注水的性能。

到这里呢尤大大的分享就结束了,本博主总结的内容中如果存在争议大家可以在评论区进行指点,希望能够给大家带来一定的收获和成长!

写在最后

如果你正在使用Vue进行前端开发,或者是你准备学习Vue,或者是你对Vue有一定的兴趣,邀请你们到CSDN-Vue技能树来打卡:https://edu.csdn.net/skill/vue

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

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

相关文章

bzoj4919 [Lydsy1706月赛]大根堆

Description 给定一棵n个节点的有根树,编号依次为1到n,其中1号点为根节点。每个点有一个权值v_i。你需要将这棵树转化成一个大根堆。确切地说,你需要选择尽可能多的节点,满足大根堆的性质:对于任意两个点i,j&#xff0…

众多mock工具,这一次我选对了

文章目录写在前面Mock介绍Mock能解决什么问题?传统Mock解决方案Postman接口测试工具Mock js第三方库Eolink解决方案全局Mock高级Mock返回结果Mock智能内置Mock智能自定义Mock约束条件MockEolink的Mock解决方案的优势:写在最后写在前面 交战之前,战士必先利其兵器&…

高并发的理解和使用场景-----特意区别和多线程的关系

一,高并发的理解 1.概念:就是短时间内遇到大量操作请求,导致站点服务器/db服务器资源被占满甚至严重时直接导致宕 2.影响:没有做高并发预处理的系统会给用户很差的体验感; 3.系统好坏的衡量:衡量一个系统的…

async 和 await 原来这么简单

前言 前端同学们可能都知道 async 和 await 的使用,当被面试官问到 async 和 await 的是什么?或者说一说你对 async、await 的理解?如果我们还是仅仅去阐述我是如何使用的就显得格外的苍白无力。今天博主就来带大家进一步认识我们的 async 和…

我为何在 CSDN 乐在其中

文章目录写在前面成为博主究竟能得到什么?内在提升耀眼名片丰富眼界提升知名度博客》变现写在最后写在前面 各位伙伴大家好,我是几何心凉,一位不是很大的也不是很小的博主,今天想要跟大家去聊一些比较实在的内容;大家能…

10分钟设置免费远程桌面

文章目录前言远程桌面设置教程启动Amazon Lightsail实例配置远程桌面启动远程桌面使用远程桌面前言 “你见过洛杉矶凌晨4点的样子吗?” 没有也没关系,你可以轻松配置一台位于洛杉矶的免费远程桌面。 利用Amazon全球可用区,甚至可以在世界各…

BZOJ2690: 字符串游戏(平衡树动态维护Dfs序)

Description 给定N个仅有a~z组成的字符串ai,每个字符串都有一个权值vi,有M次操作,操作分三种:Cv x v:把第x个字符串的权值修改为vCs x a:把第x个字符串修改成aQ:求出当前的最大权字符串集合,使得这个集合中的字符串经过重新排列后满足除最后一…

【第一趴】初探uni-app(uni-app发行者、uni-app推出背景、为什么选择uni-app)

文章目录写在前面DCloud当下跨平台开发存在的问题为什么选择uni-app写在最后写在前面 聚沙成塔——每天进步一点点,大家好我是几何心凉,不难发现越来越多的前端招聘JD中都加入了uni-app 这一项,它也已经成为前端开发者不可或缺的一项技能了&…

Rocket - tilelink - Atomics

https://mp.weixin.qq.com/s/TSwKL_qm-b-0e8x7r--hhg 简单介绍Atomics中数学运算、逻辑运算的实现。​​1. ioAtomics是一个硬件模块,他继承自Modules:​​IO端口定义如下:​​其中:a. write: 是否写操作;b. a&#xf…

“勤学会”火爆来袭

文章目录勤学会是什么?勤学会存在的意义是什么强大的助学团勤学会如何帮助大家学习参与勤学会能得什么奖品专属C计划加入勤学会勤学会是什么? 他来了他来了,其实两个月前勤学会的概念产品就已经出现了,只不过因为了 1024 大型活动…

LeetCode -- 204. Count Primes

题目标签 HashTab(哈希表) 题意及思路 题意:略 思路:有关素数的题目我所知道有两种做法。一种是最基本的isPrime算法,关键点在循环判断时,上限为Math.sqrt(n) (求n是否为素数)。另外…

如何寻找无序数组中的第K大元素?

如何寻找无序数组中的第K大元素? 有这样一个算法题:有一个无序数组,要求找出数组中的第K大元素。比如给定的无序数组如下所示: 如果k6,也就是要寻找第6大的元素,很显然,数组中第一大元素是24&am…

测试MongoDB的自动分片

MongoDB的自动分片: test库分片配置: db.shards.find(){ "_id" : "shard0000", "host" : "127.0.0.1:29017", "state" : 1 }{ "_id" : "shard0001", "host" : "1…

线上CPU飚高(死循环,死锁……)?帮你迅速定位代码位置

top基本使用: top命令参考本篇文章 查看内存和CPU的top命令,别看输出一大堆,理解了其实很简单 top 命令运行图: 第一行:基本信息 第二行:任务信息 第三行:CPU使用情况 第四行:物理内…

zookeeper watch笔记

ZK其核心原理满足CP, 实现的是最终一致性, 它只保证顺序一致性. zookeeper 基于 zxid 以及阻塞队列的方式来实现请求的顺序一致性。如果一个client连接到一个最新的 follower 上,那么它 read 读取到了最新的数据,然后 client 由于网络原因重新连接到 zoo…

单机简单搭建一个kafka集群(没有进行内核参数和JVM的调优)

1.JDK安装 在我的部署单节点kafka的博客里有相关的方法。(https://www.cnblogs.com/ToBeExpert/p/9789486.html )zookeeper和kafka的压缩包下载地址也在单节点部署的这篇博客里。 1.zookeeper集群的搭建 将zookeeper.tar.gz解压为三个目录,例…

[翻译]三张卡片帮你记住TDD的基本原则

原文地址:http://blog.briandicroce.com/2008/03/14/three-index-cards-to-easily-remember-the-essence-of-test-driven-development/ 当我浏览ObjectMentor的博客的时候,其中一篇Tim Ottinger的“TDD on Three Index Cards”引起了我的注意。他回忆了他…

凉哥核心圈程序员必备十大图书推荐(一)

写在前面 凉哥核心圈程序员必备十大图书推荐(一),各位伙伴应该一目了然了哈,没错凉哥准备出一系列图书推荐的文章,其实很多朋友在私下问凉哥除了大学的课程外自己要不要读一些技术类的书籍呢,答案当时要的…

了解大数据的特点、来源与数据呈现方式

本次作业来源于:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE1/homework/2639 1.浏览2019春节各种大数据分析报告,例如: 这世间,再无第二个国家有能力承载如此庞大的人流量。http://www.sohu.com/a/290025769_313993春节人口迁…

强大而优雅,API 研发管理 EOLINKER 新版正式发布!

EOLINKER 于2019年3月3日正式发布新版本!该版本大幅强化各个产品的功能、着重优化了全站的用户交互体验,并且EOLINKER AMS 产品正式更名为 EOLINKER API Studio ——API 工作室,旨在为您提供API文档管理、自动化测试以及开发协作等全方位服务…