Dockeri ja virtuaalmasinate tutvustus
Docker ja virtuaalmasinad (VM-id) on mõlemad populaarsed tööriistad rakenduste juurutamiseks, kuid need töötavad põhimõtteliselt erineval viisil. Paljud arendajad on hämmingus, kuidas Docker suudab pakkuda täielikku failisüsteemi, isoleeritud võrku ja muid funktsioone ilma VM-idega tavaliselt seotud lisakuludeta.
Selle artikli eesmärk on selgitada erinevusi Dockeri ja traditsiooniliste virtuaalmasinate vahel, selgitades, miks Dockerit peetakse sageli kergemaks ja tarkvara juurutamiseks lihtsamaks. Uurime Dockeri tootmiskeskkondades kasutamise aluseks olevaid tehnoloogiaid ja praktilisi eeliseid.
Käsk | Kirjeldus |
---|---|
FROM | Määrab Dockeri konteineri loomiseks kasutatava põhipildi. |
WORKDIR | Määrab töökataloogi Dockeri konteineris. |
COPY | Kopeerib failid või kataloogid hostmasinast Dockeri konteinerisse. |
RUN | Käitab koostamisprotsessi ajal Dockeri konteineris käsu. |
EXPOSE | Teatab Dockerile, et konteiner kuulab käitusajal määratud võrguporte. |
CMD | Määrab käsu, mis käivitatakse Dockeri konteineris selle käivitamisel. |
config.vm.box | Määrab Vagranti virtuaalmasina jaoks kasutatava põhikasti. |
config.vm.network | Konfigureerib võrgusätted, näiteks pordide edastamine hostist VM-i. |
config.vm.provision | Määrab, kuidas virtuaalmasinat ette valmistada, näiteks käitada shelliskripte häälestuse ajal. |
Dockerfile'i ja Vagrantfile'i uurimine
Esitatud näidetes demonstreerisime esmalt, kuidas luua Docker-fail Node.js-i rakenduse juurutamiseks. Dockerfile algab põhipildi määramisega FROM käsuga, kasutades antud juhul ametlikku Node.js käituskeskkonda. Töökataloogi seadistamine konteineris saavutatakse rakendusega WORKDIR käsk, mis tagab järgnevate käskude täitmise määratud kataloogis. The COPY käsku kasutatakse package.json-failide ja rakenduse koodi ülekandmiseks konteinerisse. The RUN käsk installib seejärel konteinerisse vajalikud sõltuvused. Avaldame pordi, millel rakendus töötab, kasutades EXPOSE käsk ja lõpuks CMD käsk määrab käsu rakenduse käivitamiseks konteineri käivitumisel.
Vagrantfile'i näite puhul algab konfigureerimine põhikasti määramisega config.vm.box käsk, kasutades siin Ubuntu 20.04. Võrgusätted konfigureeritakse kasutades config.vm.network käsk, mis edastab hosti pordi 8080 külalis-VM-i porti 80, võimaldades välist juurdepääsu VM-is töötavatele teenustele. The config.vm.provision käsku kasutatakse shelliskripti käitamiseks, mis värskendab pakettide loendit ja installib Apache2, varustades VM-i vajaliku tarkvaraga. Need käsud näitavad VM-i keskkonna seadistamise põhietappe, pakkudes traditsioonilisemat lähenemist võrreldes Dockeri pakutava konteinerkeskkonnaga.
Dockeri faili loomine Node.js-i rakenduse juurutamiseks
See näide demonstreerib, kuidas luua Node.js-i rakenduse jaoks Docker-fail, tutvustades Dockeri konteineris rakenduse loomise ja käitamise samme.
# Use an official Node.js runtime as a parent image
FROM node:14
# Set the working directory inside the container
WORKDIR /usr/src/app
# Copy package.json and package-lock.json to the container
COPY package*.json ./
# Install the application dependencies inside the container
RUN npm install
# Copy the rest of the application code to the container
COPY . .
# Expose the port the app runs on
EXPOSE 8080
# Define the command to run the app
CMD ["node", "app.js"]
Virtuaalse masina seadistamine Vagranti abil
See näide näitab, kuidas seadistada virtuaalmasinat Vagranti abil lihtsa Vagrantfaili abil, demonstreerides VM-i keskkonna määratlemise ja konfigureerimise protsessi.
# -*- mode: ruby -*-
# vi: set ft=ruby :
# All Vagrant configuration is done below. The "2" in Vagrant.configure
# configures the configuration version (we support older styles for
# backwards compatibility). Please don't change it unless you know what
# you're doing.
Vagrant.configure("2") do |config|
# Use Ubuntu 20.04 as the base box
config.vm.box = "ubuntu/focal64"
# Forward port 8080 on the host to port 80 on the guest
config.vm.network "forwarded_port", guest: 80, host: 8080
# Provision the VM with a shell script
config.vm.provision "shell", inline: <<-SHELL
sudo apt-get update
sudo apt-get install -y apache2
SHELL
end
Dockeri ja virtuaalmasinate mõistmine
Üks peamisi erinevusi Dockeri ja virtuaalmasinate (VM) vahel seisneb selles, kuidas nad kasutavad süsteemiressursse. VM-id töötavad hüperviisoril, mis emuleerib riistvara ja võimaldab hostmasinas korraga töötada mitmel operatsioonisüsteemil. See nõuab, et iga VM sisaldaks täielikku külalisoperatsioonisüsteemi, oma teeke ja binaarfaile. See mitte ainult ei tarbi märkimisväärseid süsteemiressursse, vaid suurendab ka juurutamise ja hoolduse üldist suurust ja keerukust.
Seevastu Docker kasutab konteineriseerimistehnoloogiat, mis võimaldab mitmel konteineril jagada sama operatsioonisüsteemi tuuma. Iga konteiner töötab kasutajaruumis isoleeritud protsessina. See tähendab, et konteinerid on VM-idega võrreldes palju kergemad ja kiiremini käivitatavad, kuna need ei pea kogu OS-i käivitama. Docker saavutab failisüsteemi isoleerimise kihilise failisüsteemi kaudu, kus igal konteineril on põhipildi peal oma failisüsteemi kiht. Võrgu eraldamist käsitletakse nimeruumide abil, mis võimaldab Dockeril pakkuda iga konteineri jaoks isoleeritud võrgukeskkondi ilma VM-idega seotud lisakuludeta.
Korduma kippuvad küsimused Dockeri ja virtuaalmasinate kohta
- Mis on peamine erinevus Dockeri ja VM-ide vahel?
- Docker kasutab host-OS-i tuuma jagamiseks konteineriseerimist, muutes selle kergemaks ja kiiremaks, samas kui virtuaalsed masinad nõuavad täielikku külalis-OS-i ja hüperviisorit.
- Miks peetakse Dockeri konteinereid tõhusamaks?
- Konteinerid jagavad host-OS-i tuuma ja neil on minimaalne üldkulu, mis võimaldab kiiremat käivitusaega ja tõhusat ressursside kasutamist.
- Kuidas Docker saavutab failisüsteemi isoleerimise?
- Docker kasutab kihilist failisüsteemi, kus igal konteineril on põhipildi peal oma failisüsteemi kiht.
- Mis on hüperviisor VM-ide kontekstis?
- Hüpervisor on tarkvara, mis emuleerib riistvara, võimaldades mitmel operatsioonisüsteemil samaaegselt töötada ühes hostmasinas.
- Kuidas Docker võrguisolatsiooniga toime tuleb?
- Docker kasutab iga konteineri jaoks eraldatud võrgukeskkonna pakkumiseks nimeruume.
- Miks on tarkvara juurutamine Dockeri kujutisele lihtsam kui virtuaalmasinale?
- Dockeri kujutised hõlmavad kõiki sõltuvusi ja konfiguratsioone, tagades järjepidevuse erinevates keskkondades.
- Millised on Dockeri levinumad kasutusjuhud?
- Dockerit kasutatakse tavaliselt mikroteenuste arhitektuuri, pideva integreerimise/pideva juurutamise (CI/CD) ja isoleeritud arenduskeskkondade jaoks.
- Kas Dockeri konteinerid saavad töötada mis tahes operatsioonisüsteemiga?
- Dockeri konteinerid võivad töötada mis tahes operatsioonisüsteemis, mis toetab Dockerit, kuid nad jagavad host-OS-i tuuma.
- Mis on Dockeri põhipilt?
- Baaspilt on Dockeri konteinerite loomise lähtepunkt, mis sisaldab sageli OS-i ja põhilisi sõltuvusi.
Docker vs. Virtual Machines kokkuvõte
Dockeri ja virtuaalmasinate võrdlemisel seisneb peamine erinevus nende ressursside kasutamises ja juurutamise tõhususes. Virtuaalmasinad töötavad täieliku külalisoperatsioonisüsteemi ja hüperviisoriga, mis toob kaasa suurema ressursikulu. Seevastu Dockeri konteinerid jagavad host OS-i tuuma, mille tulemuseks on kergem ja paindlikum lahendus. Docker saavutab isoleeritud keskkonnad kihilise failisüsteemi ja võrgunimeruumide kaudu, võimaldades tal pakkuda virtuaalse masinaga sarnaseid funktsioone ilma sellega seotud üldkuludeta. See muudab tarkvara juurutamise Dockeri piltidele tõhusamaks, järjepidevamaks ja erinevates tootmiskeskkondades hõlpsamini hallatavaks.
Viimased mõtted Dockeri ja virtuaalmasinate kohta
Kokkuvõtteks võib öelda, et Dockeri konteineriseerimise kasutamine pakub traditsiooniliste virtuaalmasinate ees märkimisväärse eelise, minimeerides ressursikasutuse ja lihtsustades juurutusprotsesse. Jagades host OS-i tuuma ning kasutades isoleeritud failisüsteeme ja võrku, pakub Docker jõulist, kuid kerget lahendust tänapäevaseks rakenduste juurutamiseks. Nende erinevuste mõistmine võib aidata arendajatel valida nende vajadustele vastava õige tööriista, tagades tõhusa ja skaleeritava rakenduste haldamise.