오늘도 좋은 글 읽고 많이 배워갑니다!! 혹시 풀스택 개발자에 대해서 어떻게 생각하시나요?? 프론트도 재밌고 백엔드도 재밌는데 둘다 하려고 하니 T자형 개발자가 되기 힘들고, 또 "풀스택개발자는 상상속 유니콘이다" 라는 말도 있어서 어떻게 생각하시는지 궁금합니다!!
오늘도 좋은 소재를 공유해주신 분들께 너무 너무 감사하다는 인사를 먼저 드립니다.
이번에는 풀스택 개발자에 대해 한번 얘기를 해보려고 합니다. 명확한 실체없이 떠도는 용어인만큼 저마다의 해석이 다릅니다. 그러다 보니 상당히 많이 변질된 용어이기도하고 사람들이 환상을 가지고 있는 용어이기도 합니다.
이번 글에서는 현업의 프론트엔드 개발자의 시각에서 풀스택 개발자가 무엇인지 그리고 풀스택이 어떠한 의미를 가지는 지에 대해 이야기를 드릴까 합니다.
이 글 또한 또하나의 풀스택 개발자에 대한 해석과 설명일테지만 프론트엔드 개발자이기 이전에 스스로를 풀 스택 개발자라고 생각했었기에 이 글이 풀스택 개발자에 대한 이해를 도울 수 있기를 바랍니다.
우선 풀스택 개발자에 대한 사전적인 의미를 생각해봅니다. 그러기 위해서는 구글에 'full-stack developer'를 한번 검색해보았습니다.
클라이언트 및 서버 사이드 코드를 학습하고 웹 사이트가 작동하도록 해주는 모든 기술군에 대해 이해하고 있는 개발자입니다.
풀스택 개발자란 GUI 프론트엔드부터 데이터베이스 백엔드에 이르는 모든 소프트웨어 스택을 이해하는 개발자를 말한다.
풀스택 개발자는 데이터베이스, 서버, 시스템 엔지니어링 및 클라이언트의 모든 작업을 처리할 수 있는 엔지니어입니다.
풀스택 개발자, 폴리글랏 개발자 모두 하나의 범주를 넘어 다양한 환경 및 플랫폼을 이해하고 사용되는 대부분의 언어와 지식을 갖춘 인재를 얘기합니다.
...
점점 거대해져 가는 풀스택 개발자의 의미... 🤯
지금의 풀스택 개발자가 정의가 정확하게는 뭔지는 모르겠지만 이 말은 도체대 어디서 부터 생겨난 말일까요?
출처: https://trends.google.co.kr/trends/explore?date=all&q=%2Fg%2F11cn3vn3w2
🔥 2014년도를 기점으로 해서 풀스택 개발자의 용어가 크게 관심도가 증가한다는 것을 알 수 있습니다. 왜 저 시기부터 일까요? (눈치 채신 분들도 있겠죠?)
사실 웹에 오랫동안 종사한 사람들은 풀스택의 의미에 대해서 정확하게 알고 있습니다.
당신은 풀스택 개발자입니까? 라는 말은 사실 다음과 같습니다.
"혼자서 ... 웹 사이트(서비스) 만들 줄 아세요? 😎"
웹은 문서를 가상의 공간에서 공유하기 위해서 태어났습니다. 오프라인에 있던 문서를 가상의 공간으로 링크로 연결이 되는 공간을 만들어냈습니다.
이후 사용자의 정보를 전달하고 그 내용에 따라 다른 형태의 페이지를 동적으로 만들어내는 방법이 개발이 됩니다. 예컨데 방문자수에 따라 다르게 표기가되는 카운터같은 것처럼 말이죠.
그 과정이 발전을 하게 되면서 사용자로부터 스스로 문서를 만들어내고 보관할 수 있게 됩니다. 방명록이라고 하는 것들이 추후 게시판, 포럼과 같은 형식으로 발전을 하게 되죠.
문서를 보여주기 위해서 태어난 웹에서 문서를 생성하고 보관하고 관리하는 도구로 발전을 하게 됩니다.
이런 서비스들을 만들어내는 사람을 우리는 웹 개발자라고 불렀습니다.
웹은 문서였기에 이러한 서비스가 발전하기 이전에 잘 읽히게 하기 위해서 잘 꾸며져 있을 필요가 있었습니다. 문서이기도 했고 장식이기도 했고 카달로그의 역할도 복합적인 의미를 가지고 있었죠.
이러한 문서를 돋보이게 만들 수 있는 하는 사람들을 우리는 웹 디자이너라고 불렀습니다. 웹문서가 홈페이지로 업데이트가 되면서 회사의 정보를 표현하거나 개인을 표현하는 수단으로 발전을 했죠.
하지만 게시판이나 포럼등 기능들과 디자인이 결합할 필요가 생기면서 둘다 어느정도 할 수 있는 역할이 필요했습니다. 때로은 웹 개발자가 웹 디자인을 적용해야 했고 웹 디자이너가 웹 개발을 하기도 했죠.
이제는 웹 사이트를 하나 만들기 위해서는 화면을 다루는 웹 디자인 영역과 데이터를 다루는 웹 개발 영역을 둘 다 할 줄 알아야 했습니다.
하지만 이때는 웹 사이트가 어느 정도 정형화가 되어 있었기에 웹 디자이너는 솔루션을 이용해서 디자인만 적용 하거나 웹 개발자는 디자인 테마를 사서 적용 후 배포 하는 식으로도 가능했었기에 충분히 혼자서도 웹 사이트를 만드는 것은 어렵지 않았던 시기입니다.
디자인도 할 수있고 웹 개발도 할 수 있었던 사람을 당시에는 웹 마스터라고 부르던 시절이 있었습니다.
출처: https://github.com/ManzDev/frontend-evolution
하지만 2010년을 기점으로 구글을 앞세운 웹 서비스는 전혀 다른 방향으로 흘러갑니다. 웹은 이제 문서라는 개념을 완전히 탈피를 하고 하나의 어플리케이션과 같은 역할을 수행할 수 있게 됩니다.
그리고 페이스북의 2013년 React의 등장으로 웹 개발은 기존과는 다른 새로운 국면으로 흘러가게 됩니다.
자세한 이야기가 궁금하다면 이 글도 한번 읽어보세요 :)
프론트엔드 역사와 미래, 업무 분야 ... 그리고 잘하는 프론트엔드 개발자란?
https://velog.io/@teo/frontend
이렇게 웹 서비스의 개념이 커지고 프론트엔드라는 생태계와 분야가 만들어지면서 기존의 많은 웹 개발자에게 프론트엔드라는 역할을 같이하기를 원하게 됩니다. 그리고 기존의 웹 개발은 프론트엔드에 대치되는 백엔드라고 불리게 됩니다.
이때부터 기존의 웹 개발자이면서 새로운 생태계인 프론트엔드를 같이 할 수 있는 개발자를 찾기 시작합니다! 이른바 백엔드와 프론트엔드를 모두 할 줄 아는 '풀스택 개발자'를 말이죠.
지금이야 풀스택 개발자에게 자기멋대로 의미부여가 확장이 되고 있지만 풀스택 개발자의 시초는 이 변화된 웹 생태계를 다 이해하고 있는 사람을 말하는 거였습니다.
무릇 웹 개발자는 프론트엔드, 백엔드 가리지 않고 할 줄 알아야 되는거 아닐까요?
다른 분야에 비해 왜 유독 웹에서 풀 스택을 많이 찾을까요? 그것은 웹 서비스의 특성 때문입니다. 웹은 다른 UI 어플리케이션 분야와 달리 클라이언트만으로 무엇을 하기에는 부족합니다. 일단 웹을 사용하기 위해서는 브라우저는 필수적인 요소입니다. 브라우저를 통해서만 웹의 결과물들을 볼 수가 있죠.
그렇기에 브라우저를 잘 다룰줄 안다는 것은 웹 개발에서 아주 중요한 역할을 하고 있습니다. 이 브라우저를 중심으로 개발을 하는 분야가 바로 프론트엔드이죠. 백엔드 개발자들이 웹 밖에서 데이터를 다루더라도 결국 웹 서비스가 제공이 되는 것은 브라우저 안이기 때문에 브라우저를 다루는 프론트엔드를 하지 않을 수가 업습니다.
프론트엔드만 있어서 브라우저만 잘 다룬다면 어떨까요? 브라우저는 여러가지 보안정책으로 인해서 컴퓨터의 OS리소스를 거의 사용할 수가 없습니다. 그러니 중간과정을 아무리 잘 만들어도 최종적으로 데이터를 보관을 할 수 없는 어플리케이션은 데모수준밖에 되지 않습니다.
그러기에 브라우저에서 없는 기능은 반드시 백엔드의 도움을 받아야만 서비스를 완성할 수 있습니다. 그렇기 때문에 가치있는 서비스를 만들기 위해서는 반드시 백엔드를 통한 데이터 조작이 필요합니다.
웹은 초창기 시절부터 브라우저와 DB를 둘 다 다루는 것들이 당연했으니 전통적인 시각에서 웹 개발자는 원래 풀스택이었고 무릇 웹 개발자라면 둘다 할 줄 알아야 한다고 했습니다. 초창기 페이스북의 모든 개발자들은 스스로들을 풀스택 개발자라고 말했지요.
하지만 과연 지금도 그럴 수 있을까요?
출처: https://www.meme-arsenal.com/en/create/meme/3395950
"풀스택이 왜 유니콘인줄 아니?"
- "엄청 멋있기 때문이지 않을까요? +_+"
"...그런것은 이 세상에 존재하지 않기 때문이야."
웹 개발은 이제 더이상 1인 개발자의 세상이 아닙니다. 거대 웹 서비스들이 등장했고 세계 10권내의 서비스들이 존재합니다. 웹은 지난 10년동안 폭발적으로 성장을 하였습니다.
한 명이 분명 여러분야에 뛰어날 수 있습니다. 하지만 거대한 기업 세계에서는 1명의 개발자가 투자할 수 있는 시간은 동일합니다. 둘 분야 모두 뛰어난 인재라면 연봉이 높을텐데 2명의 풀 스택 개발자를 뽑아서 각각의 분야에서 0.5의 역할을 할거라면 그냥 프론트엔드, 백엔드 전문가 1명씩 뽑아서 일을 하는 면이 회사 입장에서 효율적이기 때문입니다.
이것은 서비스의 덩치가 커질수록 심화됩니다. 여러사람이 함께 일을 하게 되면 결국 특정 분야에 대해서는 누군가 보다 더 나은 전문가의 영역이 존재하게 됩니다. 할 줄 안다는 것과 그 분야의 전문가라는 것은 엄연히 다른 말입니다.
그러니 여러명의 유니콘으로 이루어진 팀을 만들려고 하는 것보다 좋은 협업능력을 가진 전문가집단이 훨씬 더 훌륭할 수 있습니다.
하지만 여전히 높은 연봉을 주고서라도 풀 스택 개발자를 원하는 기업들이 존재합니다. 왜 그럴까요?
현대의 풀 스택 개발자는 최소한의 실행 가능한 제품, 즉 초기 고객을 만족시키고 지속적인 개발을 위한 피드백을 촉발할 수 있는 충분한 기능을 갖춘 애플리케이션을 스스로 구축할 수 있는 경험 많은 제너럴리스트입니다.
여전히 몇몇 기업들은 고액의 연봉을 주고서라도 풀 스택 개발자를 희망하는 경우가 있습니다. 그들은 이 사람들이 프론트엔드와 백엔드의 두 분야 모두의 깊이있는 전문가는 아님을 알고 있습니다. 하지만 혼자서 초기 서비스를 만들어내고 협업을 해야하는 파이프라인을 이해하고 있는 전문가 입니다.
아직 서비스를 만들기도 전이라면 빠르게 아이디어를 검증해 볼 수 있는 전문가가 필요합니다. 이들에게 깊은 전문성을 요구하는게 아닙니다. 협업에는 커뮤니케이션 비용이 발생합니다. 아이디어를 빠르게 검증해서 성공할 수 있는 방법을 찾기 위해 프로토타이핑을 빨리 해내는 것은 아주 중요한 스킬입니다.
또한 스타트업에서는 초기 팀 빌딩이나 협업에 대한 경험이 부족합니다. 풀스택 개발자들은 여러 기술 전반에 걸친 폭넓은 경험적인 요소를 높이 평가받습니다. 풀스택 개발자는 백엔드, 프론트 엔드 및 디자인 팀과 협업할 수 있는 CTO와 같은 가장 좋은 위치를 차지합니다.
뿐만 아니라 IT기업이 아닌 곳에서는 풀스택 개발자가 더 유리할지도 모릅니다. 빅 테크기업과 같은 수준의 깊이를 요구하지 않더라도 기존의 아이디어를 적당히 서비스를 제공하는 것과 연결만 시킬 수 있더라도 더 부가가치를 만들어 낼 수 있습니다.
이들에게 필요한 능력은 기술적인 깊이가 아니라 최소한의 애플리케이션을 만들어 내는 능력과 해당 비지니스 도메인에 대한 넓은 통찰력입니다.
"풀.스.택. 개발자시니까... 이것도 할 줄 아시죠? 이것도?"
풀스택 개발자라는 용어가 주는 환상과 정해지지 않고 주관적인 해석으로 인해 이 글 초기에 봤듯이 이미 풀스택의 의미는 부풀려졌습니다. 그리고 이것을 악용하는 케이스도 늘어났습니다. 풀스택 개발자라는 직군이라는 핑계로 과도한 개발능력을 요구합니다.
또한 풀스택의 기준이 주관적인 해석이 달려 있기 때문에 시각차도 존재합니다. 분명 풀스택이라고 해서 뽑았는데 분명 서비스를 만들어 낼 수는 있지만 할 줄 아는 분야가 너무 한정적일 수도 있습니다.
또는 인력이 없는 회사에서는 풀스택을 하면 좋지 않냐는 명목으로 한 개발자에게 여러가지 일을 시키기도 합니다. 그리고 여러가지 경험이 많고 이력이 많은 풀스택을 선호한다면서도 정작 풀스택 개발자에 대해서는 깊이가 없기 때문에 취업에서 불리해지는 경우도 생깁니다.
출처: https://twitter.com/ddialar/status/1396365919589441540
"만능형이라는 말의 다른 이면은 어중간함입니다."
해본게 많지만 경험치가 낮은 풀스택 개발자들을 다른 실무에서 일을 하게 하려면 실제로 깊이가 모자란 경우가 많이 있습니다. 분명 한 것은 많은 것을 알겠는데 어느 하나 제대로 아는게 없는 경우가 생기게 됩니다.
앞서 말한 서비스의 규모가 이미 커져있고 전문가집단이 형성이 된 곳에 가면 이 현상은 더 두드러집니다. 이미 기준은 각 분야에서 잘하는 사람이 기준이니까요.
경험치가 충분하지 못하다면 스스로를 풀스택이라고 칭하는 사람들은 신뢰하기가 어렵습니다. 대부분의 주니어 취업 상담의 얘기에서 공통적으로 하는 얘기가 있습니다. 이것도 해봤고 저것도 해봤고 해봤다고 전부 다 기록을 하게 되면 오히려 신뢰도를 잃게 된다고 말이죠.
분명 예전에는 웹 개발자는 풀스택 개발자를 지향을 했어야 했는데 이 산업이 커지다보니 풀스택을 담기에는 너무 커져버린게 아닌가 싶습니다.
마치 옛날에 레오나르도 다빈치가 화가이자 조각가, 발명가, 건축가, 해부학자, 지리학자, 음악가였던 것 처럼요. 그때는 각 분야가 해놓은게 적었으니 한 사람이 수많은 역할을 수행할 수 있었지만 지금은 하나의 분야만 파고 들기에도 너무 알아야 할 것이 많아져버린 것이지요.
"저... 그게 아니라 레오나르도 다빈치는 진짜 천재 아닌가요? 2007년 네이처에서 선정한 인류역사를 바꾼 10인의 천재중 가장 창의성이 높은 사람인데요?"
그렇습니다. 세상은 공평하지 않고 잘하는 사람은 사실 다 잘합니다.
풀스택이 유니콘이라고는 하지만 그것은 풀스택의 기준을 한없이 올려치기를 했기 때문이 아닐까요? 주변에 혼자서 웹 서비스를 만들어내고 DB를 다루고 화면을 다루고 디자인을 하면서 프론트와 백엔드의 지식을 넘나드는 사람들은 분명히 존재합니다.
기술의 깊이가 전문가급은 아니더라도 비지니스에 대한 이해도가 높아서 스타트업을 성공시키기도 하고 프론트엔드에 전문가이면서도 필요한 백엔드 기술을 뚝딱뚝딱 잘 가져와서 스타트업에서 원하는 프로토타입을 만드는 경우도 있습니다. 백엔드의 전문가이지만 필요하면 UI를 가져와서 CMS나 백오피스를 만들어내는 개발자 역시 존재합니다.
회사에서는 분명 두 분야의 전문가가 아니라 하나의 직군과 전공을 택하고 한 분야의 전문가로 있지만 결국 개발의 본질은 같으니까요.
"혼자서 웹서비스 만들 수 있습니다! 😎"
React를 이용해서 AWS를 통해 인프라 배포나 Auto Scale등의 구성은 하지 않고 express와 DB만 이용해서 서비스를 만들었다면 풀스택이라고 할 수 있을까?
React를 이용해서 React Native를 이용해서 앱 개발을 하면 앱 개발자라고 부를 수 있나? 이는 또하나의 풀스택일까?
워드프레스로 테마를 수정해서 웹사이트를 만들었다면 풀스택이라고 할 수 있을까?
혼자서 리눅스 서버를 이용해서 APM으로 게시판을 이용한 커뮤니티를 만들었다면 풀스택 개발자일까?
Github의 pages를 이용해서 블로그를 만들었다면 풀스택이라고 할 수 있을까?
DB없이 구글시트를 연동해서 설문결과를 저장하는 서비스를 만들었다면 풀스택이라고 할 수 있을까?
혼자서 웹 서비스를 만드는 방법은 너무나 다양합니다. 그리고 백엔드와 프론트엔드의 경계는 갈수록 희미해져가고 있습니다. 그러면서도 동시에 각 분야의 깊이는 점점 더 깊어지고 있습니다.
그런데 반대로 웹 서비스를 만드는 방법은 점점 더 쉬워지고 있습니다. 우리가 백엔드의 전문가가 아니더라도 클라우드 서비스를 이용해서 대용량 트래픽을 감당할 수 있는 서버를 쉽게 생성할 수 있습니다. javascript를 깊이 있게 몰라도 프레임워크를 통해서 복잡한 페이지도 쉽게 만들어 낼 수 있게 되었습니다. 디자인을 못해도 이미 잘 만들어진 UI Framework들이 존재합니다.
프론트엔드와 백엔드만이 아닙니다. 우리는 음성인식 기능과 같은 AI 기술도 얼마든지 사용할 수가 있습니다. 우리는 AI 전문가가 아니더라도 AI 서비스를 이용해서 서비스를 만들어내는 것은 어렵지 않은 일이 되었습니다.
하나의 전문성을 갖추는 것도 중요하지만 새로운 가치는 융합과 연결에서 나옵니다. 프론트엔드와 백엔드가 하나라도 없으면 웹 서비스라고 할 수 없듯이 말입니다.
풀스택이 🦄유니콘이니 자칭 풀스택은 깊이가 없어서 꺼린다고는 하지만 어디까지나 그것은 회사나 특정 개인의 입장일뿐, 내가 어느 분야의 전문가가 되기 전까지는 웹 개발자라면 풀스택 개발자의 시각을 유지하는 것은 충분히 필요한 일입니다.
웹 분야의 경우 산업이 발전하면서 경계가 희미해지고 프론트엔드와 백엔드의 스펙트럼이 계속 바뀌어 가고 있습니다. 특히 클라우드 서비스가 보편화가 되면서 인프라나 스케일링 서버 운영에 대해서는 전혀 몰라도 React를 하면서 AWS를 이용해 Node로 express와 DB를 적당히 다루는 것 과 같은 프론트엔드 백엔드 기술을 같이 쓰는 것은 어렵지 않은 일이 되었습니다.
브라우저에서 다루지 못하는 데이터만 최소한으로 다루는 것 정도는 이제 프론트엔드에서 하는 것으로 해서 인프라와 DB, 스켈일링을 클라우드화 해서 인프라 시스템만 백엔드가 하고 DB 스키마나 CRUD는 이제 프론트엔드에서 해야한다는 입장도 존재합니다. Cloud Function와 Serverless는 현재 진행형인 상태입니다.
웹 개발자라면 내가 한 분야의 전문가가 되거나 취향이 확고해 지기 전까지는 결국 다 해야 합니다. 어중간하게 둘 다 하는 것이 아니라 내 전문성을 살리되 적어도 관심사의 스펙트럼은 넓게 유지를 해야 합니다. 일반적으로는 어느 한 분야의 전문가되는 식으로 커리어는 흘러가겠지만 결국 웹이라는 생태계 안에서 연결과 협업을 해야하는 일은 계속 해야하니까요.
프론트엔드건 백엔드건 우리는 웹 개발자잖아요.
당신은 어떤 풀스택 개발자인가요?
출처: https://www.pinterest.co.kr/pin/373728469062359052/
풀스택의 Full이 주는 어감 때문일까요? 언제부턴가 풀스택이라는 단어에 너무나 많은 의미를 투영하려고 하는 것 같습니다. 풀스택 개발자가 유니콘이 되어버린것은 개발자의 문제는 아닐지도 모르겠습니다.
하지만 사회는 점점 더 T자형 인재를 원하고 있습니다. 하나의 전문성을 가지고 있으면서 또 넓게는 다양한 분야에 대한 지식을 아우르는 그러한 의미로 T라는 모양을 사용하고 있습니다.
우리는 어느 한분야의 전문가가 되어야겠지만 결국 웹 개발자라는 나아가 개발자라는 생태계안에서 계속 살아갈 것이고 누군가와 함께 일을 하게 될 것입니다.
'풀스택이 고연봉을 주며 당연히 개발자가 지향해야 하는 곳이다.' '풀스택은 전문성이 없기 때문에 지향하면 안된다.' '풀스택이라는 것 자체가 잘못된것이다.' 풀스택에 대한 얘기들은 많지만 대부분의 글들에는 풀스택에 대한 기준이 명확하지 않습니다. 제 역시 풀스택에 대해서 경계를 그을만한 명확한 정의를 내리기는 쉽지 않을것 같아요.
한가지 분명한 사실은 풀스택의 정의는 계속 변하고 있다는 사실입니다. 뿐만 아니라 웹도 변하고있고 개발 생태계도 계속 변하고 있습니다. 그렇기에 이 변화를 끊임없이 주시를 하면서 이 넓은 생태계가 어떻게 변하고 있는지 어떻게 이용하고 연결하고 협업할 수 있을지는 계속 확인하시기 바랍니다.
🔥 그리고 웹 개발자라면 아주 쉽고 간단한 방법이라도 본인만의 서비스를 완성 할 수 있는 방법을 공부해봅시다. 풀스택 개발자의 타이틀을 따기 위함이 아닙니다. 조그맣게 여러 서비스들을 연결하여 한 사이클을 완성을 할 수 있다는 것은 개발자의 시각을 굉장히 넓혀줍니다. 그리고 혹시 아나요? 작은 아이디어를 구현한 그 서비스가 대박을 칠런지도? 😘
끝으로 마지막에 보여드린 만화는 프로그래머 유머에 올라와있지만 풀스택을 지향한다는 것은 사실은 누구보다 열심히 개발하고 있는 인재들이 아닐까하는 생각을 해봅니다. 내가 고액연봉을 받는 유니콘 풀스택 개발자가 못되더라도 우리는 다같은 개발자이기에 하나라도 더 많이 아는 것은 좋다고 생각합니다. 개발의 본질은 사실 크게 차이나지 않으니까요.
본인만의 기준에 맞는 전문성과 넓은 시각을 가진 풀스택 개발자가 되어보길 바라며,
이 글이 풀스택 개발자에 대한 이해에 도움이 되기를 바랍니다.
감사합니다. ❤️
많은 고민을 하게되는 글이군요, 감사합니다.
개인적으로는 프로그램들을 컴퓨터를 통해 아이디어를 사용자들에게 구현해서 제공하는 도구 정도로 생각하다보니, web server, web browser에 노출되는 코드들(html, css포함)와 같은 것들을 다루는 것에 경계가 없어졌습니다.
이로인해 이것저것 다룰 수 있게되어 full stack이라고 할 수 있지 않을까? 생각했었는데 단어 자체의 개념이 모호하고 이에따른 개인마다의 기준이 다르기때문에 full stack이라는 개인적으로 되고싶던 용어를 쓰기 꺼려지는거 같습니다.
커뮤니티를 돌아다니다 보면 full stack이라는 용어를 쓰는 자체로 부정적인 선입견을 가지시는 분들이 있기도 한거같더라고요.
대기업들과 정부도 클라우드 환경으로 이식하는 것을 볼때, 클라우드 서비스의 엔지니지어 외에 툴 사용법과 대처능력을 학습하는 수준이 되고 있는 듯합니다. 5년 정도 지나면 확연히 차이가 나지 않을까 생각해봅니다만.. 다만 "군"에 대한 폐쇄성은 남아있을테니까 그 분야는 남아있지 않을까요?
원래는 프론트엔드 웹 개발자 였지만, 요즘은 R&D 쪽을 하며 프론트만 하고있진않아요
문제해결을 위해 스택은 중요하지 않고 그냥 필요하면 사용하는 것이죠.
점점 앞의 수식어는 의미가 없고 '개발자' 가 되었다고 생각하고,
결국 그것이 '엔지니어' 가 되가는 길이라 생각합니다. 그런것을 누군간 '풀스택 개발자'라고 부를 순 있겠죠.
누군가는 전문성이 떨어진다 생각할 수 있지만 문제 해결만큼은 잘하는 '엔지니어'가 되고싶네요.
react / node / mysql / aws로 개발하는 2년차 개발자입니다.
2년정도 해보니 느낀건 프론트던 백앤드던 어느하나는 주력으로 정해야됨을 느낍니다.
동일하게 한쪽을 2년 팠다면 좀 더 전문성이 있을 거 같다는 생각이 들더라구요.
프론트 / 백엔드 모두 개발 환경 스택들이 너무도 빠르게 변하기 때문에 결국에는 한분야라도 정점을 찍는게(찍을 수 있을지 모르겠지만..) 좋다고 생각해요..
다만 전반적인 웹에 대한 이해를 하려면 이것 저것 해보는게 역시 최고 같아요 :)
Ordain IT Provides Various design services. Like UI/UX design, graphics design
https://ordainit.com/
뭔가 요즘은 하나만 파기도 어려운 시대인거같아요..ㅠㅠ 풀스택이 가능한가 그런사람이 있는건가실제로 존재하나..이런느낌도들고..ㅠㅠㅠ 정말 되고싶지만....
상황에 따라 다른 뜻이겠습니다만 개발 갓 배우고 풀스택 할 줄 안다며 끄적였던 게 쑥스럽네요. 좋은 글들이 많아 스승님으로 생각하고 하나씩 잘 읽어보겠습니다. 감사합니다!
훌륭한 글입니다. 저는 30년 가까이 개발만 하고 지금도 개발만 하고 있는 독고다이 노개발자
입니다. 지금도 크지는 않지만 못지않은 수익을 남기며 다행히 잘 살고 있으며 초창기 대기업 나온것을 절대 후회하지 않고 있습니다.
님의 글에 이견은 전혀 없으며 모두 동감하며 글에 빈틈이 없습니다. 경험에서 나온 풀스텍관련
주관적 첨언입니다.
저는 2년전 부터 golang으로 SIP로 기간통신사와 PSTN연동기능 개발중인데요.
지금은 상용까지 완료하여 서비스 적용후 일부 수익까지 나고 있습니다.
이러면 back end라고 할수 있죠.
그런데 1.5년 전부 webrtc로 SIP와 연결하는 작업(개발)을 하고 있습니다.
webrtc라면 브라우져 의존적이죠.
몇개월 전부 webrtc 자원접근 문제로 reac native와 flutter(dart까지 진행) 보다가 계속 빠져들고
있습니다. 그 성과로 이제는 webrtc와 SIP를 pcmu(u-law voice)방식이긴 하지만 연결하여
통화가 잘되고 있습니다.
이러면 front end 기술을 확보한 것일까요?. 30년 전에 대기업 나올때 풀스택엔지니어가 돼겠다고 하였으며 여러가지 프로그램을 다양한 언어로 개발/유지보수를 했는데요. 이제 돌이커 볼때 풀스텍이 완성되었는지 저도 의문입니다.
결론을 말하면 T자형 엔지니어가 맞다고 보며 최선을 다해서 개발자로서의 삶을 사는 것이 가장 중요한 것 같습니다.
사람은 개발 열심히 하다보면 본인이잘하는 언어(DB등)를 알수 있께 되며 언어나 기술(DB등)은 전부 비슷해서 어느정도 다른 쪽도 잘하게 되는 것이 이쪽인 것 같습니다.
제가 돈벌어서 판매한 소스 결과물의 프로그램 언어는 많으나 제대로 한것은 java와 golang,C언어 정도이고 다른언어(frontend:델파이,파워빌더,php)는 하부개발자 외주 받은 것 유지보수가 필요하여 수정할때 사용한 수준입니다.(외주개발자가 주로 안된다고 한 부분 빵꾸때움) 노개발자 입장 오랜동안 해본결과 이렇게 하는 것이 개발자로서의 길로는 제일 좋은 방향 같습니다.
새로 시작하는 개발자 분들 진로/방향에 조금이나마 도움되려 글을 길게 답변 달았습니다.
원글 쓰신분께 감사드립니다. 오랜만에 잘 정리된 글, 그리고 동감내용 잘 봤습니다.
결국 웹에서 생산성이 높아져서 혼자서도 웹개발을 다 할수 있는 시대기는 하지요.
다만 풀스텍 개발자의 한계는 비교우위 이론이 잘 보여줍니다.
내가 설령 다른 팀원보다 백엔드랑 프론트엔드를 둘 다 더 잘한다고 해도, 내가 다하는 것보다 팀원과 협업하는게 생산성이 더 좋으니까요.
스타트업에서 웹풀스텍을 원하는 이유는 간단한데, 놀게 놔둘 일이 없거든요. 아직 제품도 결정되지 않은 상황이러면 더더욱 그렇죠. 피벗하면 인원조정도 필수니까요. 전 취직에 대한 생각이 별로 없었어서, 풀스텍을 쭉 하고있긴한데, 솔직히 창업 자체에 관심이 있거나 프리랜서를 하고 싶은 경우가 아니라면 풀스텍은 좋은 진로는 아니라고 생각합니다.
제가 예전에 사수분께 여쭤봤습니다. 풀스텍이면 백엔드, 프론트엔드 다 하는데 왜 돈을 더 받지 않나요?
"풀스텍 개발자를 고용하는 곳은 백엔드, 프론트엔드 다 시키겟다는 건데, 그런 회사는 돈이 없는 회사다"
풀스택개발자 어딘가엔 있겠지요 ㅠ 좀 오래 몇년전에는 저도 제 나름대론 마음속으로 "후훗 나정도면 풀스택개발자지" 라고 생각하던 시절이 있었는데...
그때는 적어주신대로 그냥 html좀 하고 jquery좀 하고 sql좀 하고 스프링좀 하면 어디가서 명함좀 내밀 수준이었는데 지금은 정말 많이 달라졌네요! 계속 공부하고 새로운 기술을 습득하는게 최고인것 같아요
좋은글 잘 읽었습니다!