分布式多線程高并發(fā) 作為開(kāi)發(fā),項(xiàng)目中接觸不到多線程和高并發(fā),我該怎么去掌握?
作為開(kāi)發(fā),項(xiàng)目中接觸不到多線程和高并發(fā),我該怎么去掌握?所有人都有這個(gè)痛點(diǎn),但痛點(diǎn)不同。沒(méi)有辦法。程序員就是這樣。項(xiàng)目開(kāi)發(fā)是一個(gè)人負(fù)責(zé)開(kāi)發(fā)部分內(nèi)容模塊。大項(xiàng)目是可以的。每個(gè)人都會(huì)發(fā)展出更多的東西。小型
作為開(kāi)發(fā),項(xiàng)目中接觸不到多線程和高并發(fā),我該怎么去掌握?
所有人都有這個(gè)痛點(diǎn),但痛點(diǎn)不同。沒(méi)有辦法。程序員就是這樣。項(xiàng)目開(kāi)發(fā)是一個(gè)人負(fù)責(zé)開(kāi)發(fā)部分內(nèi)容模塊。大項(xiàng)目是可以的。每個(gè)人都會(huì)發(fā)展出更多的東西。小型項(xiàng)目沒(méi)有高并發(fā)性和多線程開(kāi)發(fā)。
以前做輕應(yīng)用開(kāi)發(fā)的時(shí)候,我想在微信平臺(tái)上開(kāi)發(fā),但是沒(méi)有成功。我不得不服從公司的安排。我只能從頭到尾在金蝶移動(dòng)云上寫(xiě)輕量應(yīng)用。雖然我覺(jué)得它幾乎是基于某個(gè)平臺(tái),但我心里還是有一個(gè)缺口。
開(kāi)發(fā)人員希望接觸一些他們沒(méi)有做過(guò)的事情來(lái)提高技術(shù)。然而,現(xiàn)實(shí)是殘酷的。遇到項(xiàng)目時(shí),公司有現(xiàn)成的技術(shù)。成熟的開(kāi)發(fā)者肯定不會(huì)讓不熟悉某項(xiàng)技術(shù)的人去開(kāi)發(fā)。
作為開(kāi)發(fā)者,他們只能利用業(yè)余時(shí)間學(xué)習(xí),搭建自己的電腦虛擬環(huán)境,安裝好數(shù)據(jù)庫(kù),找一些數(shù)據(jù)導(dǎo)入,私下探索,或者拿別人的程序模仿學(xué)習(xí)。
當(dāng)程序員在工作中遇到不熟悉的技術(shù)時(shí),他們總是同時(shí)學(xué)習(xí)和做。這是正常情況。沒(méi)有別的辦法了。
有多少互聯(lián)網(wǎng)系統(tǒng)確實(shí)需要使用分布式架構(gòu)?
更不用說(shuō)互聯(lián)網(wǎng)的實(shí)際發(fā)展了,現(xiàn)在即使是面試新生,分布式的問(wèn)題基本上都是不可避免的。
目前,分布式體系結(jié)構(gòu)具有高并發(fā)性和高穩(wěn)定性的特點(diǎn)。
高并發(fā)意味著當(dāng)單節(jié)點(diǎn)服務(wù)器的性能達(dá)到瓶頸時(shí),可以通過(guò)引入nginx和部署多個(gè)服務(wù)器節(jié)點(diǎn)來(lái)擴(kuò)展,以增加系統(tǒng)的吞吐量。這就是1*n=n的意思。
高穩(wěn)定性意味著,如果單個(gè)或部分節(jié)點(diǎn)由于不可預(yù)知的原因發(fā)生故障,則不會(huì)影響系統(tǒng)的整體功能服務(wù),即M-N>0(M>N)。對(duì)于用戶(hù)來(lái)說(shuō),系統(tǒng)可用性始終是最重要的。
綜上所述,根據(jù)我個(gè)人的經(jīng)驗(yàn),目前無(wú)論是市場(chǎng)級(jí)產(chǎn)品還是公司級(jí)產(chǎn)品,只要項(xiàng)目團(tuán)隊(duì)有對(duì)服務(wù)質(zhì)量的追求,他們都會(huì)以不同的方式向分布式架構(gòu)發(fā)展。
另外,對(duì)于一個(gè)功能不是很復(fù)雜和龐大的項(xiàng)目組來(lái)說(shuō),只要在開(kāi)發(fā)設(shè)計(jì)階段一開(kāi)始就及時(shí)引入Memcache或redis作為數(shù)據(jù)緩存,而不是使用服務(wù)器的內(nèi)存,后期切換到分布式系統(tǒng)的過(guò)程就會(huì)非常快。
以上是我個(gè)人的觀點(diǎn)。歡迎在下面的評(píng)論區(qū)與我交流。
我是蘇思亮,來(lái)自bat的java開(kāi)發(fā)工程師。我每天分享科技知識(shí)。歡迎您關(guān)注我,與我共同進(jìn)步。