Python多并发访问网站

来源:互联网 发布:软件著作权申请流程图 编辑:程序博客网 时间:2024/06/14 11:35

Python多并发访问网站

# Filename:visitweb_threads.py# Description:python visit web, get startTime, endTime, everytimes spentTime,threadingimport threadingimport urllib             import timeimport datetimeprint 'num       web             SpentTime'def Process(url,n):    minSpan = 0.0    maxSpan = 0.0    sumSpan= 0.0    over1s = 0    file = open('data.txt','a')  # save Data    for i in range(n):        startTime =datetime.datetime.now()        try:            urlItem = urllib.urlopen(url)            htmSource = urlItem.read()            urlItem.close()        except:            pass        endTime = datetime.datetime.now()        span = (endTime-startTime).total_seconds()        sumSpan = sumSpan + span        if span < minSpan:            minSpan = span        if span > maxSpan:            maxSpan = span        if span>1:            over1s=over1s + 1        print(u'%4d %s Spent:%7s seconds'%(i,url,span))        file.write(u'%4d %s ST:%s ET:%s Spent :%s seconds\n'%(i,url,startTime,endTime,span))    file.write('\n')    print(u'\n requested:%s times\n Total Spent:%s seconds\n avg:%s seconds\n max:%s seconds\n min:%s seconds\n over 1 secnod:%s times\n'%(n,sumSpan,sumSpan/n,maxSpan,minSpan,over1s))    file.write(u' requested:%s times\n Total Spent:%s seconds\n avg:%s seconds\n max:%s seconds\n min:%s seconds\n over 1 secnod:%s times\n'%(n,sumSpan,sumSpan/n,maxSpan,minSpan,over1s))    file.close()class ThreadClass(threading.Thread):    def run(self):        now = datetime.datetime.now()        print "%s says Hello World at time: %s" % (self.getName(), now)        file = open('threads_data.txt','a') # save threads_data        file.write( "%s says Hello World at time: %s\n" % (self.getName(), now))        Process('http://222.20.6.184/main.aspx',10)  # visit website 网站的Url和每个进程的访问次数        now = datetime.datetime.now()        print "%s says Goodbye at time: %s" % (self.getName(), now)        file.write( "%s says Goodbye at time: %s\n" % (self.getName(), now))        file.close()if __name__=='__main__':#    file = open('threads_data.txt','w')#    file.close()#    file = open('data.txt','w')#    file.close()    for i in range(1000): # 多少次同时并发访问        t = ThreadClass()        t.start()


0 0
原创粉丝点击