※ 本文轉寄自 ptt.cc, 文章原始頁面
看板Soft_Job
標題

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

時間
最新2020-01-07 19:02:00
留言47則留言,14人參與討論
推噓11 ( 11036 )
我覺得你對 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 . 也沒啥問題! : 好拉 講太多惹 大概是這樣 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 1.160.93.30 (臺灣) ※ 文章網址: https://www.ptt.cc/bbs/Soft_Job/M.1576552011.A.5AE.html

47 則留言

v420746k, 1F
推減少自己未知的領域

stillboy, 2F
我沒說vpon沒有具備C10K的架構規模吧. C10K對我而言 就

stillboy, 3F
像一個後端工程師的里程碑而已,至於坑 任何領域都有吧

stillboy, 4F
個人淺見 參考吧
通常前端的坑, 越補只是越被牽著鼻子走而已 因為太過於 high level, 反而容易變動 例如 IE / Edge / Android / iOS / react / .. 更新 你的某個 UI 元件就壞掉了, 然後你就勢必要 hotfix hotfix 完了可能也一知半解 而後端的坑, 以 Linux 來說好了, 你碰到的坑會有大量的 source code 輔助 這些 source code 可以慢慢累積該有的經驗, 這種經驗不太容易因為時間變得沒用 簡而言之, 差異就在, 後端你可以越學越舉一反三, 學到的不容易過時 前端的東西沒幾年你可能就過時了 (幾年前哪來的 vue.js ?) 當你年紀越大, 越需要這種容易隨著年紀也帶著走的經驗
※ 編輯: kloer (1.160.93.30 臺灣), 12/17/2019 16:24:27

Hsins, 5F
一知半解是開發者本身的問題吧?以前端這幾年的發展來說,

Hsins, 6F
朝著工程化的方向前進,因為 UI 所以更重視函數式編程範式

Hsins, 7F
,這兩個後面的概念並不太會隨著時間過時,會過時的是那些

Hsins, 8F
純粹調 API 使用的。
當然不會完全過時, 但是以會過時的比例來說, 前端是相當高的 10 年後誰敢保證 react / angular / vue 還佔有一席之地 ? 但是 10 年後蠻可以保證 C / C++ / Linux 還佔有一席之地 這兩者的信心程度是不同的, 容易過時的程度差太多
※ 編輯: kloer (1.160.93.30 臺灣), 12/17/2019 17:33:14

Hsins, 9F
不是啊…你拿三個框架來跟程式語言和作業系統比欸…
因為我玩的後端已經太靠近系統了, 幾乎不太需要而外引用絢麗的框架 所以我才會這樣比 當然後端也有些如 redis / memcached 之類 10 年後可能也有新東西出現, 但是差別在於 就算有新東西出現, 你用舊的東西也比較不會有過時的感覺 這種感覺有點難解釋, 除非架構與效能有極大差異 不然你都不會覺得這個老東西過時了, 還是用得很開心 反之前端可能就不同了 應該不少人還記得 Yahoo 以前風流一時的 YUI ? 現在拿來用也是可以用啦, 跑是能跑, 但是給外部的感覺就是另一回事了
※ 編輯: kloer (1.160.93.30 臺灣), 12/17/2019 17:50:18

superpai, 10F
標題是web前後端,你用C寫web嗎?

gg90052, 11F
要跟C比的話,20年前我學JS,現在要2020了我還是在用JS

b85040312, 12F
推樓上

anandydy529, 13F
Java可以從Symbian寫到Android

chatnoir, 14F
10年後JS還是會佔有一席之地der

as30385438, 15F
20年前的JS跟今天的用法差太多了 能這樣類比嗎...

gg90052, 16F
所以20年前的C跟今天的C用法一樣嗎?

x000032001, 17F
cpp表示 你們在吵甚麼

b85040312, 18F
組語表示:

