මයිටොජන් සමඟ ඇන්සිබල් වේගවත් කිරීම

පිළිතුරු වඩාත් ජනප්රිය එකක් බවට පත් විය පද්ධති මානකරන කළමනාකරණය. පසු Red Hat විසින් මිලදී ගන්නා ලදී 2015 දී අංකය ව්යාපෘති සහභාගීවන්නන් දහස් ගණනක් ඉක්මවා ගිය අතර Ansible බොහෝ විට වැඩිපුරම භාවිතා කරන ලද යෙදවීම සහ වාද්‍ය වෘන්ද පද්ධතිය බවට පත් විය. එහි පුළුල් පරාසයක යෙදුම් ඉතා ආකර්ෂණීයයි.

Ansible SSH සම්බන්ධතා හරහා දුරස්ථ ධාරක වෙත ක්‍රියා කරයි. එය SSH සැසියක් විවෘත කරයි, ලොග් වී, ජාලය හරහා පයිතන් කේතය පිටපත් කර එය වෙනම තාවකාලික ගොනුවකට ලියයි. ඊට පසු, එය දුරස්ථ යන්ත්රය මත මෙම ගොනුව ධාවනය කරයි. මෙම සමස්ත මෙහෙයුම් අනුපිළිවෙල තරමක් දිගු හා වෙහෙසකර වේ, එබැවින් එය ප්‍රශස්ත කිරීමට විවිධ ක්‍රම තිබේ.

මෙම ක්රමවලින් එකකි SSH නල මාර්ග සෑම අවස්ථාවකදීම නව සැසියක් විවෘත කරනවාට වඩා, උපදෙස් ක්‍රියාත්මක කිරීමට එක් SSH සැසියක් භාවිතා කිරීමට ඔබට ඉඩ සලසයි, එමඟින් අපට බොහෝ කාලයක් ඉතිරි කර ගත හැකිය. (නිවා දැමීමට මතක තබා ගන්න requiretty ඔබේ තුළ sudo සඳහා සැකසීම /etc/sudoers දුරස්ථ යන්ත්‍රයේ ගොනුව)

Ansible overclock කිරීමට නව ක්‍රමයක් නම් python පුස්තකාලයකි මයිටොජන්. කවුරුහරි එය අසා නොමැති නම්, මම එහි ක්රියාකාරිත්වය කෙටියෙන් විස්තර කරමි. එය දුරස්ථ යන්ත්‍රයක පයිතන් කේතය වේගයෙන් ක්‍රියාත්මක කිරීමට ඉඩ සලසයි, සහ ඇන්සිබල් භාවිතයේ එක් උදාහරණයක් පමණි. Mitogen දුරස්ථ යන්ත්‍රය මත UNIX පයිප්පයක් භාවිතා කරන අතර zlib සමඟ සම්පීඩිත සහ අච්චාරු සමඟ අනුක්‍රමික පයිතන් කේතය මාරු කරයි. මෙය වේගයෙන් සම්පූර්ණ කිරීමට සහ ගමනාගමනය ඉතිරි කිරීමට උපකාරී වේ. ඔබ වඩාත් සවිස්තරාත්මක පැහැදිලි කිරීමක් සඳහා උනන්දුවක් දක්වන්නේ නම්, පිටුවේ ඒ ගැන කියවීම වඩාත් සුදුසුය "එය ක්රියා කරන ආකාරය". නමුත් අද අපි අවධානය යොමු කරන්නේ Ansible සමඟ පුස්තකාලය ක්‍රියා කරන ආකාරය ගැන පමණි.

ඇතැම් තත්වයන් තුළ Mitogen ඔබේ Ansible කේතය කිහිප වතාවක් වේගවත් කළ හැකි අතර රථවාහන පරිභෝජනය සැලකිය යුතු ලෙස අඩු කරයි. අපි වඩාත් ජනප්‍රිය භාවිත අවස්ථා පරීක්‍ෂා කර එය අපට කොතරම් උපකාරී වේදැයි බලමු.

