ਡੌਕਰ ਅਤੇ ਵਰਚੁਅਲ ਮਸ਼ੀਨਾਂ ਦੀ ਜਾਣ-ਪਛਾਣ
ਡੌਕਰ ਅਤੇ ਵਰਚੁਅਲ ਮਸ਼ੀਨਾਂ (VMs) ਐਪਲੀਕੇਸ਼ਨਾਂ ਨੂੰ ਤੈਨਾਤ ਕਰਨ ਲਈ ਦੋਵੇਂ ਪ੍ਰਸਿੱਧ ਟੂਲ ਹਨ, ਪਰ ਉਹ ਬੁਨਿਆਦੀ ਤੌਰ 'ਤੇ ਵੱਖਰੇ ਤਰੀਕਿਆਂ ਨਾਲ ਕੰਮ ਕਰਦੇ ਹਨ। ਬਹੁਤ ਸਾਰੇ ਡਿਵੈਲਪਰ ਆਪਣੇ ਆਪ ਨੂੰ ਇਸ ਗੱਲ ਤੋਂ ਉਲਝਣ ਵਿੱਚ ਪਾਉਂਦੇ ਹਨ ਕਿ ਕਿਵੇਂ ਡੌਕਰ ਇੱਕ ਸੰਪੂਰਨ ਫਾਈਲ ਸਿਸਟਮ, ਅਲੱਗ-ਥਲੱਗ ਨੈਟਵਰਕਿੰਗ, ਅਤੇ ਹੋਰ ਵਿਸ਼ੇਸ਼ਤਾਵਾਂ ਪ੍ਰਦਾਨ ਕਰ ਸਕਦਾ ਹੈ ਬਿਨਾਂ ਓਵਰਹੈੱਡ ਦੇ ਆਮ ਤੌਰ 'ਤੇ VMs ਨਾਲ ਜੁੜੇ।
ਇਸ ਲੇਖ ਦਾ ਉਦੇਸ਼ ਡੌਕਰ ਅਤੇ ਰਵਾਇਤੀ ਵਰਚੁਅਲ ਮਸ਼ੀਨਾਂ ਵਿਚਕਾਰ ਅੰਤਰ ਨੂੰ ਸਪੱਸ਼ਟ ਕਰਨਾ ਹੈ, ਇਹ ਦੱਸਣਾ ਕਿ ਡੌਕਰ ਨੂੰ ਅਕਸਰ ਸੌਫਟਵੇਅਰ ਦੀ ਤਾਇਨਾਤੀ ਲਈ ਵਧੇਰੇ ਹਲਕਾ ਅਤੇ ਆਸਾਨ ਕਿਉਂ ਮੰਨਿਆ ਜਾਂਦਾ ਹੈ। ਅਸੀਂ ਅੰਡਰਲਾਈੰਗ ਤਕਨਾਲੋਜੀਆਂ ਅਤੇ ਉਤਪਾਦਨ ਵਾਤਾਵਰਣਾਂ ਵਿੱਚ ਡੌਕਰ ਦੀ ਵਰਤੋਂ ਕਰਨ ਦੇ ਵਿਹਾਰਕ ਲਾਭਾਂ ਦੀ ਖੋਜ ਕਰਾਂਗੇ।
ਹੁਕਮ | ਵਰਣਨ |
---|---|
FROM | ਇੱਕ ਡੌਕਰ ਕੰਟੇਨਰ ਬਣਾਉਣ ਲਈ ਵਰਤਣ ਲਈ ਅਧਾਰ ਚਿੱਤਰ ਨੂੰ ਨਿਸ਼ਚਿਤ ਕਰਦਾ ਹੈ। |
WORKDIR | ਡੌਕਰ ਕੰਟੇਨਰ ਦੇ ਅੰਦਰ ਕੰਮ ਕਰਨ ਵਾਲੀ ਡਾਇਰੈਕਟਰੀ ਸੈੱਟ ਕਰਦਾ ਹੈ। |
COPY | ਹੋਸਟ ਮਸ਼ੀਨ ਤੋਂ ਫਾਈਲਾਂ ਜਾਂ ਡਾਇਰੈਕਟਰੀਆਂ ਨੂੰ ਡੌਕਰ ਕੰਟੇਨਰ ਵਿੱਚ ਕਾਪੀ ਕਰਦਾ ਹੈ। |
RUN | ਬਿਲਡ ਪ੍ਰਕਿਰਿਆ ਦੌਰਾਨ ਡੌਕਰ ਕੰਟੇਨਰ ਵਿੱਚ ਇੱਕ ਕਮਾਂਡ ਚਲਾਉਂਦੀ ਹੈ। |
EXPOSE | ਡੌਕਰ ਨੂੰ ਸੂਚਿਤ ਕਰਦਾ ਹੈ ਕਿ ਕੰਟੇਨਰ ਰਨਟਾਈਮ 'ਤੇ ਨਿਰਧਾਰਤ ਨੈੱਟਵਰਕ ਪੋਰਟਾਂ 'ਤੇ ਸੁਣਦਾ ਹੈ। |
CMD | ਜਦੋਂ ਇਹ ਸ਼ੁਰੂ ਹੁੰਦਾ ਹੈ ਤਾਂ ਡੌਕਰ ਕੰਟੇਨਰ ਦੇ ਅੰਦਰ ਚਲਾਉਣ ਲਈ ਕਮਾਂਡ ਨਿਰਧਾਰਤ ਕਰਦਾ ਹੈ। |
config.vm.box | ਵੈਗਰੈਂਟ ਵਰਚੁਅਲ ਮਸ਼ੀਨ ਲਈ ਵਰਤਣ ਲਈ ਅਧਾਰ ਬਾਕਸ ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਕਰਦਾ ਹੈ। |
config.vm.network | ਨੈੱਟਵਰਕ ਸੈਟਿੰਗਾਂ ਨੂੰ ਕੌਂਫਿਗਰ ਕਰਦਾ ਹੈ, ਜਿਵੇਂ ਕਿ ਹੋਸਟ ਤੋਂ VM ਤੱਕ ਪੋਰਟਾਂ ਨੂੰ ਅੱਗੇ ਭੇਜਣਾ। |
config.vm.provision | ਦੱਸਦਾ ਹੈ ਕਿ ਵਰਚੁਅਲ ਮਸ਼ੀਨ ਦਾ ਪ੍ਰਬੰਧ ਕਿਵੇਂ ਕਰਨਾ ਹੈ, ਜਿਵੇਂ ਕਿ ਸੈੱਟਅੱਪ ਦੌਰਾਨ ਸ਼ੈੱਲ ਸਕ੍ਰਿਪਟਾਂ ਨੂੰ ਚਲਾਉਣਾ। |
ਡੌਕਰਫਾਈਲ ਅਤੇ ਵੈਗ੍ਰੈਂਟਫਾਈਲ ਦੀ ਪੜਚੋਲ ਕੀਤੀ ਜਾ ਰਹੀ ਹੈ
ਪ੍ਰਦਾਨ ਕੀਤੀਆਂ ਉਦਾਹਰਣਾਂ ਵਿੱਚ, ਅਸੀਂ ਪਹਿਲਾਂ ਦਿਖਾਇਆ ਕਿ ਇੱਕ Node.js ਐਪਲੀਕੇਸ਼ਨ ਨੂੰ ਤੈਨਾਤ ਕਰਨ ਲਈ ਇੱਕ ਡੌਕਰਫਾਈਲ ਕਿਵੇਂ ਬਣਾਈਏ। ਡੌਕਰਫਾਈਲ ਬੇਸ ਈਮੇਜ਼ ਨੂੰ ਨਾਲ ਨਿਸ਼ਚਿਤ ਕਰਕੇ ਸ਼ੁਰੂ ਹੁੰਦੀ ਹੈ ਕਮਾਂਡ, ਇਸ ਕੇਸ ਵਿੱਚ, ਇੱਕ ਅਧਿਕਾਰਤ Node.js ਰਨਟਾਈਮ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ. ਕੰਟੇਨਰ ਦੇ ਅੰਦਰ ਕੰਮ ਕਰਨ ਵਾਲੀ ਡਾਇਰੈਕਟਰੀ ਨੂੰ ਸੈੱਟ ਕਰਨ ਨਾਲ ਪ੍ਰਾਪਤ ਕੀਤਾ ਜਾਂਦਾ ਹੈ ਕਮਾਂਡ, ਜੋ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ ਕਿ ਅਗਲੀਆਂ ਕਮਾਂਡਾਂ ਨਿਰਧਾਰਤ ਡਾਇਰੈਕਟਰੀ ਵਿੱਚ ਚਲਾਈਆਂ ਗਈਆਂ ਹਨ। ਦ ਕਮਾਂਡ ਦੀ ਵਰਤੋਂ package.json ਫਾਈਲਾਂ ਅਤੇ ਐਪਲੀਕੇਸ਼ਨ ਕੋਡ ਨੂੰ ਕੰਟੇਨਰ ਵਿੱਚ ਟ੍ਰਾਂਸਫਰ ਕਰਨ ਲਈ ਕੀਤੀ ਜਾਂਦੀ ਹੈ। ਦ RUN ਕਮਾਂਡ ਫਿਰ ਕੰਟੇਨਰ ਦੇ ਅੰਦਰ ਲੋੜੀਂਦੀ ਨਿਰਭਰਤਾ ਨੂੰ ਸਥਾਪਿਤ ਕਰਦੀ ਹੈ। ਅਸੀਂ ਉਸ ਪੋਰਟ ਦਾ ਪਰਦਾਫਾਸ਼ ਕਰਦੇ ਹਾਂ ਜਿਸਦੀ ਵਰਤੋਂ ਕਰਕੇ ਐਪਲੀਕੇਸ਼ਨ ਚਲਦੀ ਹੈ ਕਮਾਂਡ, ਅਤੇ ਅੰਤ ਵਿੱਚ, the ਕਮਾਂਡ ਕੰਟੇਨਰ ਸ਼ੁਰੂ ਹੋਣ 'ਤੇ ਐਪਲੀਕੇਸ਼ਨ ਨੂੰ ਚਲਾਉਣ ਲਈ ਕਮਾਂਡ ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਕਰਦੀ ਹੈ।
Vagrantfile ਉਦਾਹਰਨ ਲਈ, ਸੰਰਚਨਾ ਬੇਸ ਬਾਕਸ ਨੂੰ ਨਾਲ ਨਿਸ਼ਚਿਤ ਕਰਕੇ ਸ਼ੁਰੂ ਹੁੰਦੀ ਹੈ ਕਮਾਂਡ, ਇੱਥੇ ਉਬੰਟੂ 20.04 ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ. ਨੈੱਟਵਰਕ ਸੈਟਿੰਗਾਂ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਸੰਰਚਿਤ ਕੀਤਾ ਗਿਆ ਹੈ ਕਮਾਂਡ, ਜੋ ਕਿ ਹੋਸਟ 'ਤੇ ਪੋਰਟ 8080 ਨੂੰ ਗਿਸਟ VM 'ਤੇ ਪੋਰਟ 80 'ਤੇ ਅੱਗੇ ਭੇਜਦੀ ਹੈ, VM 'ਤੇ ਚੱਲ ਰਹੀਆਂ ਸੇਵਾਵਾਂ ਤੱਕ ਬਾਹਰੀ ਪਹੁੰਚ ਦੀ ਆਗਿਆ ਦਿੰਦੀ ਹੈ। ਦ ਕਮਾਂਡ ਦੀ ਵਰਤੋਂ ਸ਼ੈੱਲ ਸਕ੍ਰਿਪਟ ਨੂੰ ਚਲਾਉਣ ਲਈ ਕੀਤੀ ਜਾਂਦੀ ਹੈ ਜੋ ਪੈਕੇਜ ਸੂਚੀ ਨੂੰ ਅੱਪਡੇਟ ਕਰਦੀ ਹੈ ਅਤੇ Apache2 ਨੂੰ ਇੰਸਟਾਲ ਕਰਦੀ ਹੈ, VM ਨੂੰ ਲੋੜੀਂਦੇ ਸੌਫਟਵੇਅਰ ਨਾਲ ਪ੍ਰੋਵਿਜ਼ਨ ਕਰਦੀ ਹੈ। ਇਹ ਕਮਾਂਡਾਂ ਇੱਕ VM ਵਾਤਾਵਰਣ ਸਥਾਪਤ ਕਰਨ ਲਈ ਬੁਨਿਆਦੀ ਕਦਮਾਂ ਦਾ ਪ੍ਰਦਰਸ਼ਨ ਕਰਦੀਆਂ ਹਨ, ਡੌਕਰ ਦੁਆਰਾ ਪ੍ਰਦਾਨ ਕੀਤੇ ਗਏ ਕੰਟੇਨਰਾਈਜ਼ਡ ਵਾਤਾਵਰਣ ਦੀ ਤੁਲਨਾ ਵਿੱਚ ਵਧੇਰੇ ਰਵਾਇਤੀ ਪਹੁੰਚ ਦੀ ਪੇਸ਼ਕਸ਼ ਕਰਦੀਆਂ ਹਨ।
Node.js ਐਪਲੀਕੇਸ਼ਨ ਡਿਪਲਾਇਮੈਂਟ ਲਈ ਇੱਕ ਡੌਕਰਫਾਈਲ ਬਣਾਉਣਾ
ਇਹ ਉਦਾਹਰਨ ਦਰਸਾਉਂਦੀ ਹੈ ਕਿ ਇੱਕ Node.js ਐਪਲੀਕੇਸ਼ਨ ਲਈ ਇੱਕ ਡੌਕਰਫਾਈਲ ਕਿਵੇਂ ਬਣਾਈ ਜਾਵੇ, ਇੱਕ ਡੌਕਰ ਕੰਟੇਨਰ ਦੇ ਅੰਦਰ ਐਪ ਨੂੰ ਬਣਾਉਣ ਅਤੇ ਚਲਾਉਣ ਦੇ ਕਦਮਾਂ ਨੂੰ ਪ੍ਰਦਰਸ਼ਿਤ ਕਰਦਾ ਹੈ।
# 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"]
ਵੈਗਰੈਂਟ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਇੱਕ ਵਰਚੁਅਲ ਮਸ਼ੀਨ ਸਥਾਪਤ ਕਰਨਾ
ਇਹ ਉਦਾਹਰਨ ਦਿਖਾਉਂਦਾ ਹੈ ਕਿ ਇੱਕ ਸਧਾਰਨ Vagrantfile ਨਾਲ Vagrant ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ ਇੱਕ ਵਰਚੁਅਲ ਮਸ਼ੀਨ ਨੂੰ ਕਿਵੇਂ ਸੈੱਟ ਕਰਨਾ ਹੈ, ਇੱਕ VM ਵਾਤਾਵਰਣ ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਅਤੇ ਸੰਰਚਿਤ ਕਰਨ ਦੀ ਪ੍ਰਕਿਰਿਆ ਦਾ ਪ੍ਰਦਰਸ਼ਨ ਕਰਦਾ ਹੈ।
# -*- 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
ਡੌਕਰ ਅਤੇ ਵਰਚੁਅਲ ਮਸ਼ੀਨਾਂ ਨੂੰ ਸਮਝਣਾ
ਡੌਕਰ ਅਤੇ ਵਰਚੁਅਲ ਮਸ਼ੀਨਾਂ (VMs) ਵਿਚਕਾਰ ਮੁੱਖ ਅੰਤਰਾਂ ਵਿੱਚੋਂ ਇੱਕ ਇਹ ਹੈ ਕਿ ਉਹ ਸਿਸਟਮ ਸਰੋਤਾਂ ਦੀ ਵਰਤੋਂ ਕਿਵੇਂ ਕਰਦੇ ਹਨ। VMs ਇੱਕ ਹਾਈਪਰਵਾਈਜ਼ਰ 'ਤੇ ਚੱਲਦੇ ਹਨ, ਜੋ ਹਾਰਡਵੇਅਰ ਦੀ ਨਕਲ ਕਰਦਾ ਹੈ ਅਤੇ ਮਲਟੀਪਲ ਓਪਰੇਟਿੰਗ ਸਿਸਟਮਾਂ ਨੂੰ ਇੱਕ ਹੋਸਟ ਮਸ਼ੀਨ 'ਤੇ ਇੱਕੋ ਸਮੇਂ ਚਲਾਉਣ ਦੀ ਆਗਿਆ ਦਿੰਦਾ ਹੈ। ਇਸ ਲਈ ਹਰੇਕ VM ਨੂੰ ਇੱਕ ਪੂਰਾ ਗੈਸਟ ਓਪਰੇਟਿੰਗ ਸਿਸਟਮ, ਲਾਇਬ੍ਰੇਰੀਆਂ ਦਾ ਆਪਣਾ ਸੈੱਟ, ਅਤੇ ਬਾਈਨਰੀਆਂ ਸ਼ਾਮਲ ਕਰਨ ਦੀ ਲੋੜ ਹੁੰਦੀ ਹੈ। ਇਹ ਨਾ ਸਿਰਫ਼ ਮਹੱਤਵਪੂਰਨ ਸਿਸਟਮ ਸਰੋਤਾਂ ਦੀ ਖਪਤ ਕਰਦਾ ਹੈ ਬਲਕਿ ਤੈਨਾਤੀ ਅਤੇ ਰੱਖ-ਰਖਾਅ ਦੇ ਸਮੁੱਚੇ ਆਕਾਰ ਅਤੇ ਜਟਿਲਤਾ ਨੂੰ ਵੀ ਵਧਾਉਂਦਾ ਹੈ।
ਇਸ ਦੇ ਉਲਟ, ਡੌਕਰ ਕੰਟੇਨਰਾਈਜ਼ੇਸ਼ਨ ਤਕਨਾਲੋਜੀ ਦਾ ਲਾਭ ਲੈਂਦਾ ਹੈ, ਜੋ ਮਲਟੀਪਲ ਕੰਟੇਨਰਾਂ ਨੂੰ ਇੱਕੋ ਓਪਰੇਟਿੰਗ ਸਿਸਟਮ ਕਰਨਲ ਨੂੰ ਸਾਂਝਾ ਕਰਨ ਦੀ ਆਗਿਆ ਦਿੰਦਾ ਹੈ। ਹਰੇਕ ਕੰਟੇਨਰ ਉਪਭੋਗਤਾ ਸਪੇਸ ਵਿੱਚ ਇੱਕ ਅਲੱਗ ਪ੍ਰਕਿਰਿਆ ਵਜੋਂ ਚੱਲਦਾ ਹੈ। ਇਸਦਾ ਮਤਲਬ ਹੈ ਕਿ ਕੰਟੇਨਰ VMs ਦੇ ਮੁਕਾਬਲੇ ਸ਼ੁਰੂ ਕਰਨ ਲਈ ਬਹੁਤ ਹਲਕੇ ਅਤੇ ਤੇਜ਼ ਹੁੰਦੇ ਹਨ, ਕਿਉਂਕਿ ਉਹਨਾਂ ਨੂੰ ਇੱਕ ਪੂਰੇ OS ਨੂੰ ਬੂਟ ਕਰਨ ਦੀ ਲੋੜ ਨਹੀਂ ਹੁੰਦੀ ਹੈ। ਡੌਕਰ ਇੱਕ ਲੇਅਰਡ ਫਾਈਲਸਿਸਟਮ ਦੁਆਰਾ ਫਾਈਲਸਿਸਟਮ ਆਈਸੋਲੇਸ਼ਨ ਨੂੰ ਪ੍ਰਾਪਤ ਕਰਦਾ ਹੈ, ਜਿੱਥੇ ਹਰੇਕ ਕੰਟੇਨਰ ਦੀ ਇੱਕ ਅਧਾਰ ਚਿੱਤਰ ਦੇ ਸਿਖਰ 'ਤੇ ਆਪਣੀ ਫਾਈਲ ਸਿਸਟਮ ਪਰਤ ਹੁੰਦੀ ਹੈ। ਨੈੱਟਵਰਕ ਆਈਸੋਲੇਸ਼ਨ ਨੂੰ ਨੇਮਸਪੇਸ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਸੰਭਾਲਿਆ ਜਾਂਦਾ ਹੈ, ਜਿਸ ਨਾਲ ਡੌਕਰ ਨੂੰ VMs ਨਾਲ ਜੁੜੇ ਓਵਰਹੈੱਡ ਤੋਂ ਬਿਨਾਂ ਹਰੇਕ ਕੰਟੇਨਰ ਲਈ ਅਲੱਗ-ਥਲੱਗ ਨੈੱਟਵਰਕਿੰਗ ਵਾਤਾਵਰਣ ਪ੍ਰਦਾਨ ਕਰਨ ਦੀ ਇਜਾਜ਼ਤ ਮਿਲਦੀ ਹੈ।
- ਡੌਕਰ ਅਤੇ VM ਵਿੱਚ ਮੁੱਖ ਅੰਤਰ ਕੀ ਹੈ?
- ਡੌਕਰ ਹੋਸਟ OS ਕਰਨਲ ਨੂੰ ਸਾਂਝਾ ਕਰਨ ਲਈ ਕੰਟੇਨਰਾਈਜ਼ੇਸ਼ਨ ਦੀ ਵਰਤੋਂ ਕਰਦਾ ਹੈ, ਇਸ ਨੂੰ ਹਲਕਾ ਅਤੇ ਤੇਜ਼ ਬਣਾਉਂਦਾ ਹੈ, ਜਦੋਂ ਕਿ VM ਨੂੰ ਇੱਕ ਪੂਰੇ ਮਹਿਮਾਨ OS ਅਤੇ ਇੱਕ ਹਾਈਪਰਵਾਈਜ਼ਰ ਦੀ ਲੋੜ ਹੁੰਦੀ ਹੈ।
- ਡੌਕਰ ਕੰਟੇਨਰਾਂ ਨੂੰ ਵਧੇਰੇ ਕੁਸ਼ਲ ਕਿਉਂ ਮੰਨਿਆ ਜਾਂਦਾ ਹੈ?
- ਕੰਟੇਨਰ ਹੋਸਟ OS ਕਰਨਲ ਨੂੰ ਸਾਂਝਾ ਕਰਦੇ ਹਨ ਅਤੇ ਘੱਟੋ-ਘੱਟ ਓਵਰਹੈੱਡ ਹੁੰਦੇ ਹਨ, ਤੇਜ਼ ਸ਼ੁਰੂਆਤੀ ਸਮੇਂ ਅਤੇ ਕੁਸ਼ਲ ਸਰੋਤ ਵਰਤੋਂ ਲਈ ਆਗਿਆ ਦਿੰਦੇ ਹਨ।
- ਡੌਕਰ ਫਾਈਲ ਸਿਸਟਮ ਆਈਸੋਲੇਸ਼ਨ ਨੂੰ ਕਿਵੇਂ ਪ੍ਰਾਪਤ ਕਰਦਾ ਹੈ?
- ਡੌਕਰ ਇੱਕ ਲੇਅਰਡ ਫਾਈਲਸਿਸਟਮ ਦੀ ਵਰਤੋਂ ਕਰਦਾ ਹੈ, ਜਿੱਥੇ ਹਰੇਕ ਕੰਟੇਨਰ ਦੀ ਇੱਕ ਬੇਸ ਚਿੱਤਰ ਦੇ ਸਿਖਰ 'ਤੇ ਆਪਣੀ ਫਾਈਲ ਸਿਸਟਮ ਪਰਤ ਹੁੰਦੀ ਹੈ।
- VMs ਦੇ ਸੰਦਰਭ ਵਿੱਚ ਇੱਕ ਹਾਈਪਰਵਾਈਜ਼ਰ ਕੀ ਹੈ?
- ਇੱਕ ਹਾਈਪਰਵਾਈਜ਼ਰ ਇੱਕ ਸਾਫਟਵੇਅਰ ਹੈ ਜੋ ਹਾਰਡਵੇਅਰ ਦੀ ਨਕਲ ਕਰਦਾ ਹੈ, ਜਿਸ ਨਾਲ ਮਲਟੀਪਲ ਓਪਰੇਟਿੰਗ ਸਿਸਟਮਾਂ ਨੂੰ ਇੱਕੋ ਹੋਸਟ ਮਸ਼ੀਨ 'ਤੇ ਇੱਕੋ ਸਮੇਂ ਚਲਾਉਣ ਦੀ ਇਜਾਜ਼ਤ ਮਿਲਦੀ ਹੈ।
- ਡੌਕਰ ਨੈੱਟਵਰਕਿੰਗ ਆਈਸੋਲੇਸ਼ਨ ਨੂੰ ਕਿਵੇਂ ਸੰਭਾਲਦਾ ਹੈ?
- ਡੌਕਰ ਹਰੇਕ ਕੰਟੇਨਰ ਲਈ ਅਲੱਗ-ਥਲੱਗ ਨੈੱਟਵਰਕਿੰਗ ਵਾਤਾਵਰਣ ਪ੍ਰਦਾਨ ਕਰਨ ਲਈ ਨੇਮਸਪੇਸ ਦੀ ਵਰਤੋਂ ਕਰਦਾ ਹੈ।
- ਇੱਕ ਡੌਕਰ ਚਿੱਤਰ ਵਿੱਚ ਸੌਫਟਵੇਅਰ ਤਾਇਨਾਤ ਕਰਨਾ ਇੱਕ VM ਨਾਲੋਂ ਸੌਖਾ ਕਿਉਂ ਹੈ?
- ਡੌਕਰ ਚਿੱਤਰ ਸਾਰੀਆਂ ਨਿਰਭਰਤਾਵਾਂ ਅਤੇ ਸੰਰਚਨਾਵਾਂ ਨੂੰ ਸ਼ਾਮਲ ਕਰਦੇ ਹਨ, ਵੱਖ-ਵੱਖ ਵਾਤਾਵਰਣਾਂ ਵਿੱਚ ਇਕਸਾਰਤਾ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਂਦੇ ਹਨ।
- Docker ਲਈ ਕੁਝ ਆਮ ਵਰਤੋਂ ਦੇ ਕੇਸ ਕੀ ਹਨ?
- ਡੌਕਰ ਦੀ ਵਰਤੋਂ ਆਮ ਤੌਰ 'ਤੇ ਮਾਈਕ੍ਰੋ ਸਰਵਿਸਿਜ਼ ਆਰਕੀਟੈਕਚਰ, ਨਿਰੰਤਰ ਏਕੀਕਰਣ/ਨਿਰੰਤਰ ਤੈਨਾਤੀ (CI/CD), ਅਤੇ ਅਲੱਗ-ਥਲੱਗ ਵਿਕਾਸ ਵਾਤਾਵਰਣਾਂ ਲਈ ਕੀਤੀ ਜਾਂਦੀ ਹੈ।
- ਕੀ ਡੌਕਰ ਕੰਟੇਨਰ ਕਿਸੇ ਵੀ OS 'ਤੇ ਚੱਲ ਸਕਦੇ ਹਨ?
- ਡੌਕਰ ਕੰਟੇਨਰ ਕਿਸੇ ਵੀ ਓਐਸ 'ਤੇ ਚੱਲ ਸਕਦੇ ਹਨ ਜੋ ਡੌਕਰ ਦਾ ਸਮਰਥਨ ਕਰਦਾ ਹੈ, ਪਰ ਉਹ ਹੋਸਟ OS ਕਰਨਲ ਨੂੰ ਸਾਂਝਾ ਕਰਦੇ ਹਨ।
- ਡੌਕਰ ਵਿੱਚ ਇੱਕ ਅਧਾਰ ਚਿੱਤਰ ਕੀ ਹੈ?
- ਇੱਕ ਅਧਾਰ ਚਿੱਤਰ ਡੌਕਰ ਕੰਟੇਨਰਾਂ ਨੂੰ ਬਣਾਉਣ ਲਈ ਸ਼ੁਰੂਆਤੀ ਬਿੰਦੂ ਹੈ, ਅਕਸਰ OS ਅਤੇ ਬੁਨਿਆਦੀ ਨਿਰਭਰਤਾਵਾਂ ਸਮੇਤ।
ਡੌਕਰ ਬਨਾਮ ਵਰਚੁਅਲ ਮਸ਼ੀਨਾਂ ਦਾ ਸੰਖੇਪ
ਡੌਕਰ ਅਤੇ ਵਰਚੁਅਲ ਮਸ਼ੀਨਾਂ ਦੀ ਤੁਲਨਾ ਕਰਨ ਵਿੱਚ, ਮੁੱਖ ਅੰਤਰ ਉਹਨਾਂ ਦੇ ਸਰੋਤ ਉਪਯੋਗਤਾ ਅਤੇ ਤੈਨਾਤੀ ਕੁਸ਼ਲਤਾ ਵਿੱਚ ਹੈ। ਵਰਚੁਅਲ ਮਸ਼ੀਨਾਂ ਇੱਕ ਪੂਰੇ ਗੈਸਟ ਓਪਰੇਟਿੰਗ ਸਿਸਟਮ ਅਤੇ ਹਾਈਪਰਵਾਈਜ਼ਰ ਨਾਲ ਕੰਮ ਕਰਦੀਆਂ ਹਨ, ਜਿਸ ਨਾਲ ਸਰੋਤਾਂ ਦੀ ਵੱਧ ਖਪਤ ਹੁੰਦੀ ਹੈ। ਇਸਦੇ ਉਲਟ, ਡੌਕਰ ਕੰਟੇਨਰ ਹੋਸਟ OS ਕਰਨਲ ਨੂੰ ਸਾਂਝਾ ਕਰਦੇ ਹਨ, ਨਤੀਜੇ ਵਜੋਂ ਇੱਕ ਵਧੇਰੇ ਹਲਕਾ ਅਤੇ ਚੁਸਤ ਹੱਲ ਹੁੰਦਾ ਹੈ। ਡੌਕਰ ਇੱਕ ਲੇਅਰਡ ਫਾਈਲ ਸਿਸਟਮ ਅਤੇ ਨੈਟਵਰਕਿੰਗ ਨੇਮਸਪੇਸਾਂ ਦੁਆਰਾ ਅਲੱਗ-ਥਲੱਗ ਵਾਤਾਵਰਣ ਪ੍ਰਾਪਤ ਕਰਦਾ ਹੈ, ਜਿਸ ਨਾਲ ਇਹ ਸੰਬੰਧਿਤ ਓਵਰਹੈੱਡ ਤੋਂ ਬਿਨਾਂ VM ਨੂੰ ਸਮਾਨ ਕਾਰਜਸ਼ੀਲਤਾ ਪ੍ਰਦਾਨ ਕਰਦਾ ਹੈ। ਇਹ ਡੌਕਰ ਚਿੱਤਰਾਂ ਲਈ ਸੌਫਟਵੇਅਰ ਦੀ ਤੈਨਾਤੀ ਨੂੰ ਹੋਰ ਕੁਸ਼ਲ, ਇਕਸਾਰ, ਅਤੇ ਵਿਭਿੰਨ ਉਤਪਾਦਨ ਵਾਤਾਵਰਣਾਂ ਵਿੱਚ ਪ੍ਰਬੰਧਨ ਲਈ ਸੌਖਾ ਬਣਾਉਂਦਾ ਹੈ।
ਸਿੱਟੇ ਵਜੋਂ, ਡੌਕਰ ਦੀ ਕੰਟੇਨਰਾਈਜ਼ੇਸ਼ਨ ਦੀ ਵਰਤੋਂ ਸਰੋਤਾਂ ਦੀ ਵਰਤੋਂ ਨੂੰ ਘਟਾ ਕੇ ਅਤੇ ਤੈਨਾਤੀ ਪ੍ਰਕਿਰਿਆਵਾਂ ਨੂੰ ਸਰਲ ਬਣਾ ਕੇ ਰਵਾਇਤੀ ਵਰਚੁਅਲ ਮਸ਼ੀਨਾਂ ਨਾਲੋਂ ਮਹੱਤਵਪੂਰਨ ਫਾਇਦਾ ਪ੍ਰਦਾਨ ਕਰਦੀ ਹੈ। ਹੋਸਟ OS ਕਰਨਲ ਨੂੰ ਸਾਂਝਾ ਕਰਕੇ ਅਤੇ ਅਲੱਗ-ਥਲੱਗ ਫਾਈਲਸਿਸਟਮ ਅਤੇ ਨੈਟਵਰਕਿੰਗ ਦੀ ਵਰਤੋਂ ਕਰਕੇ, ਡੌਕਰ ਆਧੁਨਿਕ ਐਪਲੀਕੇਸ਼ਨ ਡਿਪਲਾਇਮੈਂਟ ਲਈ ਇੱਕ ਮਜ਼ਬੂਤ ਪਰ ਹਲਕਾ ਹੱਲ ਪ੍ਰਦਾਨ ਕਰਦਾ ਹੈ। ਇਹਨਾਂ ਅੰਤਰਾਂ ਨੂੰ ਸਮਝਣਾ ਡਿਵੈਲਪਰਾਂ ਨੂੰ ਉਹਨਾਂ ਦੀਆਂ ਲੋੜਾਂ ਲਈ ਸਹੀ ਟੂਲ ਚੁਣਨ ਵਿੱਚ ਮਦਦ ਕਰ ਸਕਦਾ ਹੈ, ਕੁਸ਼ਲ ਅਤੇ ਸਕੇਲੇਬਲ ਐਪਲੀਕੇਸ਼ਨ ਪ੍ਰਬੰਧਨ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ।