kube-apiserver 如何重启?

Dee*_*yak 8 kubernetes kube-apiserver

我今天重新启动了我的系统。之后,我的主系统和 Web 浏览器未连接以查找 kubernetes GUI。

当我运行命令时systemctl status kube-apiserver.service,它给出如下所示的输出:

kube-apiserver.service
  Loaded: not-found (Reason: No such file or directory)
  Active: inactive (dead)
Run Code Online (Sandbox Code Playgroud)

怎样才能api-server重新启动?

小智 6

将 kube-apiserver 清单文件从 /etc/kubernetes/manifests 文件夹移动到临时文件夹。这种方法的优点是 - 只要从清单文件夹中删除该文件,您就可以停止 kube-apiserver。

vagrant@master01:~$ ll /etc/kubernetes/manifests/
total 16
-rw------- 1 root root 3315 May 12 23:24 kube-controller-manager.yaml
-rw------- 1 root root 1384 May 12 23:24 kube-scheduler.yaml
-rw------- 1 root root 2157 May 12 23:24 etcd.yaml
-rw------- 1 root root 3792 May 20 00:08 kube-apiserver.yaml
vagrant@master01:~$ sudo mv /etc/kubernetes/manifests/kube-apiserver.yaml /tmp/
vagrant@master01:~$ 
vagrant@master01:~$ ll /etc/kubernetes/manifests/
total 12
-rw------- 1 root root 3315 May 12 23:24 kube-controller-manager.yaml
-rw------- 1 root root 1384 May 12 23:24 kube-scheduler.yaml
-rw------- 1 root root 2157 May 12 23:24 etcd.yaml
Run Code Online (Sandbox Code Playgroud)

API 服务器现已关闭-

vagrant@master01:~$ k get pods -n kube-system
The connection to the server 10.0.0.2:6443 was refused - did you specify the right host or port?
vagrant@master01:~$ 

vagrant@master01:~$ sudo mv /tmp/kube-apiserver.yaml /etc/kubernetes/manifests/
vagrant@master01:~$ 
vagrant@master01:~$ ll /etc/kubernetes/manifests/
total 16
-rw------- 1 root root 3315 May 12 23:24 kube-controller-manager.yaml
-rw------- 1 root root 1384 May 12 23:24 kube-scheduler.yaml
-rw------- 1 root root 2157 May 12 23:24 etcd.yaml
-rw------- 1 root root 3792 May 20 00:08 kube-apiserver.yaml
Run Code Online (Sandbox Code Playgroud)

API服务器现已启动

vagrant@master01:~$ k get pods -n kube-system
NAME                               READY   STATUS    RESTARTS   AGE
coredns-558bd4d5db-269lt           1/1     Running   5          8d
coredns-558bd4d5db-967d8           1/1     Running   5          8d
etcd-master01                      1/1     Running   6          8d
kube-apiserver-master01            0/1     Running   2          24h
kube-controller-manager-master01   1/1     Running   8          8d
kube-proxy-q8mkb                   1/1     Running   5          8d
kube-proxy-x6trg                   1/1     Running   6          8d
kube-proxy-xxph9                   1/1     Running   8          8d
kube-scheduler-master01            1/1     Running   8          8d
weave-net-rh2gb                    2/2     Running   18         8d
weave-net-s2cg9                    2/2     Running   14         8d
weave-net-wksk2                    2/2     Running   11         8d
vagrant@master01:~$ 
Run Code Online (Sandbox Code Playgroud)


Rtm*_*tmY 5

您是否直接下载并安装了Kubernetes 控制器二进制文件

1 )如果是,请检查kube-apiserver.servicesystemd 单元文件是否存在:

cat /etc/systemd/system/kube-apiserver.service
Run Code Online (Sandbox Code Playgroud)

2)如果没有,您可能使用安装了
通过此设置,kubeapi-server作为 pod 在主节点上运行

