Exercise - Push a microservice image to Docker Hub
In order for Kubernetes to create a container image, it needs a place from which to get it. Docker Hub is a central place to upload Docker images. Many products, including Kubernetes, can create containers based on images in Docker Hub.
Note
You will complete this exercise in a GitHub Codespace that has Docker and the .NET SDK pre-installed. When you use these techniques in your own development environment, make sure you have these prerequisites installed.
Open the development environment
You can choose to use a GitHub codespace that hosts the exercise, or complete the exercise locally in Visual Studio Code.
To use a codespace, create a preconfigured GitHub Codespace with this Codespace creation link.
The process takes several minutes while GitHub creates and configures the codespace. Once finished, the code used for the rest of this module is in the /dotnet-kubernetes directory.
To use Visual Studio Code, clone the https://github.com/MicrosoftDocs/mslearn-dotnet-cloudnative repository to your local machine. Then:
- Install any system requirements to run Dev Container in Visual Studio Code.
- Make sure Docker is running.
- In a new Visual Studio Code window, open the folder of the cloned repository
- Press Ctrl+Shift+P to open the command palette.
- Search: >Dev Containers: Rebuild and Reopen in Container
- Select eShopLite - dotnet-kubernetes from the drop-down. Visual Studio Code creates your development container locally.
Verify the Docker images by creating containers in the codespace
There are two containers in the Contoso Shop project. Before pushing the images to Docker Hub, let's use them to create the containers in the codespace. After the containers are created and running, we'll be able to browse the Contoso company website and verify the microservices are running OK.
Follow these steps to create and run Docker containers in the codespace.
Switch to the TERMINAL tab and run the following command to go to the code root:
cd dotnet-kubernetes
Run the following command to build the containers:
dotnet publish /p:PublishProfile=DefaultContainer
It might take a while to build the containers.
Run the following command to run the app and attach the containers:
docker compose up
To test the front end service, switch to the PORTS tab, then to the right of the local address for the Front End port, select the globe icon. The browser displays the homepage.
Select Products. The catalog shows Contoso's merchandise.
Close the web site, return to the TERMINAL tab, and then press CTRL + C. Docker
compose
halts the containers.
Sign in to Docker Hub
The next step in uploading the images to Docker Hub is to sign into Docker Hub. From the command prompt, enter the following command:
docker login
Important
Use the same username and password from when you created your Docker account. You can visit the Docker Hub website to reset your password, if needed.
Upload the images to Docker Hub
Enter the following code to retag or rename the Docker images you created under your Docker username.
docker tag store [YOUR DOCKER USER NAME]/storeimage docker tag products [YOUR DOCKER USER NAME]/productservice
Then finally upload, or push, the Docker images to Docker Hub.
docker push [YOUR DOCKER USER NAME]/storeimage docker push [YOUR DOCKER USER NAME]/productservice
If you receive an authentication error, you can run
docker logout
followed bydocker login
to reauthenticate.
In this exercise, you used Dockerfiles and Docker compose to create two Docker images and containers, and pushed those images to Docker Hub.
Now, you're ready to use Kubernetes to manage Contoso's microservices deployment.