官术网_书友最值得收藏!

About Minikube

One of the things you may have been thinking to yourself when reading the previous chapter is that Kubernetes seems complex. There are a lot of moving parts, which not only need to be configured but also monitored and managed.

I remember when I originally looked at Kubernetes when it was first released before the stable version, and the installation instructions were very long and also things were a little delicate.

Misread a step at the beginning of the installation process and you could find yourself in a lot of trouble later in the installation—it reminded me of when magazines used to contain type in listings for games. If you made a typo anywhere then things would either flat-out not work or crash unexpectedly.

As Kubernetes matured, so did the installation process. Quite quickly a number of helper scripts were developed to aid in launching Kubernetes across various platforms; Minikube is one of these tools.

It has one job, to create a local Kubernetes node. Considering the breadth of features supported by Kubernetes, it has a surprising number of features, such as:

  • DNS, NodePorts, and Ingress
  • ConfigMaps and Secrets
  • A choice of container runtimes; you can use either Docker or rkt
  • Persistent Volumes via hostPath
  • Dashboards

Kubernetes features that would typically require a public cloud provider, such as AWS, Microsoft Azure, or Google Cloud, or multiple hosts, are not supported. Some of these features are:

  • LoadBalancers
  • Advanced scheduling policies

This is because Minikube only launches a single node on a virtual machine on your local PC. This shouldn't limit you though; remember that you would only ever want to use Minikube for development and you should never build production services using it. There are a lot more tools, which will be covered in Chapter 6, Installing Kubernetes in the Cloud, more suited to launching production-ready Kubernetes clusters in public clouds or other vendors.

Minikube is made up of two core components:

  • libmachine: This library from Docker is used to provision virtual machines on your host machine. It is a core component of Docker Machine as well as Docker for macOS and Docker for Windows.
  • localkube: This library, developed and donated to the Minikube project by Redspread (which is now a part of CoreOS), is responsible for deploying and maintaining the Kubernetes node once the virtual machine has been launched.

Rather than talking about what Minikube can do any more, we should look at installing it and then discuss how we can interact with it.

主站蜘蛛池模板: 喀喇沁旗| 鸡泽县| 遂平县| 枝江市| 龙州县| 商河县| 上虞市| 肃北| 任丘市| 于田县| 察隅县| 淳安县| 女性| 洪湖市| 牙克石市| 岳普湖县| 菏泽市| 体育| 长葛市| 东乌珠穆沁旗| 遂川县| 昭苏县| 漯河市| 星子县| 奎屯市| 台安县| 吉安市| 荔浦县| 留坝县| 新疆| 漳浦县| 洪湖市| 喜德县| 吴桥县| 林西县| 当涂县| 芮城县| 墨江| 长宁县| 金沙县| 宣恩县|