Mitogen سان جوابي رفتار کي تيز ڪرڻ

ناھي سڀ کان مشهور مان هڪ بڻجي ويو سسٽم جي جوڙجڪ جو انتظام. کان پوء Red Hat پاران خريد ڪيو ويو 2015 ۾ نمبر پروجيڪٽ شرڪت ڪندڙ هزارن کان وڌي ويو ۽ جوابي شايد سڀ کان وڌيڪ استعمال ٿيل مقرري ۽ آرڪيسٽريشن سسٽم بڻجي ويو. ان جي ايپليڪيشنن جو وسيع سلسلو تمام متاثر ڪندڙ آهي.

جوابي ڪم SSH ڪنيڪشن تي ريموٽ ميزبانن ڏانهن. اهو هڪ SSH سيشن کوليندو آهي، لاگ ان ٿئي ٿو، پيٿون ڪوڊ کي نيٽ ورڪ تي نقل ڪري ٿو ۽ ان کي هڪ الڳ عارضي فائل ۾ لکي ٿو. ان کان پوء، هن فائل کي ريموٽ مشين تي هلندو آهي. آپريشن جو هي سڄو سلسلو ڪافي ڊگهو ۽ مشڪل آهي، تنهنڪري ان کي بهتر ڪرڻ جا مختلف طريقا آهن.

انهن طريقن مان هڪ آهي SSH پائپ لائنون جيڪو توهان کي هدايتن تي عمل ڪرڻ لاءِ هڪ SSH سيشن استعمال ڪرڻ جي اجازت ڏئي ٿو، بجاءِ هر ڀيري نئون سيشن کولڻ، جيڪو اسان جو گهڻو وقت بچائي سگهي ٿو. (بس بند ڪرڻ ياد رکو requiretty توهان جي ۾ sudo لاء سيٽنگ /etc/sudoers ريموٽ مشين تي فائل)

اوور ڪلڪ ڪرڻ جو هڪ نئون طريقو جوابي پٿون لائبريري سڏيو ويندو آهي ميتوجن. جيڪڏهن ڪنهن ان جي باري ۾ نه ٻڌو آهي، آئون مختصر طور تي ان جي ڪارڪردگي کي بيان ڪندس. اهو ريموٽ مشين تي پٿون ڪوڊ جي تيزيءَ سان عمل ڪرڻ جي اجازت ڏئي ٿو، ۽ جوابي استعمال جو صرف هڪ مثال آهي. Mitogen ريموٽ مشين تي UNIX پائپ استعمال ڪري ٿو ۽ پيٿون ڪوڊ کي zlib سان ڪمپريس ڪيو ويو ۽ اچار سان سيريل ڪيو ويو. هي ان کي تيزيءَ سان مڪمل ڪرڻ ۾ مدد ڪري ٿو ۽ ٽرئفڪ بچائي ٿو. جيڪڏھن توھان چاھيو ٿا وڌيڪ تفصيلي وضاحت ۾، اھو بھترين آھي ان بابت پڙھڻ لاءِ صفحي تي "اهو ڪيئن ڪم ڪري ٿو". پر اڄ اسان صرف ان ڳالهه تي ڌيان ڏينداسين ته لائبريري جوابي طريقي سان ڪيئن ڪم ڪري ٿي.

Mitogen ڪجھ خاص حالتن ۾ توھان جي جوابي ڪوڊ کي ڪيترائي ڀيرا تيز ڪري سگھي ٿو ۽ خاص طور تي ٽرئفڪ جي استعمال کي گھٽائي سگھي ٿو. اچو ته سڀ کان وڌيڪ مشهور استعمال ڪيسن کي ڏسو ۽ ڏسو ته اهو اسان جي ڪيتري مدد ڪري ٿو.

مان جواب ڏيڻ لاءِ سڀ کان وڌيڪ استعمال ڪريان ٿو: ريموٽ مشين تي ڪنفيگريشن فائلون ٺاهڻ، پيڪيجز انسٽال ڪرڻ، فائلن کي ڪاپي ڪرڻ ۽ ريموٽ مشين تان. شايد توھان وٽ ٻيا مثال آھن - تبصرن ۾ لکو.

اچو ته اچو!

جوابي لاءِ Mitogen ترتيب تمام سادو آهي:
Mitogen لائبريري کي انسٽال ڪريو:

pip install mitogen

ھاڻي ٻه برابر طريقا آھن - يا ته اختيارن کي ترتيب ڏيو ansible.cfg configuration فائل ۾، يا ضروري ماحولي تبديلين کي سيٽ ڪريو.

اچو ته فرض ڪريو ته نصب ٿيل Mitogen جو رستو هوندو /usr/lib/python2.7/site-packages/ansible_mitogen/plugins/strategy. پوءِ:

export ANSIBLE_STRATEGY_PLUGINS=/usr/lib/python2.7/site-packages/ansible_mitogen/plugins/strategy
export ANSIBLE_STRATEGY=mitogen_linear

يا

[defaults]
strategy = mitogen_linear
strategy_plugins = /usr/lib/python2.7/site-packages/ansible_mitogen/plugins/strategy

اچو ته انسٽال ڪريون Ansible virtualenv ۾، Mitogen سان ۽ بغير:

virtualenv mitogen_ansible
./mitogen_ansible/bin/pip install ansible==2.7.10 mitogen
virtualenv pure_ansible
./pure_ansible/bin/pip install ansible==2.7.10

مهرباني ڪري نوٽ ڪريو ته Mitogen 0.2.7 جوابي 2.8 سان ڪم نٿو ڪري (مئي 2019 تائين)

