PHP程序員突破成長(zhǎng)瓶頸
PHP程序員突破成長(zhǎng)瓶頸-附學(xué)習(xí)建議
身邊有幾個(gè)做PHP開(kāi)發(fā)的朋友,因?yàn)槊嬖,也接觸到不少的PHP工程師,他們常疑慮自己將來(lái)在技術(shù)上的成長(zhǎng)與發(fā)展,我常給他們一些建議,希望他們能破突自己,有更好的發(fā)展。
PHP工程師面臨成長(zhǎng)瓶頸
先明確我所指的PHP工程題,是指畢業(yè)工作后,主要以PHP進(jìn)行WEB系統(tǒng)的開(kāi)發(fā),沒(méi)有使用其他語(yǔ)言工作過(guò)。工作經(jīng)驗(yàn)大概在3~4年,普通的WEB系統(tǒng)(百萬(wàn)級(jí)訪(fǎng)問(wèn),千成級(jí)數(shù)據(jù)以?xún)?nèi)或業(yè)務(wù)邏輯不是特別復(fù)雜)開(kāi)發(fā)起基本得心應(yīng)手,沒(méi)有什么問(wèn)題。但他們會(huì)這樣的物點(diǎn):
除了PHP不使用其它的語(yǔ)言,可能會(huì)點(diǎn)shell腳本。
對(duì)PHP的掌握不精(很多PHP手冊(cè)都沒(méi)有看完,庫(kù)除外)
知識(shí)面比較窄(面對(duì)需求,除開(kāi)使用PHP和mysql,不知道其它的解決辦法)
PHP代碼以過(guò)程為主,認(rèn)為面向?qū)ο蟮膶?shí)現(xiàn)太繞,看不懂
這些PHPer在遇到需要高性能,處理高并發(fā),大量數(shù)據(jù)的項(xiàng)目或業(yè)務(wù)邏輯比較復(fù)雜(系統(tǒng)需要解決多領(lǐng)域業(yè)務(wù)的問(wèn)題)時(shí),缺少思路。不能分析問(wèn)題的本質(zhì),技術(shù)判斷力比較差,對(duì)于問(wèn)題較快能找出臨時(shí)的解決辦法,但常常在不斷臨時(shí)性的解決辦法中,系統(tǒng)和自己一步步走向崩潰。那怎么提高自己呢?怎么可以挑戰(zhàn)難度更高的系統(tǒng)?
更高的挑戰(zhàn)在那里?
結(jié)合我自己的經(jīng)驗(yàn),我列出一些具體挑戰(zhàn),讓大家先有個(gè)感性的認(rèn)識(shí)。
高性能系統(tǒng)的挑戰(zhàn)在哪里?
如何選擇WEB服務(wù)器?要不要使用fast-cgi模式
要不要使用反向代理服務(wù)?選擇全內(nèi)存緩存還是硬盤(pán)緩存?
是否需要負(fù)載均衡?是基于應(yīng)用層,還是網(wǎng)絡(luò)層?如何保證高可靠性?你的PHP代碼性能如何,使用優(yōu)化工具后怎么樣?性能瓶頸在那里?是否需要寫(xiě)成C的擴(kuò)展?
用戶(hù)訪(fǎng)問(wèn)有什么特點(diǎn),是讀多還是寫(xiě)多?是否需要讀寫(xiě)分離?
數(shù)據(jù)如何存儲(chǔ)?寫(xiě)入速度和讀出速度如何?數(shù)據(jù)增漲訪(fǎng)問(wèn)速讀如何變化?
如何使用緩存?怎么樣考慮失效?數(shù)據(jù)的一致性怎么保證?
高復(fù)雜性系統(tǒng)的挑戰(zhàn)在哪里?
能否識(shí)別業(yè)務(wù)所對(duì)應(yīng)的領(lǐng)域?是一個(gè)還是多個(gè)?
能否合理對(duì)業(yè)務(wù)進(jìn)行抽象,在業(yè)務(wù)規(guī)則變化能以很小的代價(jià)實(shí)現(xiàn)?數(shù)據(jù)的一致性、安全性可否保證?
是否撐握了面向?qū)ο蟮姆治龊驮O(shè)計(jì)的方法
當(dāng)我所列出的問(wèn)題,你都能肯定的回答,我想在技術(shù)上你基本已經(jīng)可能成為架構(gòu)師了。如何你還不能回答,你需要在以下幾個(gè)方向加強(qiáng)。
怎么樣提高,突破瓶頸
如何你還不能回答,你需要在以下幾個(gè)方向加強(qiáng):
分析你所使用的技術(shù)其原理和背后運(yùn)行的機(jī)制,這樣可以提高你的技術(shù)判斷力,提高你技術(shù)方案選擇的正確性;
學(xué)習(xí)大學(xué)期間重要的知識(shí),操作系統(tǒng)原理,數(shù)據(jù)結(jié)構(gòu)和算法。知道你以前學(xué)習(xí)都是為了考試,但現(xiàn)在你需要為自己學(xué)習(xí),讓自己知其所以然。
重新開(kāi)始學(xué)習(xí)C語(yǔ)言,雖然你在大學(xué)已經(jīng)學(xué)過(guò)。這不僅是因?yàn)槟憧赡苄枰獙?xiě)PHP擴(kuò)展,而且還因?yàn),在做C的應(yīng)用中,有一個(gè)時(shí)刻關(guān)心性能、內(nèi)存控制、變量生命周期、數(shù)據(jù)結(jié)構(gòu)和算法的環(huán)境。
學(xué)習(xí)面向?qū)ο蟮姆治雠c設(shè)計(jì),它是解決復(fù)雜問(wèn)題的有效的方法。學(xué)習(xí)抽象,它是解決復(fù)雜問(wèn)題的唯一之道。
“這么多的東西怎么學(xué),這得學(xué)多久呀”?
如果你努力的話(huà),有較好的規(guī)劃,估計(jì)需要1~2年的時(shí)間,怎么學(xué)習(xí)的問(wèn)題,我們后續(xù)再談。
(注:下面是原文作者左文建分享的學(xué)習(xí)方法)
學(xué)習(xí)建議
如何有效的學(xué)習(xí)是一個(gè)大問(wèn)題。自己有些實(shí)踐但很零散,不好總結(jié)。昨天晚上睡覺(jué)前,突然想到了RUP的核心,“以架構(gòu)為中心,用例驅(qū)動(dòng),迭代開(kāi)發(fā)”,借用這個(gè)思想,關(guān)于有效的學(xué)習(xí)的方法,可以這樣來(lái)表述:
以原理、模型或機(jī)制為中心,任務(wù)驅(qū)動(dòng),迭代學(xué)習(xí)
有點(diǎn)抽象,舉個(gè)例子來(lái)說(shuō)明如何學(xué)習(xí)。
目的:學(xué)習(xí)如何提高處理性能。
可迭代驅(qū)動(dòng)的任務(wù):通過(guò)IP找到所在地域。
這是WEB應(yīng)用常見(jiàn)的任務(wù),IP數(shù)據(jù)庫(kù)是10左右萬(wàn)行的記錄。
第一次迭代:不考慮性能的情況下實(shí)現(xiàn)功能(通過(guò)PHP來(lái)實(shí)現(xiàn))
因?yàn)闊o(wú)法直接通過(guò)KEY(IP)進(jìn)行查找地域,所以直接放到數(shù)據(jù)或通過(guò)關(guān)聯(lián)數(shù)組這種簡(jiǎn)單的方法都是不行的。思路還是先把數(shù)據(jù)進(jìn)行排序,然后再進(jìn)行查找1.如何通過(guò)IP查找?已序的數(shù)據(jù),二分查找是最快的。2.如何排序?用庫(kù)函數(shù)sort當(dāng)然是可以,但是即然是學(xué)習(xí),那還是自己實(shí)現(xiàn)快速排序吧。
學(xué)習(xí)目標(biāo):排序算法,查找算法
PHPer數(shù)據(jù)結(jié)構(gòu)和算法基礎(chǔ)比較差,平時(shí)也沒(méi)有這方面的任務(wù),自己也不學(xué)習(xí),因此這方面的知識(shí)很缺乏。但是,編程解決的問(wèn)題,最終都會(huì)歸結(jié)到數(shù)據(jù)結(jié)構(gòu)和對(duì)這種數(shù)據(jù)結(jié)構(gòu)操作的算法。如果數(shù)據(jù)結(jié)構(gòu)算法常在心中,那遇到問(wèn)題就能清晰認(rèn)識(shí)到它內(nèi)在的結(jié)構(gòu),解決方法就會(huì)自然產(chǎn)生。
第二次迭代:優(yōu)化數(shù)據(jù)的加載與排序
如果做到第一步,那基本上還是不可用,因?yàn)閿?shù)據(jù)每次都需要的加載和排序,這樣太耗時(shí)間。解決的思路是,數(shù)據(jù)一次加載排序后,放到每個(gè)PHP進(jìn)程能訪(fǎng)問(wèn)到的地方。
放到memcache這是大家容易想到問(wèn)題。其實(shí)放到共享內(nèi)存(EA等加速器都支持)中是更快的方式,因?yàn)閙emcache還多了網(wǎng)絡(luò)操作。數(shù)據(jù)是整體放入到共享內(nèi)存,還是分塊放入,如何測(cè)試性能?如何分析瓶頸所在(xdebug)?在這些問(wèn)題的驅(qū)動(dòng)下你會(huì)學(xué)習(xí)到
學(xué)習(xí)目標(biāo):檢測(cè)、定位、優(yōu)化PHP性能的方法;PHP實(shí)現(xiàn)結(jié)構(gòu)對(duì)性能的影響。
第三次迭代:編寫(xiě)PHP的擴(kuò)展
性能還是上不去,不得不進(jìn)入C/C++的世界了,不過(guò)從此你將不只是PHPer而服務(wù)端的全能型工程師,當(dāng)然這對(duì)沒(méi)有做過(guò)C/C++的同學(xué)挑戰(zhàn)是巨大的。我這里無(wú)法再簡(jiǎn)單來(lái)說(shuō)如何學(xué)習(xí)C/C++,可以參看《PHP程序員學(xué)習(xí)C++》
學(xué)習(xí)目標(biāo):C/C++的學(xué)習(xí),PHP擴(kuò)展的編寫(xiě)
怎么確定需要學(xué)習(xí)的機(jī)制和原理呢?怎么找到驅(qū)動(dòng)學(xué)習(xí)任務(wù)呢?
我對(duì)需要學(xué)習(xí)的東西,都沒(méi)有什么概念,怎么回答以上的兩個(gè)問(wèn)題?
從這個(gè)技術(shù)的定位來(lái)找出需要學(xué)習(xí)的重點(diǎn),即它怎么做到(機(jī)制)的和它為什么能這樣做到(模型或原理)
列出這個(gè)技術(shù)最常見(jiàn)的應(yīng)用,做為學(xué)習(xí)的任務(wù),從簡(jiǎn)到難進(jìn)行實(shí)踐。
假如我需要學(xué)習(xí)j,我對(duì)于HTML,CSS有點(diǎn)感性認(rèn)識(shí)
首要我了解到,JS是WEB領(lǐng)域的動(dòng)態(tài)語(yǔ)言,主要解決網(wǎng)頁(yè)的動(dòng)態(tài)交互的。
那我要學(xué)習(xí)的要點(diǎn)如下:
JS如何與HTML進(jìn)行交互(機(jī)制)
JS的動(dòng)態(tài)特性在那里,與其它動(dòng)態(tài)語(yǔ)言有何區(qū)別?(語(yǔ)言模型)
如果完全自學(xué),找到需要學(xué)習(xí)的要點(diǎn)(機(jī)制、模型、原理)設(shè)定學(xué)習(xí)任務(wù)的確不是那么容易把握。如果找到一個(gè)有經(jīng)驗(yàn)的人來(lái)指導(dǎo)你或加一個(gè)學(xué)習(xí)型的團(tuán)隊(duì),那學(xué)習(xí)的速度的確會(huì)大大提高。
最后,我想說(shuō)的是:PHP因?yàn)楹?jiǎn)單而使用,但不能因?yàn)樗暮?jiǎn)單而限制我們成長(zhǎng)!
擴(kuò)展閱讀:PHP程序員突破成長(zhǎng)瓶頸
PHP程序員突破成長(zhǎng)瓶頸-附學(xué)習(xí)建議
身邊有幾個(gè)做PHP開(kāi)發(fā)的朋友,因?yàn)槊嬖嚕步佑|到不少的PHP工程師,他們常疑慮自己將來(lái)在技術(shù)上的成長(zhǎng)與發(fā)展,我常給他們一些建議,希望他們能破突自己,有更好的發(fā)展。PHP工程師面臨成長(zhǎng)瓶頸
先明確我所指的PHP工程題,是指畢業(yè)工作后,主要以PHP進(jìn)行WEB系統(tǒng)的開(kāi)發(fā),沒(méi)有使用其他語(yǔ)言工作過(guò)。工作經(jīng)驗(yàn)大概在3~4年,普通的WEB系統(tǒng)(百萬(wàn)級(jí)訪(fǎng)問(wèn),千成級(jí)數(shù)據(jù)以?xún)?nèi)或業(yè)務(wù)邏輯不是特別復(fù)雜)開(kāi)發(fā)起基本得心應(yīng)手,沒(méi)有什么問(wèn)題。但他們會(huì)這樣的物點(diǎn):除了PHP不使用其它的語(yǔ)言,可能會(huì)點(diǎn)shell腳本。對(duì)PHP的掌握不精(很多PHP手冊(cè)都沒(méi)有看完,庫(kù)除外)
知識(shí)面比較窄(面對(duì)需求,除開(kāi)使用PHP和mysql,不知道其它的解決辦法)PHP代碼以過(guò)程為主,認(rèn)為面向?qū)ο蟮膶?shí)現(xiàn)太繞,看不懂
這些PHPer在遇到需要高性能,處理高并發(fā),大量數(shù)據(jù)的項(xiàng)目或業(yè)務(wù)邏輯比較復(fù)雜(系統(tǒng)需要解決多領(lǐng)域業(yè)務(wù)的問(wèn)題)時(shí),缺少思路。不能分析問(wèn)題的本質(zhì),技術(shù)判斷力比較差,對(duì)于問(wèn)題較快能找出臨時(shí)的解決辦法,但常常在不斷臨時(shí)性的解決辦法中,系統(tǒng)和自己一步步走向崩潰。那怎么提高自己呢?怎么可以挑戰(zhàn)難度更高的系統(tǒng)?更高的挑戰(zhàn)在那里?
結(jié)合我自己的經(jīng)驗(yàn),我列出一些具體挑戰(zhàn),讓大家先有個(gè)感性的認(rèn)識(shí)。高性能系統(tǒng)的挑戰(zhàn)在哪里?
如何選擇WEB服務(wù)器?要不要使用fast-cgi模式
要不要使用反向代理服務(wù)?選擇全內(nèi)存緩存還是硬盤(pán)緩存?
是否需要負(fù)載均衡?是基于應(yīng)用層,還是網(wǎng)絡(luò)層?如何保證高可靠性?你的PHP代碼性能如何,使用優(yōu)化工具后怎么樣?性能瓶頸在那里?是否需要寫(xiě)成C的擴(kuò)展?
用戶(hù)訪(fǎng)問(wèn)有什么特點(diǎn),是讀多還是寫(xiě)多?是否需要讀寫(xiě)分離?
數(shù)據(jù)如何存儲(chǔ)?寫(xiě)入速度和讀出速度如何?數(shù)據(jù)增漲訪(fǎng)問(wèn)速讀如何變化?如何使用緩存?怎么樣考慮失效?數(shù)據(jù)的一致性怎么保證?高復(fù)雜性系統(tǒng)的挑戰(zhàn)在哪里?
能否識(shí)別業(yè)務(wù)所對(duì)應(yīng)的領(lǐng)域?是一個(gè)還是多個(gè)?
能否合理對(duì)業(yè)務(wù)進(jìn)行抽象,在業(yè)務(wù)規(guī)則變化能以很小的代價(jià)實(shí)現(xiàn)?數(shù)據(jù)的一致性、安全性可否保證?是否撐握了面向?qū)ο蟮姆治龊驮O(shè)計(jì)的方法
當(dāng)我所列出的問(wèn)題,你都能肯定的回答,我想在技術(shù)上你基本已經(jīng)可能成為架構(gòu)師了。如何你還不能回答,你需要在以下幾個(gè)方向加強(qiáng)。
怎么樣提高,突破瓶頸
如何你還不能回答,你需要在以下幾個(gè)方向加強(qiáng):
分析你所使用的技術(shù)其原理和背后運(yùn)行的機(jī)制,這樣可以提高你的技術(shù)判斷力,提高你技術(shù)方案選擇的正確性;
學(xué)習(xí)大學(xué)期間重要的知識(shí),操作系統(tǒng)原理,數(shù)據(jù)結(jié)構(gòu)和算法。知道你以前學(xué)習(xí)都是為了考試,但現(xiàn)在你需要為自己學(xué)習(xí),讓自己知其所以然。
重新開(kāi)始學(xué)習(xí)C語(yǔ)言,雖然你在大學(xué)已經(jīng)學(xué)過(guò)。這不僅是因?yàn)槟憧赡苄枰獙?xiě)PHP擴(kuò)展,而且還因?yàn),在做C的應(yīng)用中,有一個(gè)時(shí)刻關(guān)心性能、內(nèi)存控制、變量生命周期、數(shù)據(jù)結(jié)構(gòu)和算法的環(huán)境。
學(xué)習(xí)面向?qū)ο蟮姆治雠c設(shè)計(jì),它是解決復(fù)雜問(wèn)題的有效的方法。學(xué)習(xí)抽象,它是解決復(fù)雜問(wèn)題的唯一之道。
“這么多的東西怎么學(xué),這得學(xué)多久呀”?
如果你努力的話(huà),有較好的規(guī)劃,估計(jì)需要1~2年的時(shí)間,怎么學(xué)習(xí)的問(wèn)題,我們后續(xù)再談。
(注:下面是原文作者左文建分享的學(xué)習(xí)方法)學(xué)習(xí)建議
如何有效的學(xué)習(xí)是一個(gè)大問(wèn)題。自己有些實(shí)踐但很零散,不好總結(jié)。昨天晚上睡覺(jué)前,突然想到了RUP的核心,“以架構(gòu)為中心,用例驅(qū)動(dòng),迭代開(kāi)發(fā)”,借用這個(gè)思想,關(guān)于有效的學(xué)習(xí)的方法,可以這樣來(lái)表述:以原理、模型或機(jī)制為中心,任務(wù)驅(qū)動(dòng),迭代學(xué)習(xí)有點(diǎn)抽象,舉個(gè)例子來(lái)說(shuō)明如何學(xué)習(xí)。目的:學(xué)習(xí)如何提高處理性能。
可迭代驅(qū)動(dòng)的任務(wù):通過(guò)IP找到所在地域。
這是WEB應(yīng)用常見(jiàn)的任務(wù),IP數(shù)據(jù)庫(kù)是10左右萬(wàn)行的記錄。第一次迭代:不考慮性能的情況下實(shí)現(xiàn)功能(通過(guò)PHP來(lái)實(shí)現(xiàn))因?yàn)闊o(wú)法直接通過(guò)KEY(IP)進(jìn)行查找地域,所以直接放到數(shù)據(jù)或通過(guò)關(guān)聯(lián)數(shù)組這種簡(jiǎn)單的方法都是不行的。思路還是先把數(shù)據(jù)進(jìn)行排序,然后再進(jìn)行查找
1.如何通過(guò)IP查找?已序的數(shù)據(jù),二分查找是最快的。
2.如何排序?用庫(kù)函數(shù)sort當(dāng)然是可以,但是即然是學(xué)習(xí),那還是自己實(shí)現(xiàn)快速排序吧。
學(xué)習(xí)目標(biāo):排序算法,查找算法
PHPer數(shù)據(jù)結(jié)構(gòu)和算法基礎(chǔ)比較差,平時(shí)也沒(méi)有這方面的任務(wù),自己也不學(xué)習(xí),因此這方面的知識(shí)很缺乏。但是,編程解決的問(wèn)題,最終都會(huì)歸結(jié)到數(shù)據(jù)結(jié)構(gòu)和對(duì)這種數(shù)據(jù)結(jié)構(gòu)操作的算法。如果數(shù)據(jù)結(jié)構(gòu)算法常在心中,那遇到問(wèn)題就能清晰認(rèn)識(shí)到它內(nèi)在的結(jié)構(gòu),解決方法就會(huì)自然產(chǎn)生。第二次迭代:優(yōu)化數(shù)據(jù)的加載與排序
如果做到第一步,那基本上還是不可用,因?yàn)閿?shù)據(jù)每次都需要的加載和排序,這樣太耗時(shí)間。解決的思路是,數(shù)據(jù)一次加載排序后,放到每個(gè)PHP進(jìn)程能訪(fǎng)問(wèn)到的地方。
放到memcache這是大家容易想到問(wèn)題。其實(shí)放到共享內(nèi)存(EA等加速器都支持)中是更快的方式,因?yàn)閙emcache還多了網(wǎng)絡(luò)操作。數(shù)據(jù)是整體放入到共享內(nèi)存,還是分塊放入,如何測(cè)試性能?如何分析瓶頸所在(xdebug)?在這些問(wèn)題的驅(qū)動(dòng)下你會(huì)學(xué)習(xí)到
學(xué)習(xí)目標(biāo):檢測(cè)、定位、優(yōu)化PHP性能的方法;PHP實(shí)現(xiàn)結(jié)構(gòu)對(duì)性能的影響。
第三次迭代:編寫(xiě)PHP的擴(kuò)展
性能還是上不去,不得不進(jìn)入C/C++的世界了,不過(guò)從此你將不只是PHPer而服務(wù)端的全能型工程師,當(dāng)然這對(duì)沒(méi)有做過(guò)C/C++的同學(xué)挑戰(zhàn)是巨大的。我這里無(wú)法再簡(jiǎn)單來(lái)說(shuō)如何學(xué)習(xí)C/C++,可以參看《PHP程序員學(xué)習(xí)C++》
學(xué)習(xí)目標(biāo):C/C++的學(xué)習(xí),PHP擴(kuò)展的編寫(xiě)
怎么確定需要學(xué)習(xí)的機(jī)制和原理呢?怎么找到驅(qū)動(dòng)學(xué)習(xí)任務(wù)呢?我對(duì)需要學(xué)習(xí)的東西,都沒(méi)有什么概念,怎么回答以上的兩個(gè)問(wèn)題?
從這個(gè)技術(shù)的定位來(lái)找出需要學(xué)習(xí)的重點(diǎn),即它怎么做到(機(jī)制)的和它為什么能這樣做到(模型或原理)
列出這個(gè)技術(shù)最常見(jiàn)的應(yīng)用,做為學(xué)習(xí)的任務(wù),從簡(jiǎn)到難進(jìn)行實(shí)踐。假如我需要學(xué)習(xí)Javascript,我對(duì)于HTML,CSS有點(diǎn)感性認(rèn)識(shí)
首要我了解到,JS是WEB領(lǐng)域的動(dòng)態(tài)語(yǔ)言,主要解決網(wǎng)頁(yè)的動(dòng)態(tài)交互的。那我要學(xué)習(xí)的要點(diǎn)如下:JS如何與HTML進(jìn)行交互(機(jī)制)
JS的動(dòng)態(tài)特性在那里,與其它動(dòng)態(tài)語(yǔ)言有何區(qū)別?(語(yǔ)言模型)
如果完全自學(xué),找到需要學(xué)習(xí)的要點(diǎn)(機(jī)制、模型、原理)設(shè)定學(xué)習(xí)任務(wù)的確不是那么容易把握。如果找到一個(gè)有經(jīng)驗(yàn)的人來(lái)指導(dǎo)你或加一個(gè)學(xué)習(xí)型的團(tuán)隊(duì),那學(xué)習(xí)的速度的確會(huì)大大提高。
最后,我想說(shuō)的是:PHP因?yàn)楹?jiǎn)單而使用,但不能因?yàn)樗暮?jiǎn)單而限制我們成長(zhǎng)!
友情提示:本文中關(guān)于《PHP程序員突破成長(zhǎng)瓶頸》給出的范例僅供您參考拓展思維使用,PHP程序員突破成長(zhǎng)瓶頸:該篇文章建議您自主創(chuàng)作。
來(lái)源:網(wǎng)絡(luò)整理 免責(zé)聲明:本文僅限學(xué)習(xí)分享,如產(chǎn)生版權(quán)問(wèn)題,請(qǐng)聯(lián)系我們及時(shí)刪除。