kubectl get pods -n kube-system
NAME                                       READY   STATUS    
coredns-f9fd979d6-jsn6w                    1/1     Running  ..
coredns-f9fd979d6-tv5j6                    1/1     Running  ..
etcd-master-k8s                            1/1     Running  ..
kube-apiserver-master-k8s                  1/1     Running  .. #<--- Here
kube-controller-manager-master-k8s         1/1     Running  ..
kube-proxy-5kzbc                           1/1     Running  ..
kube-scheduler-master-k8s                  1/1     Running  ..
Run Code Online (Sandbox Code Playgroud)

而不是作为系统服务。

因此,由于您无法在 K8S 中重新启动 Pod,因此您必须将其删除:

kubectl delete pod/kube-apiserver-master-k8s -n kube-system
Run Code Online (Sandbox Code Playgroud)

并且会立即创建一个新的 pod。


(*) 当您运行kubeadm init 时,您应该会看到为控制平面静态 Pods创建的清单:

.
. 
[control-plane] Using manifest folder "/etc/kubernetes/manifests"
[control-plane] Creating static Pod manifest for "kube-apiserver"
[control-plane] Creating static Pod manifest for "kube-controller-manager"
[control-plane] Creating static Pod manifest for "kube-scheduler"
[etcd] Creating static Pod manifest for local etcd in "/etc/kubernetes/manifests"
.
.
Run Code Online (Sandbox Code Playgroud)

对应的yaml:

ubuntu@master-k8s:/etc/kubernetes/manifests$ ls -la
total 24
drwxr-xr-x 2 root root 4096 Oct 14 00:13 .
drwxr-xr-x 4 root root 4096 Sep 29 02:30 ..
-rw------- 1 root root 2099 Sep 29 02:30 etcd.yaml
-rw------- 1 root root 3863 Oct 14 00:13 kube-apiserver.yaml <----- Here
-rw------- 1 root root 3496 Sep 29 02:30 kube-controller-manager.yaml
-rw------- 1 root root 1384 Sep 29 02:30 kube-scheduler.yaml
Run Code Online (Sandbox Code Playgroud)

以及kube-apiserver规范:

apiVersion: v1
kind: Pod
metadata:
  annotations:
    kubeadm.kubernetes.io/kube-apiserver.advertise-address.endpoint: 10.100.102.5:6443
  creationTimestamp: null
  labels:
    component: kube-apiserver
    tier: control-plane
  name: kube-apiserver
  namespace: kube-system
spec:
  containers:
  - command:
    - kube-apiserver
    - --advertise-address=10.100.102.5
    - --allow-privileged=true
    - --authorization-mode=Node,RBAC
    - --client-ca-file=/etc/kubernetes/pki/ca.crt
    - --enable-admission-plugins=NodeRestriction
    - --enable-bootstrap-token-auth=true
    .
    .
    .
Run Code Online (Sandbox Code Playgroud)

  • 这是不正确的。您无法运行 kubectl delete pod/kube-apiserver-master-k8s -n kube-system 来重新启动 kube-apiserver 容器。这将删除 Pod。容器将继续运行。Pod 将立即重新创建,这是正确的,并将正在运行的容器重新分配给 Pod,而无需终止容器进程!编辑:如果你想重新启动 kube-apiserver,你必须杀死容器本身。例如通过 docker 或 crictl。 (2认同)

Sud*_*NSR 0

我有类似的问题,但做了一些简单的事情来解决这个问题。我认为这只是systemctl status kube-apiserver

如果上述方法有效,请尝试以下步骤

关于大师:

重启所有服务 etcd kube-apiserver kube-controller-manager kube-scheduler flanneld

在工作节点/节点上:

重启所有服务 kube-proxy kubelet flanneld docker

例如:

systemctl restart kube-controller-manager
systemctl enable kube-controller-manager
systemctl status kube-controller-manager
Run Code Online (Sandbox Code Playgroud)

注意:如果它的节点既是master又是worker。在同一节点上启动两者。

上述步骤对我有用(但我们正在开发 1.7)。希望有帮助