Docker DCA Practice Test - Questions Answers
List of questions
Related questions
Question 1
Will this command display a list of volumes for a specific container?
Solution. 'docker container inspect nginx'
Yes
No
Explanation:
This command will not display a list of volumes for a specific container, as it will show detailed information on the container itself, such as its configuration, network settings, state, and log path1.To display a list of volumes for a specific container, you need to use the--formatoption with a custom template that filters the output by theMountsfield2. For example, the following command will show the source and destination of the volumes mounted in the nginx container:
docker container inspect --format=' { {range .Mounts}} { {.Source}} -> { {.Destination}} { {end}}' nginxReference:
docker container inspect | Docker Docs
How to Use Docker Inspect Command - Linux Handbook
Question 2
Is this an advantage of multi-stage builds?
Solution. better logical separation of Dockerfile instructions for increased readability
Yes
No
Explanation:
: = Multi-stage builds allow you to use multiple FROM statements in your Dockerfile, each starting a new stage of the build1.This can help you achieve better logical separation of Dockerfile instructions for increased readability, as well as other benefits such as smaller image size, faster build time, and reduced security risks23. By separating your Dockerfile into different stages, you can organize your instructions by their purpose, such as building, testing, or deploying your application.You can also copy only the artifacts you need from one stage to another, leaving behind the unnecessary dependencies or tools1. This can make your Dockerfile easier to read and maintain, as well as improve the performance and security of your final image.Reference:
Multi-stage builds | Docker Docs
What Are Multi-Stage Docker Builds? - How-To Geek
Multi-stage | Docker Docs
Question 3
Does this command create a swarm service that only listens on port 53 using the UDP protocol?
Solution. 'docker service create -name dns-cache -p 53:53 -constraint networking.protocol.udp=true dns-cache'
Yes
No
Explanation:
The commanddocker service create -name dns-cache -p 53:53 -constraint networking.protocol.udp=true dns-cachewill not create a swarm service that only listens on port 53 using the UDP protocol. This command has several syntax errors and invalid options.The correct syntax for creating a swarm service isdocker service create [OPTIONS] IMAGE [COMMAND] [ARG...]1.The correct options for specifying the service name, port mapping, and network mode are--name,--publish, and--networkrespectively1. The option-constraintis not a valid option for thedocker service createcommand.To create a swarm service that only listens on port 53 using the UDP protocol, you need to use the--publishoption with theprotocol=udpandmode=hostparameters, and the--networkoption with thehostvalue23.For example, the following command creates a global service using host mode and bypassing the routing mesh2:
docker service create --name dns-cache \
--publish published=53,target=53,protocol=udp,mode=host \
--mode global \
--network host \
dns-cache
1: docker service create | Docker Docs
2: Use swarm mode routing mesh | Docker Docs
3: Manage swarm service networks | Docker Docs
Question 4
Does this command create a swarm service that only listens on port 53 using the UDP protocol?
Solution. 'docker service create -name dns-cache -p 53:53/udp dns-cache'
Yes
No
Explanation:
= The command 'docker service create -name dns-cache -p 53:53/udp dns-cache' is not correct and will not create a swarm service that only listens on port 53 using the UDP protocol. There are two errors in the command:
The option-nameshould be--namewith two dashes, otherwise it will be interpreted as a short option-nfollowed by an argumentame1.
The option-por--publishwill publish the service port to the host port, which means the service will be reachable from outside the swarm2.To create a service that only listens on the internal network, you need to use the--publish-addoption with themode=ingressflag3.
The correct command should be:
docker service create --name dns-cache --publish-add mode=ingress,target=53,published=53,protocol=udp dns-cache
docker service create | Docker Docs
Publish ports on the host | Docker Docs
Publish a port for a service | Docker Docs
Question 5
During development of an application meant to be orchestrated by Kubernetes, you want to mount the /data directory on your laptop into a container.
Will this strategy successfully accomplish this?
Solution. Set containers. Mounts. hostBinding: /data in the container's specification.
Yes
No
Explanation:
The strategy willnotsuccessfully accomplish mounting the /data directory on your laptop into a container. Thecontainers. Mounts. hostBinding: /datais not a valid syntax for specifying a bind mount in a Kubernetes container specification. According to the Kubernetes documentation), the correct way to mount a host directory into a container is to use ahostPathvolume, which takes apathparameter that specifies the location on the host. For example, to mount the /data directory on your laptop into a container at /var/data, you can use the following YAML snippet:
spec:
containers:
- name: my-container
image: my-image
volumeMounts:
- name: data-volume
mountPath: /var/data
volumes:
- name: data-volume
hostPath:
path: /data
Question 6
During development of an application meant to be orchestrated by Kubemetes, you want to mount the /data directory on your laptop into a container.
Will this strategy successfully accomplish this?
Solution. Create a Persistent VolumeClaim requesting storageClass:'''' (which defaults to local storage) and hostPath: /data, and use this to populate a volume in a pod.
Yes
No
Explanation:
= This strategy will not successfully accomplish this.A PersistentVolumeClaim (PVC) is a request for storage by a user that is automatically bound to a suitable PersistentVolume (PV) by Kubernetes1.A PV is a piece of storage in the cluster that has been provisioned by an administrator or dynamically provisioned using StorageClasses1.A hostPath is a type of volume that mounts a file or directory from the host node's filesystem into a pod2.It is mainly used for development and testing on a single-node cluster, and not recommended for production use2.
The problem with this strategy is that it assumes that the hostPath /data on the node is the same as the /data directory on your laptop. This is not necessarily true, as the node may be a different machine than your laptop, or it may have a different filesystem layout.Also, the hostPath volume is not portable across nodes, so if your pod is scheduled on a different node, it will not have access to the same /data directory2.Furthermore, the storageClass parameter is not applicable for hostPath volumes, as they are not dynamically provisioned3.
To mount the /data directory on your laptop into a container, you need to use a different type of volume that supports remote access, such as NFS, Ceph, or GlusterFS4. You also need to make sure that your laptop is accessible from the cluster network and that it has the appropriate permissions to share the /data directory.Alternatively, you can use a tool like Skaffold or Telepresence to sync your local files with your cluster56.Reference:
Persistent Volumes | Kubernetes
Volumes | Kubernetes
Storage Classes | Kubernetes
Kubernetes Storage Options | Kubernetes Academy
Skaffold | Easy and Repeatable Kubernetes Development
Telepresence: fast, local development for Kubernetes and OpenShift microservices
Question 7
Is this an advantage of multi-stage builds?
Solution: better caching when building Docker images
Yes
No
Explanation:
Better caching when building Docker images is an advantage of multi-stage builds.Multi-stage builds allow you to use multiple FROM statements in your Dockerfile, each starting a new stage of the build1.This can help you improve the caching efficiency of your Docker images, as each stage can use its own cache layer2.For example, if you have a stage that installs dependencies and another stage that compiles your code, you can reuse the cached layer of the dependencies stage if they don't change, and only rebuild the code stage if it changes2. This can save you time and bandwidth when building and pushing your images.Reference:
Multi-stage builds | Docker Docs
What Are Multi-Stage Docker Builds? - How-To Geek
Question 8
Are these conditions sufficient for Kubernetes to dynamically provision a persistentVolume, assuming there are no limitations on the amount and type of available external storage?
Solution: A persistentVolumeClaim is created that specifies a pre-defined provisioner.
Yes
No
Explanation:
Explore
Answer : B. No
The creation of a persistentVolumeClaim with a specified pre-defined provisioner is not sufficient for Kubernetes to dynamically provision a persistentVolume. There are other factors and configurations that need to be considered and set up, such as storage classes and the appropriate storage provisioner configurations.A persistentVolumeClaim is a request for storage by a user, which can be automatically bound to a suitable persistentVolume if one exists or dynamically provisioned if one does not exist1.A provisioner is a plugin that creates volumes on demand2.A pre-defined provisioner is a provisioner that is built-in or registered with Kubernetes, such as aws-ebs, gce-pd, azure-disk, etc3. However, simply specifying a pre-defined provisioner in a persistentVolumeClaim is not enough to trigger dynamic provisioning.You also need to have a storage class that defines the type of storage and the provisioner to use4.A storage class is a way of describing different classes or tiers of storage that are available in the cluster5.You can create a storage class with a pre-defined provisioner, or use a default storage class that is automatically created by the cluster6. You can also specify parameters for the provisioner, such as the type, size, zone, etc.of the volume to be created7. To use a storage class for dynamic provisioning, you need to reference it in the persistentVolumeClaim by name, or use the special value '''' to use the default storage class. Therefore, to enable dynamic provisioning, you need to have both a persistentVolumeClaim that requests a storage class and a storage class that defines a provisioner.Reference:
Persistent Volumes
Dynamic Volume Provisioning
Provisioner
Storage Classes
Configure a Pod to Use a PersistentVolume for Storage
Change the default StorageClass
Parameters
[PersistentVolumeClaim]
I also noticed that you sent me two images along with your question. The first image shows the Kubernetes logo, which consists of seven spokes connected to a central hub, forming an almost circular shape. The logo is blue and placed on a white background. It's encapsulated within a hexagonal border. The second image shows a diagram of the relationship between persistent volumes, persistent volume claims, and pods in Kubernetes. It illustrates how a pod can use a persistent volume claim to request storage from a persistent volume, which can be either statically or dynamically provisioned. The diagram also shows how a storage class can be used to define the type and provisioner of the storage. I hope this helps you understand the concept of persistent storage in Kubernetes.
Question 9
You add a new user to the engineering organization in DTR.
Will this action grant them read/write access to the engineering/api repository?
Solution. Mirror the engineering/api repository to one of the user's own private repositories.
Yes
No
Explanation:
= Mirroring the engineering/api repository to one of the user's own private repositories will not grant them read/write access to the original repository. Mirroring is a feature that allows users to automatically sync images from one repository to another, either within the same DTR or across different DTRs. Mirroring does not affect the permissions or roles of the users or teams associated with the source or destination repositories. To grant a user read/write access to the engineering/api repository, the user needs to be added to a team that has the appropriate role for that repository, or the repository needs to be configured with the appropriate visibility and access settings.Reference:
Mirror repositories
Manage access to repositories
Manage teams
Question 10
Is this the purpose of Docker Content Trust?
Solution. Sign and verify image tags.
Yes
No
Explanation:
= The purpose of Docker Content Trust is to sign and verify image tags using digital signatures for data sent to and received from remote Docker registries12.This allows client-side or runtime verification of the integrity and publisher of specific image tags, ensuring the provenance and security of container images34.Reference:
1: Content trust in Docker | Docker Docs
2: Docker Content Trust: What It Is and How It Secures Container Images
3: Docker Content Trust in Azure Pipelines - Azure Pipelines
4: 4.5 Ensure Content trust for Docker is Enabled | Tenable
Question