2020 Stack

栏目: IT技术 · 发布时间: 4年前

Full Stack Pronounced Dead

Welcome the 2020 Stack

Jan 2 ·8min read

2020 Stack

The author decides it’s time to update his job posting and hiring practice to reflect a new reality: “Full stack” is no longer helping him to match job requirements with applicant skills.

The Genesis of Full Stack

At the dawn of the new millennium, web tools had reached the point where everything needed to build a website could be assembled from open source software. Loosely following the OSI network model, we began to refer to the individual pieces of the assembly as layers and the collection as a stack .

The LAMP stack was the first of these, with four layers: L for Linux operating system, A for Apache HTTP server, M for MySQL database server, and P for PHP scripting language. Over time, the layers concept proved itself well as many stack variants popped up: WAMP, MAMP, XAMPP, LEMP, LEPP, MEAN, JAMStack, and others.

With each of these, the keys to a renaissance in software development were freely available, providing a low barrier to anyone interested in creating websites. All that was needed was perseverance and the desire to learn new tools, languages, and protocols. There was no need for Microsoft or Oracle or IBM or other commercial vendors. It was a level field, attracting lots of players, resulting in the speculative dot-com era of the late 1990s.

Soon, the introduction of AJAX in browsers (XMLHttpRequest) enabled a new type of website, leading to the Web 2.0 era and web applications. But the amount of work involved in developing these new applications meant that solo developers were hard-pressed to meet business deadlines.

The result was specialization. Front end developers handled the HTML, CSS, and JavaScript. Back end developers handled the host operating system, the HTTP server, and the database. And developers that were fluent in both were termed full stack developers.

The Full Stack Era

Specialization was a good thing. Until it wasn’t. On the one hand, it meant that teams could work in parallel to shorten the development cycle. On the other hand, it meant we had to work extra hard to communicate initial requirements and change-order specifications, or we’d risk losing the benefit of that parallel work effort.

So having a team of full stack developers, without distinguishable front end/back end groups, seemed like a good idea.

The most important benefit was that every developer on the team knew full well the consequences each little change would have. They could each properly evaluate impacts and risks, giving management a clear picture of costs and delays. And, as a bonus, when there were staff departures, replacements could be shuffled in without delay, and onboarding could be carried out efficiently.

But as the fundamental technologies improved, this rosy picture became less compelling. The stack was no longer limited to the initial four layers of operating system, HTTP server, database, and scripting language.

  • Complexity arose as we needed to grow our humble applications to handle an ever-larger number of concurrent users. So we added load balancers.
  • We needed faster provisioning of new servers, with less risk of catastrophic failures. So we switched to cloud computing.
  • We started building things to reach a global audience. So we began to replicate our deployments to regional data centers.
  • We discovered that schema-heavy databases and complicated joins weren’t always best. So we began using key-value stores.
  • We needed better quality control. So we hired dedicated test engineers to build regression suites.
  • We wanted to put the browser in control of rendering and composition. So we switched from server-side scripting to REST APIs.
  • We learned that good code management was critical to a team’s effectiveness. So we created workflows using Github and never looked back.

And as our capabilities grew, we began to listen more closely to our users:

  • Our users expected applications to have fewer submission forms, more fluency, more consistency, and greater ease of use. So we hired user interface experts with artistic skills and ergonomic sensibilities.
  • Our users demanded fewer obstacles to get their work done. So we hired user experience specialists to study our shortcomings and to design better ways to interact.
  • Our users discovered the convenience of cellphones and pestered us until we gave them mobile versions of our big SaaS apps.

And throughout all of this, the fundamentals kept marching forward:

  • HTML5 matured to encompass the semantic web, accessibility, service workers, and components.
  • CSS grew, going way beyond selectors and cascades, to encompass transitions, variables, new layout models, and paged media.
  • JavaScript exploded, with modularization, object-oriented classes, asynchronous functions, and the ability to execute anywhere — in the browser’s DOM, on the server, and on the desktop — all with the same scripting language.
  • And HTTP advanced with better caching, security policies, persistent sessions, multiplexed streams, header compression, and prioritization.

The full stack era didn’t die so much as it was overrun. The layers of the stack grew so vast that no one person could be an expert in everything. Diversification of duties and specialization was the natural result.

The glory of the full stack engineer working as a Renaissance Man had become the stuff of legends. And in this new era, no one person could hope to do it all.

The 2020 Stack

This leaves us with open questions. Is there still a role for talented individuals with knowledge and skills that span multiple layers? How do we accommodate the diverse mixture of experience that full stack developers have traditionally brought to the project? How does management fulfill all these needs? How should recruiters filter prospective recruits? How should job applicants declare their skillset?

It’s time to rethink the term full stack .

I say this with some ambivalence because I helped to popularize the concept. The website full-stack.com was my take on the state of the art in 2009. But sadly, in 2019, it’s a relic suitable for the Computer History Museum.

2020 Stack

Google Trends 2009–2019 for the term fullstack

Oddly, there seems to be an ever-increasing curiosity about the term full stack. A Google Trends snapshot for the period 2009–2019 shows a sharp uptick over the past five years. And it’s reaching new heights each year.

