Kubernetes(k8s)的前世今生

 

理解云计算的实质,Kubernetes就好理解了,它提供的是容器云。在私有数据中心,服务运行在物理主机的Host OS上,云计算场景下运行在虚拟机上,k8s场景下应用运行在容器内,容器替代了虚拟机。

容器是什么?

在Linux上,容器技术的底层实现机制是Linux Kernel的Control Group(CGroup)。它维护各种各样的名字空间(进程ID,IPC,网络等等),并按照Group管理系统资源分配和释放。可以在每个CGroup上施加限制(CPU、内存、IO等等),确保资源的使用配额。所有的容器可以有自己的资源和文件系统镜像。但是共享内核、容器比虚拟机开销小,性能上占优势,虚拟机比容器隔离性(isolation)好,更容易保证不同租客不相互影响。

容器技术有多种选择,Docker和Singularity是两种比较流行的选择。它们的底层机制是共通的,但是在镜像管理上有差别。Docker通过层(Layer)与层的叠加优化镜像空间的利用率,通过Overlay2文件系统实现只读共享和写时拷贝。S

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
安装 KubernetesK8S)需要多个步骤,以下是一些基本步骤: 1. 准备好至少两台服务器,其中一台将用作主节点(Master Node),其余的将用作工作节点(Worker Nodes)。 2. 在每台服务器上安装 Docker。这可以通过命令行运行以下命令来完成: ``` $ curl -sSL get.docker.com | sh && \ sudo usermod -aG docker $USER ``` 3. 安装 Kubernetes 工具。Kubernetes 有很多不同的工具,但最常用的是 kubeadm、kubectl 和 kubelet。这些可以通过以下命令来安装: ``` $ sudo apt-get update && \ sudo apt-get install -y apt-transport-https curl && \ curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add - && \ echo "deb https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list && \ sudo apt-get update && \ sudo apt-get install -y kubelet kubeadm kubectl ``` 4. 在主节点上初始化 Kubernetes。这可以通过以下命令来完成: ``` $ sudo kubeadm init --pod-network-cidr=10.244.0.0/16 ``` 5. 安装网络插件。这将使您的工作节点可以与其他节点通信。我们建议使用 Flannel 网络插件,可以通过以下命令安装: ``` $ kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml ``` 6. 加入工作节点。在主节点上运行 `kubeadm init` 命令时,会生成一个命令,您可以将其复制到工作节点上运行,以加入 Kubernetes 集群。 ``` $ sudo kubeadm join <master-node-ip>:<master-node-port> --token <token> --discovery-token-ca-cert-hash <hash> ``` 以上是安装 Kubernetes 的基本步骤。请注意,这只是一个大致的指南,具体的步骤可能因您的环境而异。更详细的指南可以在 Kubernetes 官方文档中找到。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值