Python 信號量的使用

線程中,信號量主要是用來維持有限的資源,使得在必定時間使用該資源的線程只有指定的數量git

# -*- coding:utf-8 -*-
""" Created by FizLin on 2017/07/23/-下午10:59
    mail: https://github.com/Fiz1994
    信號量

    maxconnections = 5
...
pool_sema = BoundedSemaphore(value=maxconnections)
Once spawned, worker threads call the semaphore’s acquire and release methods when they need to connect to the server:

pool_sema.acquire()
conn = connectdb()
... use connection ...
conn.close()
pool_sema.release()


"""
import threading
import time
import random

sites = ["https://www.baidu.com/", "https://github.com/Fiz1994", "https://stackoverflow.com/",
         "https://www.sogou.com/",
         "http://english.sogou.com/?b_o_e=1&ie=utf8&fr=common_index_nav&query="] * 20
sites_index = 0
maxconnections = 2
pool_sema = threading.BoundedSemaphore(value=maxconnections)


def test():
    with pool_sema:
        global sites_index, sites
        url = str(sites[sites_index])
        k = random.randint(10, 20)
        print("爬去: " + url + " 須要時間 : " + str(k))
        sites_index += 1
        # print(url)
        time.sleep(k)
        print('退出 ', url)


for i in range(100):
    threading.Thread(target=test).start()

能夠發現該程序中,永遠只有2個爬蟲是處於活動狀態github

圖片描述

相關文章
相關標籤/搜索