編碼能力卻稀松平常的程序員?
滿嘴高并發的前提是真的要接觸過高并發系統,或者目前正在負責的就是高并發系統。
如果壓根就沒有接觸過高并發系統,或者連百萬級用戶的系統都沒負責過,就不要談高并發。因為,99%的程序員都接觸不到高并發系統。
高并發這個詞語對于我,或者說對于我的項目組一點不陌生,因為我們做的是真正的高并發系統,當然不是那么的“高”,算是一般高并發吧!集群的QPS在15萬左右。
高并發系統我們關注的問題非常多,例如:負載均衡、彈性擴容、限流、熔斷、降級、響應時間、緩存等等問題。一個健壯的高并發系統限流和熔斷第一道防護線。因為海量的請求瞬間流入應用系統以后,如果系統處理不了,那就會擊垮后端的其它子系統以及其它組件,例如數據庫和緩存。所以,必須做好系統的限流。當系統的QPS超過閾值,就要拒絕新來的請求,這樣保證子系統有足夠的時間去處理請求。
高并發系統面臨的另外一個問題就是“高”的傾斜性。根據“二八”原則,80%的請求都發生在20%的時間內。也就是說,系統只有在20%的時間面臨高并發請求,其余時間并非高并發請求。而這種情況下,我們就要做好系統的彈性擴容伸縮。我們可以根據前置負載均衡器的QPS(SLB)、CPU等指標彈性的擴容或者收縮機器。這樣,當請求量大的時候,我們就自動擴容更多的機器來處理請求,當請求少的時候,我們就收縮機器,降低成本。
總之,高并發系統所涉及到技術是非常復雜的。如果想侃侃而談高并發概念,必須要親身實戰過高并發業務。通過高并發業務的實操,我們能更深的理解高并發的精髓。至于,編碼...我覺得是最底層的工作,只要思路清楚,寫代碼就是個體力活。