成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

PHP程序員如何突破成長(zhǎng)瓶頸

開發(fā) 后端 前端
PHP因?yàn)楹?jiǎn)單而使用,但不能因?yàn)樗暮?jiǎn)單而限制我們成長(zhǎng)!文章給PHP工程師突破成長(zhǎng)瓶頸提了一些建議,希望PHPer能夠突破自己,有更好的發(fā)展。

作為Web開發(fā)中應(yīng)用最廣泛的語言之一,PHP有著大量的粉絲,那么你是一名優(yōu)秀的程序員嗎?在進(jìn)行自我修煉的同時(shí),你是否想過面對(duì)各種各樣的問題,我該如何突破自身的瓶頸,以便更好的發(fā)展呢?

PHP工程師面臨成長(zhǎng)瓶頸

先明確這里所指的PHP工程師,是指主要以PHP進(jìn)行Web系統(tǒng)的開發(fā),沒有使用其的語言工作過。工作經(jīng)驗(yàn)大概在3~4年,普通的Web系統(tǒng)(百萬級(jí)訪問,千成級(jí)數(shù)據(jù)以內(nèi)或業(yè)務(wù)邏輯不是特別復(fù)雜)開發(fā)起基本得心應(yīng)手,沒有什么問題。但他們會(huì)這樣的物點(diǎn):

◆除了PHP不使用其它的語言,可能會(huì)點(diǎn)shell 腳本。

◆對(duì)PHP的掌握不精(很多PHP手冊(cè)都沒有看完,庫除外)。

◆知識(shí)面比較窄(面對(duì)需求,除開使用PHP和mysql ,不知道其它的解決辦法)。

◆PHP代碼以過程為主,認(rèn)為面向?qū)ο蟮膶?shí)現(xiàn)太繞,看不懂。

這些PHPer在遇到需要高性能,處理高并發(fā),大量數(shù)據(jù)的項(xiàng)目或業(yè)務(wù)邏輯比較復(fù)雜(系統(tǒng)需要解決多領(lǐng)域業(yè)務(wù)的問題)時(shí),缺少思路。不能分析問題的本質(zhì),技術(shù)判斷力比較差,對(duì)于問題較快能找出臨時(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)存緩存還是硬盤緩存?

◆是否需要負(fù)載均衡?是基于應(yīng)用層,還是網(wǎng)絡(luò)層? 如何保證高可靠性?

◆你的PHP代碼性能如何,使用優(yōu)化工具后怎么樣? 性能瓶頸在那里? 是否需要寫成C的擴(kuò)展?

◆用戶訪問有什么特點(diǎn),是讀多還是寫多?是否需要讀寫分離?

◆數(shù)據(jù)如何存儲(chǔ)?寫入速度和讀出速度如何? 數(shù)據(jù)增漲訪問速讀如何變化?

◆如何使用緩存? 怎么樣考慮失效?數(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ì)的方法

這里所列出的問題,你都能肯定的回答,說明在技術(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í),讓自己知其所以然;

◆重新開始學(xué)習(xí)C語言,雖然你在大學(xué)已經(jīng)學(xué)過。這不僅是因?yàn)槟憧赡苄枰獙慞HP擴(kuò)展,而且還因?yàn)椋谧鯟的應(yīng)用中,有一個(gè)時(shí)刻關(guān)心性能、內(nèi)存控制、變量生命周期、數(shù)據(jù)結(jié)構(gòu)和算法的環(huán)境;

◆學(xué)習(xí)面向?qū)ο蟮姆治雠c設(shè)計(jì),它是解決復(fù)雜問題的有效的方法。學(xué)習(xí)抽象,它是解決復(fù)雜問題的唯一之道。

#p#

如何有效的學(xué)習(xí)是一個(gè)大問題。“以架構(gòu)為中心,用例驅(qū)動(dòng),迭代開發(fā)”,借用這個(gè)思想,關(guān)于有效的學(xué)習(xí)的方法,可以這樣來表述:以原理、模型或機(jī)制為中心,任務(wù)驅(qū)動(dòng),迭代學(xué)習(xí)。有點(diǎn)抽象, 舉個(gè)例子來說明如何學(xué)習(xí)。

