Docker-Kubernetes
Prerequisites
- A containerized application
- You can also use a demo app.
- A Google Cloud Account or a Kubernetes cluster on another provider
- Everything after Cluster creation is identical with all providers.
- A free account on Codefresh
- Codefresh is a service that handles Kubernetes deployment configuration and automation.
We made Codefresh free for open-source projects and offer 200 builds/mo free for private projects, to make adopting Kubernetes as easy as possible. Deploy as much as you like on as many clusters as you like.
Set Up a Cluster
- Create an account at cloud.google.com and log in.
Note: If you’re using a Cluster outside of Google Cloud, you can skip this step.
Google Container Engine is Google Cloud’s managed Kubernetes service. In our testing, it’s both powerful and easy to use.
- Open the menu and scroll down to Container Engine. Then select Container Clusters.
data:image/s3,"s3://crabby-images/7b83b/7b83b0709663de147341c5870b230bebae53018e" alt=""
- Click Create cluster.
Deploy an Application to Kubernetes
Then we’ll deploy our application and automate the process to happen every time we commit code changes. Here are the steps
1.Create a Codefresh account
2.Connect to Google Cloud (or other cluster
3.Add Cluster
4.Deploy static image
5.Build and deploy an image
6.Automate the process
Connect to Google Cloud
To connect your Clusters in Google Container Engine, go to Account Settings > Integrations > Kubernetes and click Authenticate. This prompts you to login with your Google credentials.
data:image/s3,"s3://crabby-images/e9c16/e9c165a4e37f013d93a8fec97681fedf66945ae7" alt=""
Add Cluster
To add your cluster, click the down arrow, and then click add cluster, select the project and cluster name. You can now deploy images!
Optional: Use an Alternative Cluster
To connect a non-GKE cluster we’ll need to add a token and certificate to Codefresh. Go to Account Settings (bottom left) > Integrations > Kubernetes > Configure > Add Provider > Custom Providers. Expand the dropdown and click Add Cluster.
data:image/s3,"s3://crabby-images/e5c67/e5c6734b695488b8002c445cff39c34d6e370015" alt=""
Follow the instructions on how to generate the needed information and click Save. Your cluster now appears under the Kubernetes tab.
Deploy Static Image to Kubernetes
Now for the fun part! Codefresh provides an easily modifiable boilerplate that takes care of the heavy lifting of configuring Kubernetes for your application.
- Click on the Kubernetes tab: this shows a list of namespaces.
Think of namespaces as acting a bit like VLANs on a Kubernetes cluster. Each namespace can contain all the services that need to talk to each other on a Kubernetes cluster. For now, we’ll just work off the default namespace (the easy way!).
- Click Add Service and fill in the details.
You can use the demo application I mentioned earlier that has a Node.js frontend with a MongoDB.
data:image/s3,"s3://crabby-images/159de/159de6f4510d0849e2225e5d60a07d6f5199d666" alt=""
Here’s the info we need to pass:
Cluster – This is the cluster we added earlier, our application will be deployed there.
Namespace – We’ll use default for our namespace but you can create and use a new one if you’d prefer. Namespaces are discrete units for grouping all the services associated with an application.
Service name – You can name the service whatever you like. Since we’re deploying Mongo, I’ll just name it mongo!
Expose port – We don’t need to expose the port outside of our cluster so we won’t check the box for now but we will specify a port where other containers can talk to this service. Mongo’s default port is ‘27017’.
Image – Mongo is a public image on Dockerhub, so I can reference it by name and tag, ‘mongo:latest’.
Internal Ports – This is the port the mongo application listens on, in this case it’s ‘27017’ again.
Namespace – We’ll use default for our namespace but you can create and use a new one if you’d prefer. Namespaces are discrete units for grouping all the services associated with an application.
Service name – You can name the service whatever you like. Since we’re deploying Mongo, I’ll just name it mongo!
Expose port – We don’t need to expose the port outside of our cluster so we won’t check the box for now but we will specify a port where other containers can talk to this service. Mongo’s default port is ‘27017’.
Image – Mongo is a public image on Dockerhub, so I can reference it by name and tag, ‘mongo:latest’.
Internal Ports – This is the port the mongo application listens on, in this case it’s ‘27017’ again.
We can ignore the other options for now.
- Scroll down and click Deploy.
data:image/s3,"s3://crabby-images/dd59c/dd59c65ae47a95542c74fc30b4b52899bda27332" alt=""
Boom! You’ve just deployed this image to Kubernetes. You can see by clicking on the status that the service, deployment, replicas, and pods are all configured and running. If you click Edit > Advanced, you can see and edit all the raw YAML files associated with this application, or copy them and put them into your repository for use on any cluster.
Build and Deploy an Image
Click on Repositories > Add Repository, then copy and paste the demochat repo url (or use your own repo).
data:image/s3,"s3://crabby-images/c5752/c57521056f580900f48f0a80c890e62112e46638" alt=""
We have the option to use a dockerfile, or to use a template if we need help creating a dockerfile. In this case, the demochat repo already has a dockerfile so we’ll select that. Click through the next few screens until the image builds.
Once the build is finished the image is automatically saved inside of the Codefresh docker registry. You can also add any other registry to your account and use that instead.
To deploy the image we’ll need
- a pull secret
- the image name and registry
- the ports that will be used
Creating the Pull Secret
The pull secret is a token that the Kubernetes cluster can use to access a private Docker registry. To create one, we’ll need to generate the token and save it to Codefresh.
- Click on User Settings (bottom left) and generate a new token.
- Copy the token to your clipboard.
data:image/s3,"s3://crabby-images/b9677/b9677e099dd8c8392169e7a570f061bc7f460bc5" alt=""
- Go to Account Settings > Integrations > Docker Registry > Add Registry and select Codefresh Registry. Paste in your token and enter your username (entry is case sensitive). Your username must match your name displayed at the bottom left of the screen.
- Test and save it.
We’ll now be able to create our secret later on when we deploy our image.
Get the image name
- Click on Images and open the image you just built. Under Comment you’ll see the image name starting with r.cfcr.io.
data:image/s3,"s3://crabby-images/86892/8689249b4be58a9e2a8abf1c8f44e260f2eff7e5" alt=""
- Copy the image name; we’ll need to paste it in later.
Deploy the private image to Kubernetes
We’re now ready to deploy the image we built.
- Go to the Kubernetes page and, like we did with mongo, click Add Service and fill out the page. Make sure to select the same namespace you used to deploy mongo earlier.
data:image/s3,"s3://crabby-images/63e15/63e153b288608c2ccd1c7273a5ac91fe3344e227" alt=""
Now let’s expose the port so we can access this application. This provisions an IP address and automatically configures ingress.
- Click Deploy : your application will be up and running within a few seconds! The IP address may take longer to provision depending on your cluster location.
data:image/s3,"s3://crabby-images/409d1/409d15ff1f02d5dc5c0656834251f9b68058003a" alt=""
From this view you can scale the replicas, see application status, and similar tasks.
- Click on the IP address to view the running application.
data:image/s3,"s3://crabby-images/c249c/c249c50d51b71ec08b8e54c4e321849bc3e1ad3a" alt=""
At this point you should have your entire application up and running! Not so bad huh? Now to automate deployment!
Automate Deployment to Kubernetes
Every time we make a change to our application, we want to build a new image and deploy it to our cluster. We’ve already set up automated builds, but to automate deployment:
- Click on Repositories (top left).
- Click on the pipeline for the demochat repo (the gear icon)..
data:image/s3,"s3://crabby-images/6be1b/6be1b8c25128a4e1cd60e353f9707d352e466844" alt=""
- It’s a good idea to run some tests before deploying. Under Build and Unit Test, add npm test for the unit test script.
- Click Deploy Script and select Kubernetes (Beta). Enter the information for the service you’ve already deployed.
data:image/s3,"s3://crabby-images/270f4/270f4113c6682d62dc3aa7fe7bc2b7d84de6aa0b" alt=""
You can see the option to use a deployment file from your repo, or to use the deployment file that you just generated.
- Click Save.
You’re done with deployment automation! Now whenever a change is made, the image will build, test, and deploy.
No comments:
Post a Comment