本文共 8303 字,大约阅读时间需要 27 分钟。
Kubernetes(通常写成“k8s”)Kubernetes是Google开源的容器集群管理系统。其设计目标是在主机集群之间提供一个能够自动化部署、可拓展、应用容器可运营的平台。Kubernetes通常结合docker容器工具工作,并且整合多个运行着docker容器的主机集群,Kubernetes不仅仅支持Docker,还支持Rocket,这是另一种容器技术。
功能特性:Master节点上面主要由四个模块组成:APIServer、scheduler、controller manager、etcd
每个Node节点主要由三个模块组成:kubelet、kube-proxy、runtime。
runtime。runtime指的是容器运行环境,目前Kubernetes支持docker和rkt两种容器。Pod是k8s进行资源调度的最小单位,每个Pod中运行着一个或多个密切相关的业务容器,这些业务容器共享这个Pause容器的IP和Volume,我们以这个不易死亡的Pause容器作为Pod的根容器,以它的状态表示整个容器组的状态。一个Pod一旦被创建就会放到Etcd中存储,然后由Master调度到一个Node绑定,由这个Node上的Kubelet进行实例化。
每个Pod会被分配一个单独的Pod IP,Pod IP + ContainerPort 组成了一个Endpoint。Service其功能使应用暴露,Pods 是有生命周期的,也有独立的 IP 地址,随着 Pods 的创建与销毁,一个必不可少的工作就是保证各个应用能够感知这种变化。这就要提到 Service 了,Service 是 YAML 或 JSON 定义的由 Pods 通过某种策略的逻辑组合。更重要的是,Pods 的独立 IP 需要通过 Service 暴露到网络中。
安装有较多方式,在此使用二进制安装和利用kubadm进行安装部署
名称 | 主机名称 | IP地址 | 安装软件包 | 系统版本 |
---|---|---|---|---|
kubernets server | master | 172.16.0.67 | etcd,kube-apiserver,kube-controller-manager,kube-scheduler | CentOS7.3 64位 |
kubernets node1 | node01 | 172.16.0.66 | kubelet,kube-proxy,docker | CentOS7.3 64位 |
kubernets node1 | node02 | 172.16.0.68 | kubelet,kube-proxy,docker | CentOS7.3 64位 |
软件版本
kubenets网址server端二进制文件node端二进制文件防火墙配置
systemctl stop firewalldsystemctl disable firewalldsystemctl mask firewalldmaster服务器安装etcd
yum install etcd -y
配置etcd,并启动服务器配置开机自启动
下载软件包,创建目录拷贝文件
cd /tmp && wget -c https://dl.k8s.io/v1.8.13/kubernetes-server-linux-amd64.tar.gztar -zxf kubernetes-server-linux-amd64.tar.gzmkdir -p /opt/kubernetes/{bin,cfg}mv kubernetes/server/bin/{kube-apiserver,kube-scheduler,kube-controller-manager,kubectl} /opt/kubernetes/bin
cat > /opt/kubernetes/cfg/kube-apiserver<
cat >/lib/systemd/system/kube-apiserver.service<
systemctl daemon-reloadsystemctl enable kube-apiserversystemctl start kube-apiserver
cat >/opt/kubernetes/cfg/kube-scheduler <
cat>/lib/systemd/system/kube-scheduler.service<
systemctl daemon-reloadsystemctl enable kube-schedulersystemctl restart kube-scheduler
cat > /opt/kubernetes/cfg/kube-controller-manager<
cat > /lib/systemd/system/kube-controller-manager.service<
systemctl daemon-reloadsystemctl enable kube-controller-managersystemctl start kube-controller-manager
至此master就已经配置完成,如若配置中有错误,可以通过#journalctl -u 服务名称
查看报错,
为方便使用添加环境变量
echo "export PATH=\$PATH:/opt/kubernetes/bin" >> /etc/profilesource /etc/profile
yum install -y yum-utils device-mapper-persistent-data lvm2yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repoyum makecache fastyum install docker-ce -y
cd /tmp && wget https://dl.k8s.io/v1.8.13/kubernetes-node-linux-amd64.tar.gztar -zxf kubernetes-node-linux-amd64.tar.gzmkdir -p /opt/kubernetes/{bin,cfg}mv kubernetes/node/bin/{kubelet,kube-proxy} /opt/kubernetes/bin/
cat > /opt/kubernetes/cfg/kubelet.kubeconfig <
cat> /opt/kubernetes/cfg/kubelet <
cat>/lib/systemd/system/kubelet.service<
启动服务
systemctl daemon-reloadsystemctl enable kubeletsystemctl start kubelet创建配置文件
cat>/opt/kubernetes/cfg/kube-proxy <
创建systemd服务文件
cat > /lib/systemd/system/kube-proxy.service<
启动服务
systemctl daemon-reloadsystemctl enable kube-proxysystemctl restart kube-proxy
其他节点加入集群与node01方式相同,但需修改kubelet的--address和--hostname-override选项为本机IP即可。
yum install -y dockersystemctl enable docker && systemctl start docker
cat </etc/yum.repos.d/kubernetes.repo[kubernetes]name=Kubernetesbaseurl=https://packages.cloud.google.com/yum/repos/kubernetes-el7-x86_64enabled=1gpgcheck=1repo_gpgcheck=1gpgkey=https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpgEOF
cat </etc/sysctl.d/k8s.confnet.bridge.bridge-nf-call-ip6tables = 1net.bridge.bridge-nf-call-iptables = 1EOFsysctl --system
yum install -y kubelet kubeadm kubectlsystemctl enable kubelet && systemctl start kubeletsystemctl daemon-reloadsystemctl restart kubelet
kubeadm init --pod-network-cidr=10.244.0.0/16
--apiserver-advertise-address 指明用 Master 的哪个 interface 与 Cluster 的其他节点通信。如果 Master 有多个 interface,建议明确指定,如果不指定,kubeadm 会自动选择有默认网关的 interface。
--pod-network-cidr 指定 Pod 网络的范围。Kubernetes 支持多种网络方案,而且不同网络方案对 --pod-network-cidr 有自己的要求,这里设置为 10.244.0.0/16 是因为我们将使用 flannel 网络方案,必须设置成这个 CIDR。命令执行完成会返回提示如何注册其他节点到 Cluster,此处需要记录下token值,或整条命令。# 创建用户useradd xuelpasswd xuel# 切换到普通用户su - xuel mkdir -p $HOME/.kubesudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/configsudo chown $(id -u):$(id -g) $HOME/.kube/config# 配置环境变量export KUBECONFIG=/etc/kubernetes/admin.confecho "source <(kubectl completion bash)" >> ~/.bashrc
建议用普通用户操作kubectl
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
在需要加入集群的node节点也需要安装docker 和 kubeadm ,启动kubelet服务等操作,和master节点一样,在此就省略。
kubeadm join 172.16.0.64:6443 --token dt5tet.26peoqdwftx7yafv --discovery-token-ca-cert-hash sha256:5b4030d19662122204ff78a4fd0ac496b739a9945517deca67a9384f0bab2b21
kubectl get nodeskubectl get pod --all-namespaces
git clone https://github.com/redhatxl/k8s-prometheus-grafana.git
docker pull prom/node-exporterdocker pull prom/prometheus:v2.0.0docker pull grafana/grafana:4.2.0
kubectl create -f node-exporter.yaml
kubectl create -f k8s-prometheus-grafana/prometheus/rbac-setup.yaml
kubectl create -f k8s-prometheus-grafana/prometheus/configmap.yaml
kubectl create -f k8s-prometheus-grafana/prometheus/prometheus.deploy.yml
kubectl create -f k8s-prometheus-grafana/prometheus/prometheus.svc.yml
kubectl create -f k8s-prometheus-grafana/grafana/grafana-deploy.yaml
kubectl create -f k8s-prometheus-grafana/grafana/grafana-svc.yaml
kubectl create -f k8s-prometheus-grafana/grafana/grafana-ing.yaml
查看node-exporter
prometheus对应的nodeport端口为30003,通过访问http://47.52.166.125:30003/target 可以看到prometheus已经成功连接上了k8s的apiserver
通过端口进行granfa访问,默认用户名密码均为admin 添加数据源 导入面板,可以直接输入模板编号315在线导入,或者下载好对应的json模板文件本地导入,面板模板下载地址https:///dashboards/315查看展示效果kubectl delete deployment apache
查看具体详细事件kubectl get pods -o widekubectl expose deployment nginx --port=88 --target-port=80 --type=NodePort
配置kubernetes-dashboard.yaml
cat >kubernetes-dashboard.yaml<
转载于:https://blog.51cto.com/kaliarch/2160569