Skip to main content

[SOLVED] How can I use local Docker images with Minikube? - docker

[SOLVED] How to Effectively Use Local Docker Images with Minikube

In this guide, we will look at how to use local Docker images with Minikube. This will make our Kubernetes development easier. Using local Docker images can help us work faster. We do not need to push images to a remote registry for testing. We will talk about different methods. Each method fits different needs and development setups. This way, we can pick the best one for us.

Here are the methods we will talk about:

  • Solution 1: Use Minikube’s Docker Environment
  • Solution 2: Build Docker Images Inside Minikube
  • Solution 3: Load Docker Images from Local Machine
  • Solution 4: Use Minikube’s Image Cache
  • Solution 5: Configure Kubernetes Deployment with Local Images
  • Solution 6: Verify Local Images in Minikube

If you want to know more, you can check these links: How to Start Stopped Docker Containers and Understanding Docker Invalid Reference Format Errors.

By the end of this chapter, we will understand how to use local Docker images with Minikube. This will make our application development on Kubernetes smoother.

Solution 1 - Use Minikube’s Docker Environment

To use local Docker images with Minikube, we can use Minikube’s built-in Docker environment. This lets us build our Docker images directly inside the Minikube VM. Then, our images are ready for Kubernetes deployments without extra steps.

Steps to Use Minikube’s Docker Environment

  1. Start Minikube: If we haven’t started Minikube yet, we can do it with this command:

    minikube start
  2. Set Docker Environment: To set up our terminal for the Docker daemon inside Minikube, we run this command:

    eval $(minikube docker-env)

    This command changes our Docker CLI to work with the Docker daemon in Minikube. We can check if it works by looking at the Docker version:

    docker version

    The output should show we are connected to the Docker daemon of our Minikube instance.

  3. Build Your Docker Image: Now that we set the Docker environment to Minikube, we can build our Docker image like usual. Here’s a simple Dockerfile:

    # Dockerfile
    FROM nginx:alpine
    COPY ./my-app /usr/share/nginx/html

    We can build the image with:

    docker build -t my-app:latest .
  4. Verify the Image: After we build the image, we can check if it is in the Minikube Docker environment with:

    docker images
  5. Deploy Your Application: Now we can create a Kubernetes deployment using the image we just built. Here’s a sample deployment YAML file:

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: my-app
    spec:
      replicas: 2
      selector:
        matchLabels:
          app: my-app
      template:
        metadata:
          labels:
            app: my-app
        spec:
          containers:
            - name: my-app
              image: my-app:latest
              ports:
                - containerPort: 80

    We can apply the deployment with:

    kubectl apply -f deployment.yaml

Using Minikube’s Docker environment helps us build and deploy our local Docker images to the Minikube Kubernetes cluster easily. For more tips, you might find this guide on how to start stopped Docker containers helpful.

Solution 2 - Build Docker Images Inside Minikube

To use local Docker images with Minikube, we can build the Docker images directly inside the Minikube environment. This way, we create images that are ready to use in our Minikube cluster. We do not need to push them to a remote place. Here is a simple guide on how to do this.

Step 1: Start Minikube

First, we need to make sure Minikube is running. We can start Minikube with this command:

minikube start

Step 2: Configure Docker Environment

After Minikube starts, we should set up our shell to use Minikube’s Docker daemon. This helps us build images right in Minikube. We can run this command:

eval $(minikube docker-env)

Step 3: Build Your Docker Image

Now that our shell is ready, we can build our Docker image like we usually do with the Docker CLI. We create a Dockerfile in our project folder. Here is an example Dockerfile:

# Use a base image
FROM node:14

# Set the working directory
WORKDIR /usr/src/app

# Copy package.json and install dependencies
COPY package*.json ./
RUN npm install

# Copy the rest of the application code
COPY . .

# Expose the application port
EXPOSE 3000

# Command to run the application
CMD ["npm", "start"]

We build the Docker image with this command:

docker build -t my-local-image:1.0 .

Step 4: Verify Image Creation

To check if our image built well and is in Minikube’s Docker environment, we can list the Docker images:

docker images

We should see my-local-image:1.0 in the list.

Step 5: Deploy the Image to Minikube