arthur104, 19F
拿語言比框架是什麼鬼?
跟什麼比什麼無關 我上面說了, 是我個人的後端玩得比較接近系統 根本無需要套用框架, 我才這樣比 或許你可以提出一下該什麼比什麼, 然後提個合理的理由為何要這樣比 重點其實也不在於後端比前端好, 而是兩者都應該碰 但是我會偏向推薦後端, 比重大概是 70% 後端 30% 前端
※ 編輯: kloer (1.160.91.182 臺灣), 12/19/2019 10:13:05

Hsins, 20F
不是啊,我提了啊,前端真的該理解的是為什麼函數式編程的

Hsins, 21F
編程範式會被各框架廣泛的應用,而不該著重在 API 與框架使

Hsins, 22F
用上。
會提到框架原因是, 現代前端你不用流行的框架你就落伍了 偏偏這些流行的框架可能也不這麼持久
※ 編輯: kloer (1.160.91.182 臺灣), 12/19/2019 11:29:13

Hsins, 23F
React 到現在也六年了。你怎麼不說 C++ 不用上 14 17 的特

Hsins, 24F
性落伍?還在用 Python 2.7 算是落伍,過幾天就不再支援了

Hsins, 25F
你說的我都同意,就是比的點很奇怪...
比的點不是這麼好我同意 我的點在於前端比後端更容易變化 所以我一律推薦後端比重要高一些

b85040312, 26F
我也看過公司堅持不用框架 JQ 也不用 只用原生寫網站

b85040312, 27F
抄屌XD

b85040312, 28F
說真的框架的效果只是有一個規範而已吧?如果理解底層

b85040312, 29F
用原生要寫一樣的效果也不難吧
※ 編輯: kloer (1.160.91.182 臺灣), 12/19/2019 13:44:13

Hsins, 30F
當系統越趨複雜,會遇到硬體上資源的限制,有些狀況並不是

Hsins, 31F
硬體設備不足夠的問題,所以越複雜越大的架構要碰到系統端

Hsins, 32F
越需要計算機基礎學科的支持,這也是後端越往深挖會遇到的

Hsins, 33F
,想當然而要處理這類問題時,語言也不會是太高階的。這些

Hsins, 34F
都沒毛病。至於說不用框架這件事,框架或者函數庫的使用,

Hsins, 35F
就是工程化的體現啊…你有可以用的東西,還是那些在大公司

Hsins, 36F
或開源界大老弄出來的,你要自幹還是跟著用?
框架當然必須要用就該用 我的重點一直都不是該不該用框架 而是前端比後端變化快, 所以造成這些東西不容易累積
※ 編輯: kloer (1.160.91.182 臺灣), 12/20/2019 10:12:04

Hsins, 37F
所以我在一開始的推文有說,該深鑽的是 paradigm,為什麼會

Hsins, 38F
有這些框架出現。後面用不用框架那段是回 b85 啦

johnny94, 39F
前面說的挺好的,但是回應部分總覺得容不進其他想法
會有這種感覺是正常的, 不是容不進其他想法 而是網路上文字打打很難描述清楚真實的想法 描述不清的情況下就會有這種排斥性 A 覺得 B 說的錯, B 也覺得 A 說的錯 這是還好, 不要有太錯誤的東西都是可容忍的
※ 編輯: kloer (1.160.91.182 臺灣), 12/20/2019 13:45:06

BignoZe, 40F
前端目前趨向穩定期了 是個可以進場的好時機

b85040312, 41F
樓上怎麼說

acgotaku, 42F
感覺樓主也陷入軟工的歧視鍊

acgotaku, 43F
低階語言歧視高階 後端歧視前端 非框架歧視框架

acgotaku, 44F
其實我跟我同學同事對開發都有一個共識

acgotaku, 45F
就是先開發出來能上線才是贏家

acgotaku, 46F
現在產品週期太快了 很多產品沒考慮優化前

acgotaku, 47F
就已經走不下去了