මම Ansible බොහෝ විට භාවිතා කරන්නේ: දුරස්ථ යන්ත්‍රයක වින්‍යාස ගොනු නිර්මාණය කිරීම, පැකේජ ස්ථාපනය කිරීම, දුරස්ථ යන්ත්‍රයට සහ ඉන් පිටතට ගොනු පිටපත් කිරීම. සමහර විට ඔබට වෙනත් උදාහරණ තිබේ - අදහස් දැක්වීමේදී ලියන්න.

අපි යමු!

Ansible සඳහා මයිටොජන් වින්‍යාසය ඉතා සරල ය:
Mitogen පුස්තකාලය ස්ථාපනය කරන්න:

pip install mitogen

දැන් සමාන ක්‍රම දෙකක් ඇත - එක්කෝ ansible.cfg වින්‍යාස ගොනුවේ විකල්ප වින්‍යාස කරන්න, නැතහොත් අවශ්‍ය පරිසර විචල්‍යයන් සකසන්න.

ස්ථාපිත 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

Mitogen සමඟ සහ රහිතව Virtualenv හි Ansible ස්ථාපනය කරමු:

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 Ansible 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'

දැන් අපි දුරස්ථ යන්ත්‍රයක ගොනු නිර්මාණය කරන 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):
    මයිටොජන් සමඟ ඇන්සිබල් වේගවත් කිරීම

  • දුරස්ථ ධාරකයක ගොනු සෑදීම සඳහා ස්ක්‍රිප්ට් copy මොඩියුලය:
    මයිටොජන් සමඟ ඇන්සිබල් වේගවත් කිරීම

  • දුරස්ථ ධාරකයක සිට දේශීය එකකට ගොනු බාගැනීමේ අවස්ථාව:
    මයිටොජන් සමඟ ඇන්සිබල් වේගවත් කිරීම

අපි දුරස්ථ යන්ත්‍ර කිහිපයක් (3) සහිත අවස්ථාවක් උත්සාහ කරමු, උදාහරණයක් ලෙස දුරස්ථ ධාරකයකට ලිපිගොනු පිටපත් කිරීමේ අවස්ථාවක්:
මයිටොජන් සමඟ ඇන්සිබල් වේගවත් කිරීම

ඔබට පෙනෙන පරිදි, Mitogen මෙම අවස්ථා වලදී අපට කාලය සහ ගමනාගමනය යන දෙකම ඉතිරි කරයි. නමුත් බාධකය Ansible හි නොවේ නම්, උදාහරණයක් ලෙස තැටියක හෝ ජාලයක I/O හෝ වෙනත් ස්ථානයක නම්, Mitogen අපට උපකාර කරනු ඇතැයි අපේක්ෂා කිරීම අපහසුය.

අපි pip භාවිතයෙන් 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 ක් ගත විය, එය නොමැතිව සමාන වේ.
පිටුවේ Ansible පිටුව සඳහා Mitogen ඔබට වෙනත් මිණුම් සලකුණු සහ පරීක්ෂණ දෙස බැලිය හැකිය. පිටුවේ සඳහන් පරිදි:

මයිටොජන් මොඩියුලය ක්‍රියාත්මක වන විට එය වේගවත් කළ නොහැක. එය කළ හැක්කේ මෙම මොඩියුලය ක්‍රියාත්මක කිරීම හැකි තරම් වේගවත් කිරීම පමණි.

එමනිසා, ඔබගේ යෙදවීමේදී ඔබගේ බාධාවන් සොයා ගැනීම වැදගත් වන අතර ඒවා Ansible නිසා සිදුවුවහොත්, Mitogen ඔබට ඒවා විසඳීමට සහ ඔබේ ක්‍රීඩා පොත් ක්‍රියාත්මක කිරීම සැලකිය යුතු ලෙස වේගවත් කිරීමට උපකාරී වනු ඇත.

මූලාශ්රය: www.habr.com

අදහස් එක් කරන්න