Now that we built our image, we can deploy it to our Minikube Kubernetes cluster. We create a deployment with this command:

kubectl create deployment my-app --image=my-local-image:1.0

Step 6: Expose the Deployment

To access our application, we need to expose the deployment with a service:

kubectl expose deployment my-app --type=NodePort --port=3000

Step 7: Access Your Application

Finally, we can get the URL to access our application:

minikube service my-app --url

This command gives us a URL that we can use to reach our application inside Minikube.

Summary

By building Docker images inside Minikube, we make our development process easier. We can quickly test our applications. This way is good when we work with local Docker images. It helps us deploy in our Kubernetes environment. For more details about using Minikube with Docker, we can check the resources available here.

Solution 3 - Load Docker Images from Local Machine

We can use local Docker images with Minikube. We load the images directly from our local machine into the Minikube environment. This way, we can run Kubernetes deployments that use images built on our local Docker setup. We do not need to push them to a remote registry.

Steps to Load Docker Images into Minikube

  1. Start Minikube: First, we need to make sure that Minikube is running. If it is not started yet, we can start it with this command:

    minikube start
  2. Load the Docker Image: Next, we use the minikube image load command to load our local Docker image into the Minikube cluster. We need to tell the image name and tag that we want to load. For example, if our Docker image is named my-app and has the tag v1, we can use:

    minikube image load my-app:v1

    If we have not built the image yet, we can do it using Docker:

    docker build -t my-app:v1 .
  3. Verify the Loaded Image: After we load the image, we can check if it is available in Minikube. We do this by running the command:

    minikube ssh -- docker images

    This command shows the list of images in the Minikube’s Docker environment. It includes the one we just loaded.

  4. Use the Loaded Image in Deployments: To use the loaded Docker image in our Kubernetes deployments, we can reference it in our deployment YAML file. For example:

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: my-app-deployment
    spec:
      replicas: 2
      selector:
        matchLabels:
          app: my-app
      template:
        metadata:
          labels:
            app: my-app
        spec:
          containers:
            - name: my-app
              image: my-app:v1
              ports:
                - containerPort: 8080

    After that, we apply this deployment configuration using:

    kubectl apply -f deployment.yaml
  5. Access Your Application: After we deploy, we can access our application through Minikube’s service exposure methods, such as:

    minikube service my-app-deployment

By following these steps, we can load Docker images from our local machine into our Minikube environment. This helps us test and deploy our applications easily. For more help on Docker image handling, we can read about how to manage Docker images.

Solution 4 - Use Minikube’s Image Cache

Minikube has a feature called image cache. This feature lets us save Docker images on our local machine. We can then use these images in different Minikube clusters. This is really helpful for developers. When we often rebuild images, we can speed up our deployment. We do not need to push and pull images from a remote place every time.

Steps to Use Minikube’s Image Cache

  1. Start Minikube with the Image Cache Option: When we start Minikube, we can turn on the image cache feature. If we have Minikube version 1.16.0 or newer, it is on by default. If we want to turn it on ourselves, we can run this command:

    minikube start --cache-images
  2. Building Your Docker Image: We can build our Docker image with the docker command using the Minikube Docker daemon. This will save our images for use in Minikube.

    First, we need to set our terminal to use Minikube’s Docker daemon:

    eval $(minikube docker-env)

    Then we build our Docker image:

    docker build -t my-local-image:latest .

    This command names the image as my-local-image:latest. Now it is in Minikube’s image cache.

  3. Verify Images in Minikube’s Cache: To see if our image is saved and ready in Minikube, we can use this command:

    docker images

    We should see my-local-image in the list of images.

  4. Use the Cached Image in Your Kubernetes Deployment: Now we can use this cached image in our Kubernetes deployment YAML file. Here is a simple example of a deployment configuration:

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: my-app
    spec:
      replicas: 2
      selector:
        matchLabels:
          app: my-app
      template:
        metadata:
          labels:
            app: my-app
        spec:
          containers:
            - name: my-app
              image: my-local-image:latest
              ports:
                - containerPort: 80
  5. Deploy Your Application: We can apply our deployment configuration to create the pods:

    kubectl apply -f deployment.yaml
  6. Access Your Application: After the deployment is successful, we can access our application based on our service setup. We usually do this through a NodePort or LoadBalancer service.

