
本身在 K8S 中部署一个应用是需要写 yaml 文件的,我们这次简单部署,通过拉取网络上的镜像来部署应用,会用图解的方式来分享一下,过程中都发生了什么
简单部署一个程序
我们可以通过 kubectl run
的方式来简单部署一个应用,现在我们先不关心里面的 yaml 结构和具体的配置,先运行起来,看看效果
kubectl run mykubia --image=luksa/kubia --port=9999 --generator=run/v1
,执行该命令,就可以创建一个容器,并运行起来
$ kubectl get pods
NAME READY STATUS RESTARTS AGE
mykubia 1/1 Running 0 63s
可以看到 我们的 mykubia 应用已经运行起来的,我们可以通过命令 kubectl logs -f mykubia
查看日志

在上命令中,解释一下:
-
--image=luksa/kubia
指定一个要运行的容器镜像
-
--port=9999
指的是我们指定服务运行的端口号是 9999
-
--generator=run/v1
加上这个标志指的是 让 k8s 集群创建一个 ReplicationController ,而不是一个 Deployment
pod 是什么
在 K8S 中,一个 pod 是一组紧密相关的容器,它们总是运行在同一个工作节点上面,他们有着同样的 Linux 命名空间

每一个 pod 就像是一个独立的逻辑机器,他有这些资源:
-
自己的 IP -
主机名 -
进程 -
能够运行一个独立的应用程序
这里面运行的应用程序可以是单进程的,运行在单个容器中,每一个进程都会在自己的容器运行
如上图,每一个 pod 都会有自己的 IP,一个 pod 会包含 1 个或者多个 容器,多个 pod 也会分布在不同的工作节点上面
从执行命令到容器运行背后都发生了哪些动作?

从程序员敲入命令到实际服务运行可以简单的分成 8 个步骤,如上图:
-
1
构建镜像,必须先要把 镜像推送到 Docker Hub 上面,这一步是 执行 docker push luksa/kubia
-
2
docker 服务器将镜像推送到 docker hub 中
-
3
kubectl 收到指令,kubectl run mykubia --image=lukia/kubia --port=9999
-
4
kubectl 想 REST API 服务器发送请求,请求调度
-
5
主节点收到请求后,创建 Pod ,并调度到工作节点
-
6
工作节点收到主节点的调度通知
-
7
工作节点 使用 kubelet 指令告诉自己环境中 docker 要运行镜像了
-
8
工作节点的 docker 于是就向 Docker Hub 拉取镜像,运行
最终,呈现出来的就是,我们通过指令 kubectl get pods 的时候,就可以看到我们的 pod 在运行了
外部如何访问 pod 中的服务?
我们如何在外部访问在 pod 运行中的服务呢?
我们可以通过指令:kubectl get pods -o wide
查看更多详细信息

虽然说每一个 pod 都有一个自己的 IP,但是这个 IP 只有在集群内部才可以访问的,在外部是没有办法访问的
我们在内部访问内部肯定是没有问题的

curl 一下 这个 ip 例如,curl 172.18.0.6:8080
要从外部访问内部的 pod 中的服务,我们可以创建一个特殊的 LoadBalancer 类型的服务(service)
创建一个服务对象
我们创建的这个服务对象,外部就可以访问到内部 pod 中的服务了
我们必须是要创建 LoadBalancer 类型的服务才可以,如果我们创建 ClusterIP 类型的服务也是不行的,
ClusterIP 类型的服务 是 K8S 内部默认的类型,默认只能在内部互相访问,外部是无法访问的
我们可以执行如下指令:
kubectl expose rc mykubia --type=LoadBalancer --name kubia-http
-
rc mykubia
指的是要告诉 k8s 我们之前创建的 ReplicationController
此处的 rc 是 ReplicationController 的缩写
-
–type=LoadBalancer
执行类型为 LoadBalancer ,指定为 LoadBalancer 类型后,将会创建一个外部的负载均衡服务,外部可以通过这个服务的 ip 来访问到内部的 pod
查看服务
我们可以通过 kubectl get services
来查看服务列表

查看服务列表的时候,我们可以看到 EXTERNAL-IP 部分,刚开始是显示
当有了明确的外部 IP, 那么外部就可以通过该 IP 来访问我们的内部服务了
当然,如果你现在在使用的还是 minikube ,也是可以这样来玩的
因为 minikube 上面是单节点集群的,我们可以敲入指令:minikube service kubia-http

就可以看到如上信息,我们就可以通过这个 ip 来访问这个服务了
今天就到这里,学习所得,若有偏差,还请斧正
欢迎点赞,关注,收藏
朋友们,你的支持和鼓励,是我坚持分享,提高质量的动力

好了,本次就到这里
技术是开放的,我们的心态,更应是开放的。拥抱变化,向阳而生,努力向前行。
我是阿兵云原生,欢迎点赞关注收藏,下次见~
原文始发于微信公众号(阿兵云原生):在 K8S 中部署一个应用 上
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/175341.html