目的: 學(xué)習(xí)如何提高處理性能。

可迭代驅(qū)動(dòng)的任務(wù): 通過IP找到所在地域。這是Web應(yīng)用常見的任務(wù),IP數(shù)據(jù)庫是10左右萬行的記錄。

第一次迭代: 不考慮性能的情況下實(shí)現(xiàn)功能(通過PHP來實(shí)現(xiàn))

因?yàn)闊o法直接通過KEY(IP)進(jìn)行查找地域,所以直接放到數(shù)據(jù)或通過關(guān)聯(lián)數(shù)組這種簡(jiǎn)單的方法都是不行的。思路還是先把數(shù)據(jù)進(jìn)行排序,然后再進(jìn)行查找:

◆如何通過IP查找?已序的數(shù)據(jù),二分查找是最快的。

◆如何排序?用庫函數(shù)sort當(dāng)然是可以,但是即然是學(xué)習(xí),那還是自己實(shí)現(xiàn)快速排序吧。

學(xué)習(xí)目標(biāo): 排序算法,查找算法

PHPer數(shù)據(jù)結(jié)構(gòu)和算法基礎(chǔ)比較差,平時(shí)也沒有這方面的任務(wù),自己也不學(xué)習(xí),因此這方面的知識(shí)很缺乏。但是,編程解決的問題,最終都會(huì)歸結(jié)到數(shù)據(jù)結(jié)構(gòu)和對(duì)這種數(shù)據(jù)結(jié)構(gòu)操作的算法。如果數(shù)據(jù)結(jié)構(gòu)算法常在心中,那遇到問題就能清晰認(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)程能訪問到的地方。放到Memcache這是大家容易想到問題。其實(shí)放到共享內(nèi)存(EA等加速器都支持)中是更快的方式,因?yàn)閙emcache還多了網(wǎng)絡(luò)操作。 數(shù)據(jù)是整體放入到共享內(nèi)存,還是分塊放入,如何測(cè)試性能? 如何分析瓶頸所在(xdebug)? 在這些問題的驅(qū)動(dòng)下你會(huì)學(xué)習(xí)到。

學(xué)習(xí)目標(biāo): 檢測(cè)、定位、優(yōu)化PHP性能的方法; PHP實(shí)現(xiàn)結(jié)構(gòu)對(duì)性能的影響。

第三次迭代: 編寫PHP的擴(kuò)展

性能還是上不去,不得不進(jìn)入C/C++的世界了,不過從此你將不只是PHPer 而服務(wù)端的全能型工程師,當(dāng)然這對(duì)沒有做過C/C++的同學(xué)挑戰(zhàn)是巨大的。

學(xué)習(xí)目標(biāo):C/C++的學(xué)習(xí),PHP擴(kuò)展的編寫

怎么確定需要學(xué)習(xí)的機(jī)制和原理呢? 怎么找到驅(qū)動(dòng)學(xué)習(xí)任務(wù)呢?我對(duì)需要學(xué)習(xí)的東西,都沒有什么概念,怎么回答以上的兩個(gè)問題? 從這個(gè)技術(shù)的定位來找出需要學(xué)習(xí)的重點(diǎn),即它怎么做到(機(jī)制)的和它為什么能這樣做到。列出這個(gè)技術(shù)最常見的應(yīng)用,做為學(xué)習(xí)的任務(wù),從簡(jiǎn)到難進(jìn)行實(shí)踐。

假如我需要學(xué)習(xí)JavaScript,我對(duì)于HTML,CSS有點(diǎn)感性認(rèn)識(shí)。首要要了解的是,JavaScript是Web領(lǐng)域的動(dòng)態(tài)語言,主要解決網(wǎng)頁的動(dòng)態(tài)交互的。那要學(xué)習(xí)的要點(diǎn)如下:

◆JavaScript如何與HTML進(jìn)行交互 (機(jī)制)

◆JavaScript的動(dòng)態(tài)特性在那里,與其它動(dòng)態(tài)語言有何區(qū)別?(語言模型)

如果完全自學(xué),找到需要學(xué)習(xí)的要點(diǎn)(機(jī)制、模型、原理) 設(shè)定學(xué)習(xí)任務(wù)的確不是那么容易把握。如果找到一個(gè)有經(jīng)驗(yàn)的人來指導(dǎo)你或加一個(gè)學(xué)習(xí)型的團(tuán)隊(duì),那學(xué)習(xí)的速度的確會(huì)大大提高。

最后,想對(duì)大家說:PHP因?yàn)楹?jiǎn)單而使用,但不能因?yàn)樗暮?jiǎn)單而限制我們成長(zhǎng)!

原文鏈接:http://bbs.phpchina.com/viewthread.php?tid=197650&rpid=1656910&ordertype=0&page=1#pid1656910

【編輯推薦】

  1. PHP程序員易忽略的PHP精華和技巧
  2. PHP程序員最容易出現(xiàn)的錯(cuò)誤總結(jié)
  3. 架構(gòu)師最怕程序員知道的10件事
  4. PHP批量刪除數(shù)據(jù)減輕程序員壓力
  5. 充滿荊棘的專家程序員之道

 

責(zé)任編輯:王曉東 來源: PHPChina
相關(guān)推薦

2011-05-11 17:49:12

PHP

2019-04-23 10:09:26

職業(yè)程序員架構(gòu)師

2014-10-17 18:31:05

PHP

2017-03-02 09:37:36

PHP程序員成長(zhǎng)規(guī)劃

2009-03-20 10:06:21

程序員PHP職場(chǎng)

2021-07-30 10:41:57

程序員IT互聯(lián)網(wǎng)

2015-08-20 09:31:35

2020-05-12 12:52:21

架構(gòu)菜鳥程序員

2015-10-08 09:53:18

寶德云計(jì)算

2022-08-11 08:18:19

前端程序員

2016-12-26 17:08:30

程序員

2015-08-18 15:22:59

程序員成長(zhǎng)階段

2009-02-24 09:58:45

程序員成長(zhǎng)開竅

2013-03-28 15:50:37

程序員Java

2015-04-03 09:38:32

程序員前人挖坑后人填坑

2016-07-26 13:47:49

程序員新手編程

2018-08-29 12:50:24

程序員

2018-09-06 15:27:45

程序員自我驅(qū)動(dòng)

2012-08-15 10:47:27

2015-04-08 10:57:15

程序員程序員四年經(jīng)歷
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 欧美久久久电影 | 国产在线一区二区三区 | 超碰97免费 | 日本三级网 | 91在线网站| 久久久久久久久99精品 | 欧美日韩久久 | 日韩精品无码一区二区三区 | 亚洲精品久久久一区二区三区 | 97精品国产| 日韩在线小视频 | 狠狠躁天天躁夜夜躁婷婷老牛影视 | 激情网五月天 | 91免费看片| 夜夜草 | 91观看 | 中文一区 | 亚州午夜精品 | 亚洲成人一区二区三区 | 中文字幕欧美在线观看 | 成人黄色三级毛片 | 中文字幕日韩av | 亚洲精品视频网站在线观看 | 日韩一区二区在线视频 | 成人欧美一区二区三区在线播放 | 最新国产精品 | 日本三级在线网站 | 九九综合 | 免费观看一区二区三区毛片 | 日本二区在线观看 | 国产成人综合在线 | .国产精品成人自产拍在线观看6 | 欧美区日韩区 | 天堂av免费观看 | 中文一区二区 | 欧美日韩成人影院 | 欧美综合久久 | 九九导航| 91精品国产色综合久久 | 中文在线a在线 | 久久成人精品一区二区三区 |