By using Minikube’s image cache feature, we can make our development work much easier. This way, we do not need to push and pull images from Docker Hub or other places. We can make changes and test our applications quicker when we work with Minikube.

For more tips and help, we can check resources like how to troubleshoot Docker issues.

Solution 5 - Configure Kubernetes Deployment with Local Images

To use local Docker images in our Minikube Kubernetes deployment, we need to set up our deployment YAML file right. This helps Kubernetes find the local images that we built or loaded into Minikube. Here are the steps to do this:

  1. Verify Local Images in Minikube: First, we need to make sure the local Docker images are available in our Minikube setup. We can check this by running:

    minikube images

    This command shows all Docker images in the Minikube Docker daemon.

  2. Create a Deployment YAML File: Next, we create a Kubernetes deployment YAML file called (deployment.yaml). This file will say what local image to use. Here is an example of how we can set up our deployment:

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: my-app
      labels:
        app: my-app
    spec:
      replicas: 1
      selector:
        matchLabels:
          app: my-app
      template:
        metadata:
          labels:
            app: my-app
        spec:
          containers:
            - name: my-container
              image: my-local-image:latest # Change to your local image name
              ports:
                - containerPort: 8080

    In the image field, we should change my-local-image:latest to the name and tag of our local Docker image.

  3. Deploy the Configuration: When our deployment file is ready, we apply it using this command:

    kubectl apply -f deployment.yaml

    This command makes the deployment in our Minikube cluster with the local image we specified.

  4. Verify the Deployment: After we deploy, we can check if our pods are running well by using:

    kubectl get pods

    We should see our pod listed with a status of Running. If there are problems, we can see more details by checking the logs:

    kubectl logs <pod-name>
  5. Accessing Your Application: If our application has a service, we can access it with Minikube’s service command:

    minikube service my-app

    This command opens our web browser with the URL to reach our application running in Minikube.

By following these steps, we can set up our Kubernetes deployment in Minikube to use local Docker images. This way, we can develop and test our applications quickly in a separate environment. For more information on managing Docker images, we can check this guide.

Solution 6 - Verify Local Images in Minikube

We want to make sure that our local Docker images are ready and can be used in Minikube. We can check their presence and accessibility by following these steps:

  1. Open a Terminal: First, we open the terminal where Minikube is running.

  2. Set the Docker Environment: Next, we set the Docker environment to use Minikube’s Docker daemon. This lets us manage images directly in Minikube.

    eval $(minikube docker-env)
  3. List Docker Images: After setting the environment, we can check what local Docker images are in Minikube. We do this by running:

    docker images

    This command shows all the Docker images that are in Minikube’s Docker environment. We should look for our image name and tag in the list.

  4. Verify Image Availability: If we see our image listed, it means the image is ready for use in our Minikube cluster. If our image is not there, we may need to build it again or check if it is loaded into Minikube.

  5. Check Kubernetes Pods: To make sure the image works in a deployment, we can create a simple Kubernetes pod with our local image. We can create a file named my-local-pod.yaml like this:

    apiVersion: v1
    kind: Pod
    metadata:
      name: my-local-pod
    spec:
      containers:
        - name: my-local-container
          image: my-local-image:latest # Change to your local image name

    Then we apply the pod configuration:

    kubectl apply -f my-local-pod.yaml
  6. Verify Pod Status: After we create the pod, we check its status to see if it runs correctly:

    kubectl get pods

    If the pod is in Running state, it means we used our local image in Minikube successfully.

  7. Inspect Pod Logs: To confirm our application works as we expect, we can look at the logs of our pod:

    kubectl logs my-local-pod

By following these steps, we can confirm that our local Docker images are set up and working in Minikube. If we want more help on using Docker with Minikube, we can check this resource.

Conclusion

In this article, we looked at different ways to use local Docker images with Minikube. We talked about using Minikube’s Docker setup and how to build images inside Minikube. It is important for developers to know these methods to make their work with Kubernetes easier.

By using the methods we shared, we can manage local images better. This will help improve our development process and fix common problems with Docker images.

For more information, we can check out our guides on how to update the /etc/hosts file and running a Vite dev server inside Docker.

Comments