Ansible bizkortzea Mitogen-ekin

Ansible ezagunenetako bat bihurtu zen Sistemaren konfigurazioaren kudeaketa. Ondoren Red Hat-ek erosi zuen 2015ean zenbakia proiektuko partaideak milaka gainditu zituen eta Ansible bihurtu zen ziurrenik gehien erabiltzen den hedapen eta orkestrazio sistema. Bere aplikazio sorta zabala oso ikusgarria da.

Ansiblek urruneko ostalarien SSH konexioen bidez funtzionatzen du. SSH saio bat irekitzen du, saioa hasi, Python kodea sarean kopiatzen du eta aparteko aldi baterako fitxategi batean idazten du. Horren ondoren, fitxategi hau urruneko makinan exekutatzen du. Eragiketa-sekuentzia osoa nahiko luzea eta neketsua da, beraz, optimizatzeko hainbat modu daude.

Modu horietako bat da SSH kanalizazioak horri esker, SSH saio bat erabiltzeko argibideak exekutatzeko, saio berri bat aldi bakoitzean ireki beharrean, eta horrek denbora asko aurreztuko digu. (Gogoratu itzali behar duzula requiretty sudo konfiguratzeko zure /etc/sudoers fitxategia urruneko makinan)

Ansible overclock egiteko modu berri bat python liburutegia da Mitogenoa. Inork entzun ez badu, bere funtzionaltasuna labur deskribatuko dut. Python kodea azkar exekutatzeko aukera ematen du urruneko makina batean, eta Ansible erabilera adibide bat besterik ez da. Mitogen-ek UNIX kanalizazioa erabiltzen du urruneko makinan eta zlib-rekin konprimituta eta pickle-rekin seriatuta dagoen python kodea transferitzen du. Horrek azkarrago osatzen laguntzen du eta trafikoa aurrezten du. Azalpen zehatzago bat interesatzen bazaizu, hobe da horri buruz orrialdean irakurtzea "Nola dabil". Baina gaur liburutegiak Ansiblerekin nola funtzionatzen duen aztertuko dugu.

Mitogen-ek zenbait kasutan zure Ansible kodea hainbat aldiz bizkortu dezake eta trafikoaren kontsumoa nabarmen murrizten du. Ikus ditzagun erabilera kasu ezagunenak eta ikus ditzagun zenbat laguntzen digun.

Ansible erabiltzen dut gehien: urruneko makina batean konfigurazio-fitxategiak sortzeko, paketeak instalatzeko, fitxategiak kopiatzeko eta urruneko makinatik. Agian beste adibide batzuk dituzu - idatzi iruzkinetan.

Goazen!

Ansiblerako Mitogen konfigurazioa oso erraza da:
Instalatu Mitogen liburutegia:

pip install mitogen

Orain bi modu baliokide daude: ansible.cfg konfigurazio fitxategiko aukerak konfiguratu edo beharrezko ingurune-aldagaiak ezarri.

Demagun instalatutako Mitogen bidea izango dela /usr/lib/python2.7/site-packages/ansible_mitogen/plugins/strategy. Orduan:

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

edo

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

Instalatu dezagun Ansible virtualenv-en, Mitogenarekin eta gabe:

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

Kontuan izan Mitogen 0.2.7 ez dela Ansible 2.8-rekin funtzionatzen (2019ko maiatzean)

Aliasak egitea:

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'

Orain saia gaitezen urruneko makina batean fitxategiak sortzen dituen playbook bat exekutatzen:

---
- 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 }}

Eta exekutatu dezagun Mitogenekin eta gabe 10 fitxategi sortzeko:

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 aldiz hobekuntza ikusten dugu. Ikus ditzagun 20, 30, ..., 100 fitxategi:

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

Ondorioz, exekuzioa 10 aldiz baino gehiago bizkortu dugu!
Orain proba ditzagun eszenatoki desberdinak eta ikus ditzagun zenbat bizkorrago funtzionatzen duen guztia:

  • Fitxategiak tokiko batetik urruneko ostalari batera kopiatzeko scripta (moduluarekin copy):
    Ansible bizkortzea Mitogen-ekin

  • Urruneko ostalari batean fitxategiak sortzeko script-a copy modulua:
    Ansible bizkortzea Mitogen-ekin

  • Urruneko ostalari batetik tokiko batera fitxategiak deskargatzeko eszenatokia:
    Ansible bizkortzea Mitogen-ekin

Proba dezagun urruneko hainbat (3) makina dituen eszenatoki bat, adibidez, fitxategiak urruneko ostalari batera kopiatzen dituen eszenatoki bat:
Ansible bizkortzea Mitogen-ekin

Ikus dezakezunez, Mitogenek denbora eta trafikoa aurrezten gaitu agertoki hauetan. Baina botila-lepoa Ansible-n ez badago, baina adibidez disko edo sare baten I/O-n edo beste nonbait, zaila da espero Mitogen-ek lagunduko gaituela.

Saia gaitezen yum/dnf eta python moduluekin paketeak instalatzen dituen script bat pip erabiliz. Paketeak cachean gorde ziren sareko akatsen menpe ez egoteko:

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

Mitogenekin 12 segundo behar izan zituen, bera gabe.
Orrialdean Mitogen Ansible orria beste erreferentzia eta proba batzuk begiratu ditzakezu. orrialdeak dioen bezala:

Mitogenek ezin du modulua bizkortu martxan dagoenean. Modulu honen exekuzioa ahalik eta azkarren egin dezake.

Hori dela eta, garrantzitsua da zure inplementazioan zure botila-lepoak aurkitzea eta Ansibleren ondoriozkoak badira, Mitogenek horiek konpontzen lagunduko dizu eta zure liburuen exekuzioa nabarmen azkartzen lagunduko dizu.

Iturria: www.habr.com

Gehitu iruzkin berria