pyspider源碼分析

pyspider代碼結(jié)構(gòu)

主要從以下幾個(gè)模塊看pyspider源碼

  • libs里面的工具類五慈。比如最常用的basehandler 等等。
  • process依溯,scheduler毯炮,resultdb。其中最容易看得是resultdb
  • webui部分肃弟,web如何調(diào)用數(shù)據(jù)庫(kù)的腳本等

debug的一些技巧

pyspider在run.py啟動(dòng)了多個(gè)線程玷室, 多個(gè)線程的debug其實(shí)很麻煩,我們需要根據(jù)上一個(gè)欄目的代碼結(jié)構(gòu)來一個(gè)個(gè)的看笤受。

比如最簡(jiǎn)單的resultdb模塊穷缤,只有一個(gè)result_worker.py文件,看懂了這個(gè)文件箩兽,其實(shí)就看懂了這個(gè)模塊津肛。

class ResultWorker(object):

    """
    do with result
    override this if needed.
    """

    def __init__(self, resultdb, inqueue):
        self.resultdb = resultdb
        self.inqueue = inqueue
        self._quit = False

    def on_result(self, task, result):
        '''Called every result'''
        if not result:
            return
        if 'taskid' in task and 'project' in task and 'url' in task:
            logger.info('result %s:%s %s -> %.30r' % (
                task['project'], task['taskid'], task['url'], result))
            return self.resultdb.save(
                project=task['project'],
                taskid=task['taskid'],
                url=task['url'],
                result=result
            )
        else:
            logger.warning('result UNKNOW -> %.30r' % result)
            return

    def quit(self):
        self._quit = True

    def run(self):
        '''Run loop'''
        logger.info("result_worker starting...")

        while not self._quit:
            try:
                task, result = self.inqueue.get(timeout=1)
                self.on_result(task, result)
            except Queue.Empty as e:
                continue
            except KeyboardInterrupt:
                break
            except AssertionError as e:
                logger.error(e)
                continue
            except Exception as e:
                logger.exception(e)
                continue

        logger.info("result_worker exiting...")


class OneResultWorker(ResultWorker):
    '''Result Worker for one mode, write results to stdout'''
    def on_result(self, task, result):
        '''Called every result'''
        if not result:
            return
        if 'taskid' in task and 'project' in task and 'url' in task:
            logger.info('result %s:%s %s -> %.30r' % (
                task['project'], task['taskid'], task['url'], result))
            print(json.dumps({
                'taskid': task['taskid'],
                'project': task['project'],
                'url': task['url'],
                'result': result,
                'updatetime': time.time()
            }))
        else:
            logger.warning('result UNKNOW -> %.30r' % result)
            return

OneResultWorker不需要看,功能上汗贫,這個(gè)模塊和上面實(shí)現(xiàn)一樣的功能身坐,應(yīng)該是用來單獨(dú)啟動(dòng)的時(shí)候調(diào)用的代碼。同樣的道理落包,很多one開頭的代碼都可以掠過部蛇。

pyspider的各個(gè)模塊的數(shù)據(jù)通過隊(duì)列獲得。

目錄

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末咐蝇,一起剝皮案震驚了整個(gè)濱河市涯鲁,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌有序,老刑警劉巖抹腿,帶你破解...
    沈念sama閱讀 216,496評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異旭寿,居然都是意外死亡警绩,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門盅称,熙熙樓的掌柜王于貴愁眉苦臉地迎上來房蝉,“玉大人僚匆,你說我怎么就攤上這事微渠〈罨茫” “怎么了?”我有些...
    開封第一講書人閱讀 162,632評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵逞盆,是天一觀的道長(zhǎng)檀蹋。 經(jīng)常有香客問我,道長(zhǎng)云芦,這世上最難降的妖魔是什么俯逾? 我笑而不...
    開封第一講書人閱讀 58,180評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮舅逸,結(jié)果婚禮上桌肴,老公的妹妹穿的比我還像新娘。我一直安慰自己琉历,他們只是感情好坠七,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著旗笔,像睡著了一般彪置。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蝇恶,一...
    開封第一講書人閱讀 51,165評(píng)論 1 299
  • 那天拳魁,我揣著相機(jī)與錄音,去河邊找鬼撮弧。 笑死潘懊,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的贿衍。 我是一名探鬼主播授舟,決...
    沈念sama閱讀 40,052評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼舌厨!你這毒婦竟也來了岂却?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,910評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤裙椭,失蹤者是張志新(化名)和其女友劉穎躏哩,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體揉燃,經(jīng)...
    沈念sama閱讀 45,324評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡扫尺,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了炊汤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片正驻。...
    茶點(diǎn)故事閱讀 39,711評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡弊攘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出姑曙,到底是詐尸還是另有隱情襟交,我是刑警寧澤,帶...
    沈念sama閱讀 35,424評(píng)論 5 343
  • 正文 年R本政府宣布伤靠,位于F島的核電站捣域,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏宴合。R本人自食惡果不足惜焕梅,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望卦洽。 院中可真熱鬧贞言,春花似錦、人聲如沸阀蒂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)脂新。三九已至挪捕,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間争便,已是汗流浹背级零。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留滞乙,地道東北人奏纪。 一個(gè)月前我還...
    沈念sama閱讀 47,722評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像斩启,于是被迫代替她去往敵國(guó)和親序调。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容