[英]releasing modules with threaded classes and controlling them python
基本上,我正在構建一個具有幾個編號選項供您選擇的應用程序。
它名為main.py ,我為每個可能的選項編寫了獨立模塊,因此我可以單獨運行這些模塊。 現在我寫的這個模塊包含一個線程類。 我執行命令時遇到的一個問題: python mod_keepOnline.py
是它不會將控制權傳遞回終端| AND |。 當我運行模塊通過main.py時 , main.py停止監聽新的選擇。 我知道是因為線程。 我想知道如何“讓線程在生成之后自行管理”。 因此,將控制權從mod_keepOnline.py
到終端或主腳本。
我還希望能夠再次殺死已釋放的線程。
像mod_keepOnline.py -killAll
東西
嗯,這是我的代碼:
###########################################
################## SynBitz.net ############
import threading
import objects
import time
import mechanize
import os
import gb
##########################################
class Class_putOnline (threading.Thread):
def __init__ (self,person,onlineTime):
threading.Thread.__init__ (self)
self.startTime = time.time()
self.alive = True
self.person = person
self.onlineTime = onlineTime
self.firstMessage=True
def run(self):
while(self.alive):
if(self.firstMessage):
print self.person.getInfo() + " SPAWNED ONLINE"
self.firstMessage=False
self.person.login()
time.sleep(300)
self.person.logout()
if((time.time()-self.startTime) > self.onlineTime):
print self.person.getInfo() + " SPAWNED OFFLINE "
self.alive = False
self._Thread__stop()
#########################################
def main():
for line in open(gb.accFile,"r"):
gb.accountList.append(line.rstrip('\n'))
for account in gb.accountList:
gb.accountInfo = account.split('|',4)
browser = mechanize.Browser()
browser.set_handle_robots(False)
browser.set_handle_redirect(True)
browser.set_handle_referer(True)
browser.addheaders = [('User-agent', 'Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.1) Gecko/2008071615 Fedora/3.0.1-1.fc9 Firefox/3.0.1')]
gb.spiderList.append(objects.spider.Bot(gb.accountInfo[0],gb.accountInfo[2],gb.accountInfo[1],gb.accountInfo[3],browser))
if gb.accountInfo[2] not in gb.distros:
gb.distros.append(gb.accountInfo[2])
onlineAccounts = []
for index, acc in enumerate(gb.spiderList):
onlineAccounts.append(Class_putOnline(acc,115200)) # 600*6*8*4= 28800 = 8 uur 3600 test seconds = 1 h (1200 seconds for test time of 20 minutes... )
time.sleep(0.1)
onlineAccounts[index].start()
if __name__ == "__main__":
main()
當我打開到服務器的ssh會話並運行python腳本時,即使我在后台運行它,在關閉會話后它也會死掉。 未連接時如何保持腳本運行?
當我打開到服務器的ssh會話並運行python腳本時,即使我在后台運行它,在關閉會話后它也會死掉。 未連接時如何保持腳本運行?
將其作為cronjob運行,如果需要按需運行腳本,請手動啟動cronjob。
好吧,我是python的新手
我也是。
編輯:快速提示,使用“”“進行長注釋。
例:
“““描述:
這樣既可以做到這一點,又可以做到這一點。 這樣使用它。
“”
我認為:
運行流程時,終端的輸入和輸出將重定向到流程的輸入和輸出。
如果您啟動線程,這將不會對此進行任何更改。 只要兩者都存在,則該過程具有終端輸入和輸出。 您可以做的是將此程序發送到后台(使用control-z)。
如果運行程序,則它具有自己的名稱空間。 您可以導入一個模塊並更改其屬性,但這絕不會在另一個程序中更改該模塊。
如果要有兩個程序,一個在后台運行所有的例行程序(例如,泰森提議的作業),另一個從命令行運行,則需要在這兩個進程之間進行通信。
也許還有其他方法可以繞過流程的邊界,但我不知道它們。
因此,我編寫了一個可以在其中存儲值的模塊。每次直接存儲值時,模塊的狀態都會保存到磁盤。
'''
This is a module with persistent attributes
the attributes of this module are spread all over all instances of this module
To set attributes:
import runningConfiguration
runningConfiguration.x = y
to get attributes:
runningConfiguration.x
'''
import os
import types
import traceback
fn = fileName = fileName = os.path.splitext(__file__)[0] + '.conf'
class RunningConfiguration(types.ModuleType):
fileName = fn
def __init__(self, *args, **kw):
types.ModuleType.__init__(self, *args, **kw)
import sys
sys.modules[__name__] = self
self.load()
def save(self):
import pickle
pickle.dump(self.__dict__, file(self.fileName, 'wb'))
def load(self):
import pickle
try:
dict = pickle.load(file(self.fileName, 'rb'))
except EOFError:
pass
except:
import traceback
traceback.print_exc()
else:
self.__dict__.update(dict)
def __setattr__(self, name, value):
## print 'set', name, value,
l = []
v1 = self.__dict__.get(name, l)
self.__dict__[name] = value
try:
self.save()
## print 'ok'
except:
if v1 is not l:
self.__dict__[name] = v1
raise
def __getattribute__(self, name):
import types
if name in ('__dict__', '__class__','save','load','__setattr__', '__delattr__', 'fileName'):
return types.ModuleType.__getattribute__(self, name)
## print 'get', name
self.load()
l = []
ret = self.__dict__.get(name, l)
if ret is l:
if hasattr(self.__class__, name):
return getattr(self.__class__, name)
if name in globals():
return globals()[name]
raise AttributeError('%s object has no attribute %r' % (self.__class__.__name__, name))
return ret
def __delattr__(self, name):
del self.__dict__[name]
self.save()
RunningConfiguration(__name__)
我將其保存到runningConfiguration.py。
您可以像這樣使用它:
# program1
import runningConfiguration
if not hasattr(runningConfiguration, 'programs'):
runningConfiguration.programs = [] ## variable programs is set
runningConfiguration.programs+= ['program1'] ## list is changed and = is used -> module is saved
這是一個不安全的模塊,不是所有內容都可以保存到其中,而是包含很多內容。 同樣,當兩個模塊同時保存時,第一個寫入的值可能會丟失。
嘗試一下:從兩個不同的程序導入ist,並查看其行為。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.