But if all those queries are looking for the next thing, here it is. Of course, we have to give it a name so we can properly discuss it.

I’ll call it the 2020 stack . A new name for a new generation.

Here’s my take on it:

First, let’s honor those individuals who have deep skills in diverse areas. They are our best hope at not falling into the trap of specialization. We want to shun those empire-building tendencies, those gurus with secret incantations, and those silos of information that creep in with specialization.

Second, let’s come to grips with the fact that career development means that people come and go. Organizations must expect this as part of their ordinary operation. Business can’t be interrupted when senior staff move on. “No one is indispensable.”

Third, communication between specialists is weakened by domain jargon. When experts use terminology, acronyms, and idiomatic expressions that are domain-specific, they put themselves and their teammates in peril. “He said/she said.” Cross-domain fertilization is vital in keeping communication channels clear.

So here are some characteristics of the new 2020 stack specialist:

Since no one person can handle it all, the 2020 stack must be covered by a team. Not a group of individuals, but a true team. That means that when one person is falling behind, another will pick up the slack. When one person has superior skills, there’s a mechanism in place for mentoring the others. When there’s a gap in the team’s knowledge-base, they seek out and hire a team member who’s smarter than all of them.

Every 2020 team player must be a cross-domain expert. Any individual with a skillset limited to just one or two layers of the stack isn’t truly a 2020 team player — these types of individuals may aspire to be future 2020 team members, or they may not. But until they acquire deep knowledge across multiple layers of the stack, they’re just 2020 candidates.

The mix of skills that 2020 team members bring to a project isn’t rigidly categorized. Unlike the front end/back end categories that we’ve embraced until now, the 2020 divisions are manifold. One 2020 team may have a member with skills that include NoSQL, cloud configuration, and continuous integration. Meanwhile, another 2020 team may have an analogous team member with skills that include SQL databases, Node.js servers, containers, and orchestration. To refer to either as simply a 2020 back end team player gives them too little credit.

Finally, the vital ingredient: Communication should be carried out with the shared intention of making the best decision for the problem at hand. This means that peers whose skillsets overlap should communicate with an open mind. Rather than just informing peers about new developments, peers should discuss things. This makes everyone smarter, and it prevents specialization from creeping back in. Symbiotic growth.

Hello, “2020 Stack!”

So let’s give it a spin and see how we could use this to better match job requirements with applicant skills. Here’s what a project manager may post, hoping to find a good fit for their company culture:

Rock City Brewing is seeking a “2020 stack” team player with a strong background in testing, documentation, and code management. Applicants should also have cross domain skills in at least two of the following areas: cloud configuration, containers, orchestration, CI/CD, and server-side scripting.
        
Shape our future by helping us choose the best tools for the job. At RCB, career advancement is part of your job. Share your knowledge with the rest of the RCB 2020 stack each week at Tech Tuesday.

A recruiter for the same posting may choose a more specific set of keywords to find candidates:

Our client is looking for a “2020 stack” team player to help with regression testing, API documentation, Github workflow management, and DevOps.
        
If you have any combination of these, we want to hear from you.

And here’s what an applicant may put on their LinkedIn profile (using both the old and new terminology because he’s pragmatic):

Antoní is a “2020 stack” team player with significant experience in classic back end technologies and newer 2020 DevOps layers, including Gitlab, Kubernetes and Digital Ocean.Antoní is a passionate advocate of open source and DRY, and believes the key to successful reuse is in great documentation.

In each of these, we see an explicit bridging of roles between the code management domain and the DevOps domain. And in each, the nod to “2020 stack” suggests a more sophisticated role than the old Agile team player cliché.

Layers, Layers, Layers

So what’s the most sensible way to carve up this new space? Do terms like front end and back end give us the specificity we need? How about the terms server and web, sitting alongside design and ops . Surely, these are broad enough categories. Right?

But wait, we can’t ignore the testing folks, because we know that without their techpertise we’d deliver products inferior to our competitors. And without the marketing side of things, we’d never even have customers.

The case could be made for all of these and more. I’ve already shared my perfect 2020 stack . But how you carve up your layers isn’t as important as how it stacks up. The new 2020 stack is all about cross-domain communication. I think that’s the new Renaissance.


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

界面设计模式

界面设计模式

[美]泰德维尔(Tidwell,J.) / 蒋芳 / 电子工业出版社 / 2013-9-1 / CNY 119.00

模式意味着重用。 好的模式建立在对人与事物的深刻认知之上。 本书开篇即总结了“与人有关”的各类问题,为读者提供了界面设计总体思路上的指引,帮助读者举一反三。 接下来,本书收集并分析了很多常用的界面设计模式,帮助读者理解在实现级别的各种常用解决方案,将它们灵活地运用到自己的设计中。 同时,随着网络和技术的不断发展,本书在第1 版的基础上,更新了几乎所有的模式示例和说明,并新增......一起来看看 《界面设计模式》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

在线进制转换器
在线进制转换器

各进制数互转换器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具