عرف ٺاھڻ:

alias pure-ansible-playbook='$(pwd)/pure_ansible/bin/ansible-playbook'
alias mitogen-ansible-playbook='ANSIBLE_STRATEGY_PLUGINS=$(pwd)/mitogen_ansible/lib/python3.7/site-packages/ansible_mitogen/plugins/strategy ANSIBLE_STRATEGY=mitogen_linear $(pwd)/mitogen_ansible/bin/ansible-playbook'

هاڻي اچو ته هڪ پلي بڪ هلائڻ جي ڪوشش ڪريون جيڪا ريموٽ مشين تي فائلون ٺاهي:

---
- hosts: all
  gather_facts: false
  tasks:
    - name: Create files with copy content module
      copy:
        content: |
          test file {{ item }}
        dest: ~/file_{{ item }}
      with_sequence: start=1 end={{ n }}

۽ اچو ته ان کي 10 فائلون ٺاهڻ لاءِ Mitogen سان ۽ بغير هلون:

time mitogen-ansible-playbook file_creation.yml -i hosts -e n=10 &>/dev/null

real    0m2.603s
user    0m1.152s
sys     0m0.096s

time pure-ansible-playbook file_creation.yml -i hosts -e n=10 &>/dev/null

real    0m5.908s
user    0m1.745s
sys     0m0.643s

اسان ڏسون ٿا 2-گنا سڌارو. اچو ته چيڪ ڪريون 20، 30، ...، 100 فائلون:

time pure-ansible-playbook file_creation.yml -i hosts -e n=100 &>/dev/null

real    0m51.775s
user    0m8.039s
sys     0m6.305s

time mitogen-ansible-playbook file_creation.yml -i hosts -e n=100 &>/dev/null

real    0m4.331s
user    0m1.903s
sys     0m0.197s

نتيجي طور، اسان 10 ڀيرا کان وڌيڪ تيزيء سان عمل درآمد ڪيو!
ھاڻي اچو ته مختلف منظرنامي جي ڪوشش ڪريون ۽ ڏسون ته ڪيترو تيزيءَ سان ھر شيءِ اسان لاءِ ڪم ڪري ٿي.

  • اسڪرپٽ فائلن کي نقل ڪرڻ لاءِ ريموٽ ميزبان کي مقامي مان (ماڊيول سان copy):
    Mitogen سان جوابي رفتار کي تيز ڪرڻ

  • ريموٽ ميزبان تي فائلون ٺاهڻ لاءِ اسڪرپٽ copy ماڊل:
    Mitogen سان جوابي رفتار کي تيز ڪرڻ

  • منظرنامو فائلن کي ڊائون لوڊ ڪرڻ سان گڏ هڪ ريموٽ ميزبان کان مقامي هڪ ڏانهن:
    Mitogen سان جوابي رفتار کي تيز ڪرڻ

اچو ته ڪيترن ئي (3) ريموٽ مشينن سان هڪ منظر آزمائي، مثال طور هڪ منظر جيڪو فائلن کي نقل ڪرڻ سان ريموٽ ميزبان ڏانهن:
Mitogen سان جوابي رفتار کي تيز ڪرڻ

جئين توهان ڏسي سگهو ٿا، Mitogen اسان کي انهن حالتن ۾ وقت ۽ ٽرئفڪ ٻنهي کي بچائيندو آهي. پر جيڪڏهن رڪاوٽ جواب ۾ نه آهي، پر مثال طور هڪ ڊسڪ يا نيٽ ورڪ جي I/O ۾، يا ڪنهن ٻئي هنڌ، پوء اهو اميد ڪرڻ ڏکيو آهي ته Mitogen اسان جي مدد ڪندو.

اچو ته ڪوشش ڪريون هڪ اسڪرپٽ انسٽال ڪرڻ سان پيڪيجز کي انسٽال ڪرڻ سان yum/dnf ۽ python ماڊلز پائپ استعمال ڪندي. پيڪيجز ڪيش ڪيا ويا ته جيئن نيٽ ورڪ جي خرابين تي منحصر نه هجي:

---
- hosts: all
  gather_facts: false
  tasks:
    - name: Install packages
      become: true
      package:
        name:
          - samba
          - httpd
          - nano
          - ruby
        state: present

    - name: Install pip modules
      become: true
      pip:
        name:
          - pytest-split-tests
          - bottle
          - pep8
          - flask
        state: present

Mitogen سان ان کي 12 سيڪنڊ ورتو، ساڳيء طرح ان کان سواء.
پني تي جوابي صفحو لاءِ Mitogen توھان ڏسي سگھوٿا ٻيا معيار ۽ ٽيسٽ. جيئن صفحو چوي ٿو:

Mitogen ماڊل کي تيز نه ٿو ڪري سگهي جڏهن اهو هلندڙ آهي. اهو صرف هن ماڊل جي عمل کي ممڪن طور تي تيز ڪري سگهي ٿو.

تنهن ڪري، اهو ضروري آهي ته توهان جي مقرري ۾ توهان جي رڪاوٽون ڳولڻ ۽ جيڪڏهن اهي جواب ڏيڻ جي سبب آهن، پوء Mitogen توهان کي انهن کي حل ڪرڻ ۾ مدد ڪندي ۽ توهان جي راندين جي ڪتابن جي عمل کي تيز ڪرڻ ۾ مدد ڪندي.

جو ذريعو: www.habr.com

تبصرو شامل ڪريو