AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 564654
Accepted
CodeMed
CodeMed
Asked: 2020-01-29 16:27:56 +0800 CST2020-01-29 16:27:56 +0800 CST 2020-01-29 16:27:56 +0800 CST

无法识别文件。拒绝连接

  • 772

connection refused在 Amazon Linux 2 实例上,每次运行引用文件路径的命令时,命令行都会引发以下错误。当使用httpsurl 代替文件路径时,也会引发相同的错误。

为什么会发生这种情况,如何解决这个问题,以便可以从命令行读取和使用文件?

这是控制台输出:

[kubernetes-host@ip-of-ec2-instance ~]$ sudo kubectl apply -f rbac-kdd.yaml | tee kubeadm-rbac-kdd.out
unable to recognize "rbac-kdd.yaml": Get http://localhost:8080/api?timeout=32s: dial tcp 127.0.0.1:8080: connect: connection refused
unable to recognize "rbac-kdd.yaml": Get http://localhost:8080/api?timeout=32s: dial tcp 127.0.0.1:8080: connect: connection refused
[kubernetes-host@ip-of-ec2-instance ~]$

文件的相对路径是正确的。该命令正在尝试将 calico 应用于由 创建的 Kubernetes 集群kubeadm,如果有帮助的话。 但我认为这是一个基本的 linux 问题。

SELinux 已在此 Amazon Linux 2 EC2 实例上禁用。

在我尝试确定可能的原因时,希望能得到一些指示。


问题隔离:

另外,.kube/config指示端口的内容6443如下:

[kubernetes-host@ip-of-ec2-instance ~]$ cat /home/kubernetes-host/.kube/config
apiVersion: v1
clusters:
- cluster:
    certificate-authority-data: <encrypted-certificate-authority-data-here>
    server: https://ip-of-ec2-instance:6443
  name: kubernetes
contexts:
- context:
    cluster: kubernetes
    user: kubernetes-admin
  name: kubernetes-admin@kubernetes
current-context: kubernetes-admin@kubernetes
kind: Config
preferences: {}
users:
- name: kubernetes-admin
  user:
    client-certificate-data: <encrypted-client-certificate-data-here>
    client-key-data: <encrypted-client-key-data-here>
[kubernetes-host@ip-of-ec2-instance ~]$

问题似乎是kubectl apply命令正在使用 port8080而 Kubernetes apiserver 正在使用 port 6443。如何纠正这种不匹配以使kubectl apply命令使用 port 6443?

进一步,kubectl能够看到6443是正确的端口,并且curl可以到达正确的6443端口,如下:

[kubernetes-host@ip-of-ec2-instance ~]$ kubectl cluster-info
Kubernetes master is running at https://ip-of-ec2-instance:6443
KubeDNS is running at https://ip-of-ec2-instance:6443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy  

To further debug and diagnose cluster problems, use 'kubectl cluster-info dump'.

[kubernetes-host@ip-of-ec2-instance ~]$ curl https://ip-of-ec2-instance:6443
curl: (60) SSL certificate problem: unable to get local issuer certificate
More details here: https://curl.haxx.se/docs/sslcerts.html

curl failed to verify the legitimacy of the server and therefore could not
establish a secure connection to it. To learn more about this situation and
how to fix it, please visit the web page mentioned above.
[kubernetes-host@ip-of-ec2-instance ~]$

[kubernetes-host@ip-of-ec2-instance ~]$ curl https://127.0.0.1:6443
curl: (60) SSL certificate problem: unable to get local issuer certificate
More details here: https://curl.haxx.se/docs/sslcerts.html

curl failed to verify the legitimacy of the server and therefore could not
establish a secure connection to it. To learn more about this situation and
how to fix it, please visit the web page mentioned above.
[kubernetes-host@ip-of-ec2-instance ~]$

为什么kubectl apply不能映射到端口6443,什么时候kubectl cluster-info能够映射到正确的端口?

files command-line
  • 1 1 个回答
  • 786 Views

1 个回答

  • Voted
  1. Best Answer
    TopherIsSwell
    2020-01-30T10:51:33+08:002020-01-30T10:51:33+08:00

    这看起来您无法连接到 Kubernetes API 服务器。这可能有很多原因

    • Kubernetes API 服务器未运行
    • API 服务器未在 TCP/8080 上侦听
    • API 服务器未监听 127.0.0.1 的环回地址
    • API 服务器未使用 HTTP(但使用 HTTPS)进行侦听
    • 本地防火墙(例如 iptables)正在阻止连接
    • TCPwrapper 正在阻止连接。
    • 诸如 SELinux 之类的强制访问控制系统正在阻止连接,但您说这已被禁用。如果您在 Amazon Linux 上安装了 AppArmor,那么我不知道是否有人可以帮助您。:)
    • 这个列表可以继续解释为什么这种联系不会发生的更多深奥的原因。
    一些补救/故障排除步骤
    • 确保 k8s api 服务器正在运行(我不知道您是如何安装它的,所以我无法建议您如何检查,可能使用systemctl statusor docker ps)。
    • 运行ss -ln并检查在 127.0.0.1:8080 或 *:8080 上监听的内容
    • 看看您是否可以使用其他东西连接到套接字curl -k https://127.0.0.1:8080以检查 https 或curl http://127.0.0.1:8080HTTP。
    • 如果您的 API 服务器在 docker 容器中运行,请确保它正在侦听主机上的 8080。docker ps或docker inspect查看端口转发。
    • 检查防火墙,iptables -S这是一个长镜头,你不会经常看到规则阻止数据包进入本地主机。
    • 检查 /etc/hosts.deny 是否有任何可能阻止您的内容(同样,这是一个很长的镜头,因为这通常不会被意外配置)。

    编辑

    在查看更多故障排除数据后。我注意到您kubectl以 root 身份运行。您的 kubeconfig 位于用户目录中。您应该以用户“kubernetes-host”的身份运行 kubectl,只需sudo在命令开头删除 即可。kubeconfig 文件会将 Kubectl 引导到正确的端点(地址和端口),但以 root 身份运行,kubectl 不会检查 /home/kubernetes-host/.kube/config。

    所以试试kubectl apply -f rbac-kdd.yaml

    如果由于某种原因必须以 root 身份运行,您应该:

    1) 质疑导致你来到这里的生活选择。

    2) 运行sudo kubectl apply --kubeconfig=/home/kubernetes-host/.kube/config -f rbac-kdd.yaml以显式使用 kubernetes-host 用户主目录中的配置。

    • 1

相关问题

  • 需要许多参数的实用程序的推荐界面是什么?[关闭]

  • 远程运行 X 应用程序,在远程主机上运行 GUI [关闭]

  • 使 mysql CLI 以交互方式向我询问密码

  • du/df 和 ls 报告不同的磁盘使用情况

  • 没有服务器的命令行 pub/sub?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve