前言:关于k8s 与 docker
Docker和Kubernetes(通常简称为K8s)是两个在容器化应用程序方面非常流行的开源工具。
Docker:
Docker 是一种轻量级的容器化平台,允许开发者将应用程序及其所有依赖项打包到一个称为容器的可移植容器中。每个容器都运行在宿主操作系统的独立进程中,具有自己的文件系统和网络空间。Docker 提供了一种标准化的方式,使应用程序能够在不同的环境中轻松部署和运行。Docker 镜像包含了应用程序的代码、运行时、系统工具、系统库等。
Kubernetes (K8s):
Kubernetes 是一个用于自动部署、扩展和管理容器化应用程序的开源容器编排工具。它提供了一种容器编排系统,可以自动化应用程序的部署、伸缩和管理。Kubernetes 允许用户定义容器的部署、配置和调度,确保它们在整个集群中以高效和可靠的方式运行。K8s 提供了强大的功能,如自动负载均衡、滚动更新、自动扩展等,使得在大规模容器化环境中管理应用变得更加容易。
关系与区别:
-
关系: Docker 可以用于创建、打包和分发容器,而 Kubernetes 用于在一个集群中管理这些容器的部署、伸缩和运维。
-
单机 vs. 集群: Docker 主要关注单个主机上的容器化,而 Kubernetes 更专注于在多个主机上协调和管理容器。
-
抽象层次: Docker 提供了一个容器运行时环境,而 Kubernetes 提供了容器编排和管理的整体解决方案。
-
自动化: Kubernetes 提供更高级别的自动化,例如自动负载均衡、自动扩展、滚动更新等功能,使得在生产环境中更容易管理大规模应用。
通常,组合使用 Docker 和 Kubernetes 可以提供一个完整的容器化解决方案,使开发者能够方便地开发、测试和部署应用程序,并在生产环境中有效地管理这些应用程序。
kubectl 常用命令集合
1. 语法规则
kubectl [command] [TYPE] [NAME] [flags]
- command :指定要对一个或多个资源执行的操作,例如 create 、 get 、 describe 、 delete
- TYPE :指定资源类型。资源类型不区分大小写,可以指定单数、复数或缩写形式。
- NAME :指定资源的名称。名称区分大小写。如果省略名称,则显示所有资源的详细信息 kubectl get pods 。
- flags : 指定可选的参数。例如,可以使用 -s 或 -server 参数指定 Kubernetes API 服务器的地址和端口。
1.1 get命令
# 查看集群状态信息kubectl cluster-info# 查看集群状态kubectl get cs# 查看集群节点信息kubectl get nodes# 查看集群命名空间kubectl get ns# 查看指定命名空间的服务kubectl get svc -n kube-system# 以纯文本输出格式列出所有 pod 。kubectl get pods# 以纯文本输出格式列出所有 pod ,并包含附加信息 ( 如节点名 ) 。kubectl get pods -o wide# 以纯文本输出格式列出具有指定名称的副本控制器。提示:您可以使用别名 'rc' 缩短和替换'replicationcontroller' 资源类型。kubectl get replicationcontroller <rc-name># 以纯文本输出格式列出所有副本控制器和服务。kubectl get rc,services# 以纯文本输出格式列出所有守护程序集,包括未初始化的守护程序集。kubectl get ds --include-uninitialized# 列出在节点 server01 上运行的所有 podkubectl get pods --field-selector=spec.nodeName=server01
1.2 describe 命令
# 显示名称为 <node-name> 的节点的详细信息。kubectl describe nodes <node-name># 显示名为 <pod-name> 的 pod 的详细信息。kubectl describe pods/<pod-name># 显示由名为 <rc-name> 的副本控制器管理的所有 pod 的详细信息。# 记住:副本控制器创建的任何 pod 都以复制控制器的名称为前缀。kubectl describe pods <rc-name># 描述所有的 pod ,不包括未初始化的 podkubectl describe pods --include-uninitialized=false
说明: kubectl get 命令通常用于检索同一资源类型的一个或多个资源。 它具有丰富的参数, 允许您使用 - o 或 -- output 参数自定义输出格式。您可以指定 - w 或 -- watch 参数以开始观察 特定对象的更新。 kubectl describe 命令更侧重于描述指定资源的许多相关方面。它可以调用 对 API 服务器 的多个 API 调用来为用户构建视图。 例如,该 kubectl describe node 命令不 仅检索有关节点的信息,还检索在其上运行的 pod 的摘要,为节点生成的事件等。
1.3 delete命令
# 使用 pod.yaml 文件中指定的类型和名称删除 pod 。kubectl delete -f pod.yaml# 删除标签名 = <label-name> 的所有 pod 和服务。kubectl delete pods,services -l name=<label-name># 删除所有具有标签名称 = <label-name> 的 pod 和服务,包括未初始化的那些。kubectl delete pods,services -l name=<label-name> --include-uninitialized# 删除所有 pod ,包括未初始化的 pod 。kubectl delete pods --all
1.4 进入容器命令
# 从 pod <pod-name> 中获取运行 'date' 的输出。默认情况下,输出来自第一个容器。kubectl exec <pod-name> date# 运行输出 'date' 获取在容器的 <container-name> 中 pod <pod-name> 的输出。kubectl exec <pod-name> -c <container-name> date# 获取一个交互 TTY 并运行 /bin/bash <pod-name > 。默认情况下,输出来自第一个容器。kubectl exec -ti <pod-name> /bin/bash
1.5 logs命令
# 从 pod 返回日志快照。kubectl logs <pod-name># 从 pod <pod-name> 开始流式传输日志。这类似于 'tail -f' Linux 命令。kubectl logs -f <pod-name>
1.6 格式化输出
将 pod 信息格式化输出到一个 yaml 文件kubectl get pod web-pod-13je7 -o yaml