पायथन फोरेंसिक - मल्टीप्रोसेसिंग समर्थन

सामान्य अपराधों में डिजिटल साक्ष्य के पहाड़ों का विश्लेषण करने के लिए फोरेंसिक विशेषज्ञों को आम तौर पर डिजिटल समाधान लागू करना मुश्किल लगता है। अधिकांश डिजिटल जांच उपकरण सिंगल थ्रेडेड होते हैं और वे एक बार में केवल एक कमांड निष्पादित कर सकते हैं।

इस अध्याय में, हम पाइथन की बहुसंकेतन क्षमताओं पर ध्यान केंद्रित करेंगे, जो सामान्य फोरेंसिक चुनौतियों से संबंधित हो सकती हैं।

बहु

मल्टीप्रोसेसिंग को एक से अधिक प्रक्रिया का समर्थन करने के लिए कंप्यूटर सिस्टम की क्षमता के रूप में परिभाषित किया गया है। मल्टीप्रोसेसिंग का समर्थन करने वाले ऑपरेटिंग सिस्टम कई कार्यक्रमों को समवर्ती रूप से चलाने में सक्षम बनाते हैं।

मल्टीप्रोसेसिंग के विभिन्न प्रकार हैं जैसे कि symmetric तथा asymmetric processing। निम्न आरेख एक सममित बहुसंकेतन प्रणाली को संदर्भित करता है जिसका आमतौर पर फोरेंसिक जांच में पालन किया जाता है।

उदाहरण

निम्नलिखित कोड दिखाता है कि पायथन प्रोग्रामिंग में आंतरिक रूप से विभिन्न प्रक्रियाओं को कैसे सूचीबद्ध किया गया है।

import random
import multiprocessing

def list_append(count, id, out_list): 
   #appends the count of number of processes which takes place at a time
   for i in range(count):
      out_list.append(random.random())
         
   if __name__ == "__main__": 
      size = 999  
      procs = 2
      # Create a list of jobs and then iterate through 
      # the number of processes appending each process to 
      # the job list  
      jobs = []
         
   for i in range(0, procs): 
      out_list = list() #list of processes 
      process1 = multiprocessing.Process(
         target = list_append, args = (size, i, out_list))

      # appends the list of processes
      jobs.append(process)

   # Calculate the random number of processes
   for j in jobs:
      j.start()  #initiate the process

   # After the processes have finished execution
   for j in jobs:
      j.join()
      print "List processing complete."

यहाँ, समारोह list_append() सिस्टम में प्रक्रियाओं के सेट को सूचीबद्ध करने में मदद करता है।

उत्पादन

हमारा कोड निम्न आउटपुट का उत्पादन करेगा -