當前位置: 首頁>>代碼示例>>Python>>正文


Python Schedule.add_entry_cid方法代碼示例

本文整理匯總了Python中schedule.Schedule.add_entry_cid方法的典型用法代碼示例。如果您正苦於以下問題:Python Schedule.add_entry_cid方法的具體用法?Python Schedule.add_entry_cid怎麽用?Python Schedule.add_entry_cid使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在schedule.Schedule的用法示例。


在下文中一共展示了Schedule.add_entry_cid方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: Provisioner

# 需要導入模塊: from schedule import Schedule [as 別名]
# 或者: from schedule.Schedule import add_entry_cid [as 別名]

#.........這裏部分代碼省略.........
    
    def sync_machines(self):
        slots_addrs = condor_slots()
        running_machines = [m for m in self.machines if m.status == MachineStatus.running]
        allocating_machines = [m for m in self.machines if m.status == MachineStatus.allocating]
        #allocating_machines.sort(key=lambda x: self.schedule.entries_host[x][0].start())
        i = 0
        for (slot,addr) in slots_addrs:
            if slot not in [m.condor_slot for m in running_machines]:
                allocated_machine = None
                if not self.local:
                    allocated_machine = next((m for m in allocating_machines if m.priv_addr == addr), None)
                elif len(allocating_machines[i:]) > 0:
                    # update machine
                    allocated_machine = allocating_machines[i]
                
                if allocated_machine:
                    allocated_machine.status = MachineStatus.running
                    allocated_machine.condor_slot = slot
                    
                    # update entry
                    boot_entry = self.schedule.entries_host[allocated_machine][0]
                    boot_entry.log[LogKey.real_end] = self.timestamp
                    boot_entry.status = EntryStatus.completed
                
                    i += 1
                    print "++Machine", allocated_machine.condor_slot
                else:
                    if next((e for e in self.schedule.entries if e.host.priv_addr == addr and e.status != EntryStatus.completed), None):
                        print "ERROR: slot not found", slot, addr, 'nr', len(running_machines), 'na', len(allocating_machines)
                

    
    def _handle_log_events(self):
        jobs_terminated = False
        log_entries = self.logwatcher.nexts()
        
        for le in log_entries:
            if le.id in self.schedule.entries_cid:
                sched_entry = self.schedule.entries_cid[le.id]
            else:
                sched_entry = next((e for e in self.schedule.entries if e.job.dag_job_id == le.name and e.job.wf_id == le.wf_id), None)
                if sched_entry:
                    sched_entry.condor_id = le.id
                    self.schedule.add_entry_cid(sched_entry)
            if sched_entry:
                sched_entry.log[le.event] = le.timestamp
                
                if le.event == LogKey.execute:
                    sched_entry.status = EntryStatus.executing
            
                elif le.event == LogKey.job_terminated:
                    sched_entry.status = EntryStatus.completed 
                    sched_entry.log[LogKey.real_end] = self.timestamp
                    print "--Job", le.id, sched_entry.job.dag_job_id, sched_entry.host.condor_slot
                    jobs_terminated = True
            else:
                print 'could not find sched_entry for:', le.id
        return jobs_terminated
                
    def _handle_ready_jobs(self):    
        need_condor_resched = False
        idle_cjobs = condor_idle() # idle jobs

        for cjob in idle_cjobs:
            condor_id, wf_id, dag_job_id = cjob.split()
            if condor_id in self.schedule.entries_cid:
                sched_entry = self.schedule.entries_cid[condor_id]
            else:
                sched_entry = next((e for e in self.schedule.entries \
                                    if e.job.dag_job_id == dag_job_id \
                                    and e.job.wf_id == wf_id ), None)
                if sched_entry:
                    sched_entry.condor_id = condor_id
                    self.schedule.add_entry_cid(sched_entry)

            if sched_entry and sched_entry.status == EntryStatus.scheduled \
                    and sched_entry.host.status == MachineStatus.running:
                sched_entry.status = EntryStatus.executing
                sched_entry.log[LogKey.real_start] = self.timestamp
                print "++Job", condor_id, dag_job_id, sched_entry.host.condor_slot
                condor_qedit(condor_id, wf_id, dag_job_id, sched_entry.host.condor_slot)
                need_condor_resched = True

        if need_condor_resched:
            condor_reschedule()

    def update_jobs(self):
        
        # handle log events and check if any job terminated
        self.jobs_terminated = self._handle_log_events() or self.jobs_terminated
        
        # need to update schedule (?)
        if self.last_resched and self.jobs_terminated and \
        ((self.timestamp - self.last_resched).seconds > SCHED_TIMEOUT):
            self.update_schedule()
            self.jobs_terminated = False
        
        # handle jobs that are ready to execute
        self._handle_ready_jobs()
開發者ID:rika,項目名稱:dynamic-provisioning,代碼行數:104,代碼來源:provisioner.py


注:本文中的schedule.Schedule.add_entry_cid方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。