Minikube体验
本文的环境如下:
操作系统: Mac OSX EI Caption
Docker:Docker version 18.03.1-ce, build 9ee9f40
Minikube:minikube version: v0.27.0
Kubernetes: v1.10.0
Minikube 介绍
Minikube支持Kubenetes的以下特性:
- DNS
- NodePorts
- ConfigMaps and Secrets
- Dashboards
- Container Runtime: Docker, rkt and CRI-O
- Enabling CNI (Container Network Interface)
- Ingress
Minikube 安装
因为 Google 在国内没办法访问,我使用了阿里版的 Minikube 。
Minikube运行要求安装有VirtualBox或VMWare Fusion,我用的是VirtualBox。
VirtualBox安装很简单,从 官方下载DMG 安装即可。
下载安装 Minikube
curl -Lo minikube http://kubernetes.oss-cn-hangzhou.aliyuncs.com/minikube/releases/v0.27.0/minikube-darwin-amd64 && chmod +x minikube && sudo mv minikube /usr/local/bin/
启动 Minikube
minikube start --registry-mirror=https://registry.docker-cn.com
如果你遇到这个错误,Error restarting cluster: restarting kube-proxy: waiting for kube-proxy to be up for configmap update: timed out waiting for the condition
通过 minikube delete,minikube start 可以解决
打开 Minikube 控制台
minikube dashboard
随后浏览器中会自动打开这个界面。

使用
Minikube在本地虚拟机环境中部署 Kubernetes。

