Re: [請益] web前後端的選擇

作者: kloer (測試..)   2019-12-17 11:06:49
我覺得你對 C10K 可能有誤解
以你文中的例子來說:
"據上個月vpon座談 如果我沒記錯 最複雜的子系統 qps約6000~7000左右吧?"
這並不代表他們的系統沒有達到 C10K 標準
C10K 的背後意義是什麼 ?
我的理解是硬體跟架構要恰當, 在合理的硬體條件下, Concurrent 數量要合理
並且隨著 clients 數量提升越來越高, 系統的資源花費不會離 Linear 差太遠
這跟後端背後的應用相當有關係, 我認真覺得後端一定要學好 C / C++
以及 Linux Kernel 背後一些重要參數的意義
後端要碰的坑可多了, 例如一個不太懂 Linux 的人, 即使寫出可以跑的程式
他可能也會在 scale 越來越大的時候碰到 ulimit 內的限制問題而不自知
然後就出包了, 還是在半夜出包, 等著收一堆客戶抱怨信
資深的因為踩過一堆坑, 就能在系統開發初期就預料到可能會碰上哪些問題
這些都是經驗累積而來的, 後端要做到很好難度確實比前端高不少, 要踩的坑太多
還沒踩到只是你還沒碰到而已 (也很可能跟際遇有關, 沒有合適的環境跟應用去踩坑)
就算想做前端, 最好也是要稍微摸一下後端, 不然後端對你來說只是黑盒子
身為一位 RD, 應該勇於解開所有黑盒子, 了解透徹, 減少自己未知的領域
※ 引述《stillboy (joey)》之銘言:
: 我自己full stack 對兩端都有粗淺的了解
: 但
: 看到這麼多前端的hater就覺得無奈QQ
: 你不懂前端 你要說啊! bro
: 客觀來說好了 台灣的後端??
: 除了幾家走出國際的大數據公司 or 本來就是國際大公司
: 有多少公司的後端達到C10K的等級? (新手不知道的 請自行Google)
: 據上個月vpon座談 如果我沒記錯 最複雜的子系統 qps約6000~7000左右吧?
: 如果連C10K都沒有的話 這種規模和複雜度就不要拿出來嘴惹
: 如果是大陸的一二線軟體公司的後端 C100K C1000K都有
: 這種後端 我舉雙腳和雙手贊成 如果是台灣的
: 台灣 除了少數的公司 其他去了 就算年資10年 最後還是領低薪
: 解決問題的scale就在那裡 ..你解決問題的等級多高 薪水就多高
: 領底薪也是合情合理
: 然後
: 順便釐清一下
: 真正的前端 跟 美術
: 一 點 關 係 都 沒 有
: 說有關係的 大概還停留在dreamweaver 和 fontpage的時代吧
: 或 所待個公司和產業 太過老舊.
: 在現代
: 美術和體驗的職位 叫做『UI/UX』 看公司大小 有些公司例如Google
: 會再細分 叫做 UX researcher 這種相關職等的人 會跟工程的人有許多討論。
: 前端在近10年來因為硬體日新月異 導致client端能做的事情變爆幹多
: 原本的架構是後端處理所有的事情 client端收到資料 顯示出來
: but 現在可能一個頁面有幾百個api的需求 加上行動裝置的出現
: 導致原本back-end request數量變超級大
: 比較爛的解法當然就是直接買更多機器 但成本會變很高
: 所以 有人想 既然前端硬體效能變好 那為啥不好好利用前端?
: 所以前後端分離出現了 也就是所謂的SPA 之後為了改善SEO and initial loading slow
: 的問題 又走到了 進階版的server-side rendering 但是 based on SPA.
: 走到這個SPA level之後 前端有自己的server 後端也有自己的server
: 因為這樣的配置 導致後端的工作量大為減少 而把這些工作量丟給client端
: 從而後端可以handle更多的工作量
: 所以為啥會看到 有些前端職位的需求要會redis node.js nginx
: but 這只適用於不需要太複雜的情況 複雜一點的情況的client server
: 還是需要考群以及分散式的需求 這樣的話 可能還是會由後端來處理。
: 而此時的前端基本上就變成應用程式軟體一樣
: 需要什麼資料跟後端要 要回來自己處理
: 同時也要效能 安全性 兼容性 design pattern 也是不容忽視的一環
: 所以說 為啥前端有些你看徵才文 薪水不比後端差
: 就是因為前端 早就不是以前的前端了
: 最後總結一下
: 走到極端的後端 VS 極端的前端
: 論複雜度 毫無疑問 後端屌打前端
: 但前提是 產品的scale要很大 (例如server的數量及至少至少要 > 50)
: 且 有很多real-time和巨量的數據的issues需要處理
: 這種架構以上都是分散式或微服務 跨區以上的等級
: 需要處理很多race condition/一致性/...等 複雜的問題
: 而一堆公司的後端常常會包含DBA 那就更複雜
: 如何取捨該功能是使用sql or nosql 並且對sql or nodql底層原理有通盤的了解
: 但台灣走到這種scale的軟體公司 屈指可數
: 所以如果要在台灣工作的話 選自己爽的比較重要
: 什麼叫做自己爽? 有些人天生喜歡面對client 喜歡面對畫面
: 有些人喜歡always面對程式碼 有些人喜歡自己寫一些web or app應用來玩
: 只要你在任何一端強的話 薪水早就不會是什麼大問題了
: 當然普遍來說 後端天花板會比較高
: 最後 不建議新手 走什麼full-stack拉
: full-stack 要顧 前後端 devops 然後五年後 全部都半桶水(半桶水其實是很高估)
: 很多事情欲速則不達 full-stack代表你要做的事情就是爆幹多
: 根本沒時間反芻 根本沒時間好好理解原理 基礎根基根本就不穩
: 比較好的path是你先走任何一端5~7年以上 再走任外一端5~7年以上
: 先把一端的基礎好好打好 念熟 到講一堆觀念 就像吃飯喝水一樣的解釋給旁人聽
: 當然一個最重要的前提是 你們公司做的產品是很有挑戰性的
: 所謂有挑戰性就是 後端至少朝C10K 甚至C100K走
: 前端 朝做tool走 而不是一直在那邊單純無腦刻畫面
: 而不是 product的 level一直在 0~1 1~10打轉
: 在這種有挑戰的公司各呆至少五年 我想 應該可以自稱 junior full-stack惹
: 看到一堆人 寫沒幾年 react+node.js+mongoDB就自稱full-stack
: 問他為什麼是node.js 為什麼mongoDB 也說不出個所以然
: 也是沒錯 大概是產品scale < 100 簡單應用的 full-stack . 也沒啥問題!
: 好拉 講太多惹 大概是這樣
作者: v420746k (Tyrone_Huang)   2019-12-17 12:43:00
推減少自己未知的領域
作者: stillboy (joey)   2019-12-17 14:49:00
我沒說vpon沒有具備C10K的架構規模吧. C10K對我而言 就像一個後端工程師的里程碑而已,至於坑 任何領域都有吧個人淺見 參考吧
作者: Hsins (翔)   2019-12-17 17:16:00
一知半解是開發者本身的問題吧?以前端這幾年的發展來說,朝著工程化的方向前進,因為 UI 所以更重視函數式編程範式,這兩個後面的概念並不太會隨著時間過時,會過時的是那些純粹調 API 使用的。不是啊…你拿三個框架來跟程式語言和作業系統比欸…
作者: superpai (超級白)   2019-12-17 19:10:00
標題是web前後端,你用C寫web嗎?
作者: gg90052   2019-12-17 22:59:00
要跟C比的話,20年前我學JS,現在要2020了我還是在用JS
作者: b85040312 (萬年newman)   2019-12-18 08:27:00
推樓上
作者: anandydy529 (AndyAWD)   2019-12-18 12:34:00
Java可以從Symbian寫到Android
作者: chatnoir (對不起)   2019-12-18 14:40:00
10年後JS還是會佔有一席之地der
作者: as30385438 (LCT)   2019-12-18 18:57:00
20年前的JS跟今天的用法差太多了 能這樣類比嗎...
作者: gg90052   2019-12-18 19:31:00
所以20年前的C跟今天的C用法一樣嗎?
作者: x000032001 (版廢了該走了)   2019-12-18 20:59:00
cpp表示 你們在吵甚麼
作者: b85040312 (萬年newman)   2019-12-18 21:57:00
組語表示:
作者: arthur104 (arthur)   2019-12-19 00:46:00
拿語言比框架是什麼鬼?
作者: Hsins (翔)   2019-12-19 11:15:00
不是啊,我提了啊,前端真的該理解的是為什麼函數式編程的編程範式會被各框架廣泛的應用,而不該著重在 API 與框架使用上。React 到現在也六年了。你怎麼不說 C++ 不用上 14 17 的特性落伍?還在用 Python 2.7 算是落伍,過幾天就不再支援了你說的我都同意,就是比的點很奇怪...
作者: b85040312 (萬年newman)   2019-12-19 12:16:00
我也看過公司堅持不用框架 JQ 也不用 只用原生寫網站抄屌XD說真的框架的效果只是有一個規範而已吧?如果理解底層用原生要寫一樣的效果也不難吧
作者: Hsins (翔)   2019-12-20 01:19:00
當系統越趨複雜,會遇到硬體上資源的限制,有些狀況並不是硬體設備不足夠的問題,所以越複雜越大的架構要碰到系統端越需要計算機基礎學科的支持,這也是後端越往深挖會遇到的,想當然而要處理這類問題時,語言也不會是太高階的。這些都沒毛病。至於說不用框架這件事,框架或者函數庫的使用,就是工程化的體現啊…你有可以用的東西,還是那些在大公司或開源界大老弄出來的,你要自幹還是跟著用?
作者: johnny94 (32767)   2019-12-20 12:55:00
前面說的挺好的,但是回應部分總覺得容不進其他想法
作者: BignoZe (BignoZe)   2019-12-22 12:36:00
前端目前趨向穩定期了 是個可以進場的好時機
作者: b85040312 (萬年newman)   2019-12-22 13:04:00
樓上怎麼說
作者: acgotaku (otaku)   2018-01-07 18:58:00
感覺樓主也陷入軟工的歧視鍊低階語言歧視高階 後端歧視前端 非框架歧視框架其實我跟我同學同事對開發都有一個共識就是先開發出來能上線才是贏家現在產品週期太快了 很多產品沒考慮優化前就已經走不下去了

Links booklink

Contact Us: admin [ a t ] ucptt.com