पायथन फोरेंसिक - मल्टीप्रोसेसिंग समर्थन
सामान्य अपराधों में डिजिटल साक्ष्य के पहाड़ों का विश्लेषण करने के लिए फोरेंसिक विशेषज्ञों को आम तौर पर डिजिटल समाधान लागू करना मुश्किल लगता है। अधिकांश डिजिटल जांच उपकरण सिंगल थ्रेडेड होते हैं और वे एक बार में केवल एक कमांड निष्पादित कर सकते हैं।
इस अध्याय में, हम पाइथन की बहुसंकेतन क्षमताओं पर ध्यान केंद्रित करेंगे, जो सामान्य फोरेंसिक चुनौतियों से संबंधित हो सकती हैं।
बहु
मल्टीप्रोसेसिंग को एक से अधिक प्रक्रिया का समर्थन करने के लिए कंप्यूटर सिस्टम की क्षमता के रूप में परिभाषित किया गया है। मल्टीप्रोसेसिंग का समर्थन करने वाले ऑपरेटिंग सिस्टम कई कार्यक्रमों को समवर्ती रूप से चलाने में सक्षम बनाते हैं।
मल्टीप्रोसेसिंग के विभिन्न प्रकार हैं जैसे कि 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() सिस्टम में प्रक्रियाओं के सेट को सूचीबद्ध करने में मदद करता है।
उत्पादन
हमारा कोड निम्न आउटपुट का उत्पादन करेगा -