启动 Cluster
bogon:k8s rousseau$ minikube start
Starting local Kubernetes v1.10.0 cluster...
Starting VM...
Getting VM IP address...
Moving files into cluster...
Setting up certs...
Connecting to cluster...
Setting up kubeconfig...
Starting cluster components...
Kubectl is now configured to use the cluster.
Loading cached images from config file.
该命令创建并配置一个运行了单个Kubernetes节点的虚拟机。Minikube 启动过程中,可以用--extra-config=component.key=value的形式给 Kubernetes 指定参数。
停止 Cluster
bogon:k8s rousseau$ minikube stop
删除 Cluster
bogon:k8s rousseau$ minikube delete
访问服务
minikube service [-n NAMESPACE] [--url] NAME
网络
前面的原理图说明了Minikube启动了一个虚拟机,这个虚拟机的地址是Host-Only的,要获得主机IP,执行。
bogon:k8s rousseau$ minikube ip
192.168.99.100
存储
简单的示例
构建一个 Node 服务
构建一个简单的Node网页程序,用户访问的时候输出hello world。
var http = require('http');
var handleRequest = function(request, response) {
console.log('Received request for URL: ' + request.url);
response.writeHead(200);
response.end('Hello World!');
};
var www = http.createServer(handleRequest);
www.listen(8080);
可以在终端中执行node server.js并通过http://localhost:8080查看效果
生成镜像
编写 Dockerfile 文件
FROM node:6.9.2
EXPOSE 8080
COPY server.js .
CMD node server.js
因为我们使用的是 Minikube ,不需要把镜像放到镜像仓库中,只需要放在Minikube VM中。
bogon:k8s rousseau$ eval $(minikube docker-env)
bogon:k8s rousseau$ docker build -t hello-node:v1 .
Sending build context to Docker daemon 3.072kB
Step 1/4 : FROM node:6.9.2
6.9.2: Pulling from library/node
75a822cd7888: Pull complete
57de64c72267: Pull complete
4306be1e8943: Pull complete
871436ab7225: Pull complete
0110c26a367a: Pull complete
1f04fe713f1b: Pull complete
ac7c0b5fb553: Pull complete
Digest: sha256:2e95be60faf429d6c97d928c762cb36f1940f4456ce4bd33fbdc34de94a5e043
Status: Downloaded newer image for node:6.9.2
---> faaadb4aaf9b
Step 2/4 : EXPOSE 8080
---> Running in a3229e6d0438
Removing intermediate container a3229e6d0438
---> f8e1aa12de28
Step 3/4 : COPY server.js .
---> 5254ea79c7a4
Step 4/4 : CMD node server.js
---> Running in 060ef7e6f713
Removing intermediate container 060ef7e6f713
---> 2fe0fd2e98d7
Successfully built 2fe0fd2e98d7
Successfully tagged hello-node:v1
部署
使用 kubectl 命令行部署应用。
bogon:k8s rousseau$ kubectl run hello-node --image=hello-node:v1 --port=8080
deployment.apps "hello-node" created
bogon:k8s rousseau$ kubectl get deployments
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
hello-node 1 1 1 1 26s
bogon:k8s rousseau$ kubectl get pods
NAME READY STATUS RESTARTS AGE
hello-node-658d8f6754-7mz28 1/1 Running 0 37s
Pods在Kubernetes中是一组容器的集合,在这个例子中只有一个容器实例,所以看到的各项统计数字都是1。
创建服务
默认情况下,Pod只能通过内部地址访问,为了让 hello-node 可以从外部访问,需要将Pod暴露为 Kubernetes 的服务。
bogon:k8s rousseau$ kubectl expose deployment hello-node --type=LoadBalancer
service "hello-node" exposed
bogon:k8s rousseau$ kubectl get services
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
hello-node LoadBalancer 10.108.143.198 <pending> 8080:32386/TCP 7s
kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 1h
--type=LoadBalancer参数表示我们希望将我们的服务暴露在外面,在云的环境中支持负载均衡情况下,只需要提供负载均衡的地址。在Minikube中,LoadBanlancer类型让服务可以通过minikube service来访问
minikube service hello-node
这个命令会自动打开浏览器窗口访问服务,使用本地IP。
更新应用
假设我们更新了应用,输出新的一段话。
response.end('Hello World Again!');
生成镜像
docker build -t hello-node:v2 .
更新部署
kubectl set image deployment/hello-node hello-node=hello-node:v2
查看更新
minikube service hello-node
销毁服务
kubectl delete service hello-node
kubectl delete deployment hello-node
参考资料:
1、Minikube - Kubernetes本地实验环境
2、Hello Minikube
3、Running Kubernetes Locally via Minikube
4、Install Minikube
Minikube体验的更多相关文章
- minikube国内在线部署体验
问题描述: 快速学习k8s的各个组件的作用及yml的编写,minikube很适合. how to install Minikube, a tool that runs a single-node Ku ...
- Minikube之Win10单机部署
Kubernetes(k8s)是自动化容器操作的开源平台,基于这个平台,你可以进行容器部署,资源调度和集群扩容等操作.如果你曾经用过Docker部署容器,那么可以将Docker看成Kubernetes ...
- Kubernetes 笔记 02 demo 初体验
本文首发于我的公众号 Linux云计算网络(id: cloud_dev),专注于干货分享,号内有 10T 书籍和视频资源,后台回复「1024」即可领取,欢迎大家关注,二维码文末可以扫. 从前面的文章我 ...
- 安装指定版本的minikube
Minikube是什么? Kubernetes集群的安装和部署对于很多初学者来说是一道坎.为了方便大家开发和体验Kubernetes,Kubernetes开源社区提供了可以在本地部署的Minikube ...
- Minikube之Win10单机部署Kubernetes(k8s)自动化容器操作的开源平台
Minikube之Win10单机部署 Kubernetes(k8s)是自动化容器操作的开源平台,基于这个平台,你可以进行容器部署,资源调度和集群扩容等操作.如果你曾经用过Docker部署容器,那么可以 ...
- Minikube安装成功Kubernetes,一次过!
介绍 Minikube 是 K8S 官方为了开发者能在个人电脑上运行 K8S 而提供的一套工具.实现上是通过 Go 语言编写,通过调用虚拟化管理程序,创建出一个运行在虚拟机内的单节点集群. 注:从这里 ...
- containerd 与安全沙箱的 Kubernetes 初体验
作者 | 易立 阿里云资深技术专家 containerd 是一个开源的行业标准容器运行时,关注于简单.稳定和可移植,同时支持 Linux 和 Windows. 2016 年 12 月 14 日,Do ...
- kubeadm搭建K8s集群及Pod初体验
基于Kubeadm 搭建K8s集群: 通过上一篇博客,我们已经基本了解了 k8s 的基本概念,也许你现在还是有些模糊,说真的我也是很模糊的.只有不断地操作去熟练,强化自己对他的认知,才能提升境界. 我 ...
- K8S Kubernetes 简单介绍 转自 http://time-track.cn/kubernetes-trial.html Kubernetes初体验
这段时间学习了一下 git jenkins docker 最近也在看 Kubernetes 感觉写得很赞 也是对自己对于K8S 有了进一步得理解 感谢 倪 大神得Blog 也希望看到这篇Bl ...
随机推荐
- Qwidget+opencv显示图像
步骤 1. 设置opencv库路径 在.pro文件中添加 INCLUDEPATH += D:/opencv/OpencvMingw/opencv310/include LIBS += D:/openc ...
- Maximum Shortest Distance 最大团 二分答案 HDU 3585
题意:给出n个点 要求取k个点 这k个点中 距离最小的两个点要求距离最大 拿到手看不出是最大团 也看不出是二分答案(第一次用) 因为答案必然存在 一定有一个最值 所以用二分答案来做 最大距 ...
- Javassist学习总结
今天在弄dubbo时出现了一个依赖缺少问题,就好奇研究一下,这个依赖是啥. javassist是一个字节码类库,可以用他来动态生成类,动态修改类等等 1.介绍Javassist 要想将编译时不存在的类 ...
- P1757 通天之分组背包
P1757 通天之分组背包背包中的经典问题,我竟然不知道.分组背包就是每个物品有一个所属的小组,小组内的物品会冲突.就是把01背包中的两个for换一下位置01:for(i,1,kind) for(j, ...
- 使用JQuery获取对象的几种方式(转)
原文:http://51876.iteye.com/blog/1350358 1.先讲讲JQuery的概念 JQuery首先是由一个 America 的叫什么 John Resig的人创建的,后来又很 ...
- Eclipse下Maven新建项目、自动打依赖jar包(包含普通项目和Web项目)
不多说,直接上干货! 当我们无法从本地仓库找到需要的构件的时候,就会从远程仓库下载构件至本地仓库.一般地,对于每个人来说,书房只有一个,但外面的书店有很多,类似第,对于Maven来说,每个用户只有一个 ...
- 002.Postfix空客户端配置
一 空客户端介绍 空客户端必须满足(符合)以下条件: 本地发送的任何邮件都会转发到现有出站邮件中继以进行发送 本地postfix服务不接受任何电子邮件的本地发送 用户可以在空客户端运行邮件客户端来读取 ...
- STM32 F4 ADC DMA Temperature Sensor
STM32 F4 ADC DMA Temperature Sensor Goal: detecting temperature variations using a temperature senso ...
- [置顶] Android系统移植与调试之------->build.prop文件详细赏析
小知识:什么是build.prop? /system/build.prop 是一个属性文件,在Android系统中.prop文件很重要,记录了系统的设置和改变,类似於/etc中的文件.这个文件是如 ...
- javascript UI框架
http://www.jianshu.com/p/709e8d6c03c9 http://www.cnblogs.com/kingboy2008/p/5261771.html jQuery uiboo ...