如何在物理主机上安全访问Grafana?
创作时间:
作者:
@小白创作中心
如何在物理主机上安全访问Grafana?
引用
7
来源
1.
https://www.solo.io/topics/kubernetes-api-gateway/kubernetes-ingress
2.
https://learn.microsoft.com/zh-cn/python/api/azure-mgmt-compute/azure.mgmt.compute.v2019_07_01.models.virtualmachinescalesetipconfiguration?view=azure-python
3.
https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/
4.
https://m.book118.com/html/2017/0823/129724278.shtm
5.
http://dict.youdao.com/w/virtual_machine_configuration/
6.
https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/custom-template/
7.
https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/
在物理主机上访问通过虚拟机部署的 Kubernetes 集群中的 Grafana,可以通过以下步骤解决:
方法一:修改本地 Hosts 文件(推荐)
适用场景:物理机与集群节点在同一局域网,且虚拟机有固定 IP。
获取 Ingress 控制器所在节点的 IP:
kubectl get svc -n ingress-nginx # 假设使用 Nginx Ingress,查看 EXTERNAL-IP 或 NodePort如果 Service 类型为
NodePort,记录节点的 IP(如192.168.1.100)。修改物理机 Hosts 文件:
- Linux/Mac:
sudo vi /etc/hosts - Windows:
C:\Windows\System32\drivers\etc\hosts
192.168.1.100 grafana.mydomain.com- Linux/Mac:
访问 Grafana:
浏览器访问http://grafana.mydomain.com(或https如果配置了 TLS)。
方法二:通过 NodePort 直接访问
适用场景:Ingress 控制器 Service 类型为 NodePort。
查找 NodePort 端口:
kubectl get svc -n ingress-nginx找到
PORT(S)列中的 NodePort(如80:31000/TCP,则31000是端口)。直接通过节点 IP + 端口访问:
浏览器访问http://<节点IP>:31000,并通过 Host 头指定域名:curl -H "Host: grafana.mydomain.com" http://<节点IP>:31000
方法三:使用 kubectl port-forward(临时调试)
适用场景:快速临时访问,无需修改网络配置。
找到 Grafana 的 Service 名称:
kubectl get svc -n monitoring # 假设 Grafana 在 monitoring 命名空间端口转发:
kubectl port-forward svc/grafana-service 3000:3000 -n monitoring访问本地端口:
浏览器访问http://localhost:3000。
方法四:配置 LoadBalancer(云环境或 MetalLB)
适用场景:生产环境或需要稳定外部 IP。
修改 Ingress 控制器 Service 类型:
kubectl edit svc ingress-nginx-controller -n ingress-nginx将
type: NodePort改为type: LoadBalancer。获取 External IP:
kubectl get svc -n ingress-nginx等待分配 External IP(云环境自动分配,本地需安装 MetalLB)。
配置 DNS 或 Hosts:
将域名grafana.mydomain.com解析到 External IP。
网络检查要点
- 防火墙规则:确保物理机到虚拟机节点的 80/443 或 NodePort 端口开放。
- 虚拟机网络模式:如果是 NAT 模式,需在宿主机配置端口转发(如 VirtualBox 的 NAT 网络设置)。
- Ingress 配置:确认 Ingress 中
host字段与域名一致,且 TLS 配置正确(如果有)。
选择最适合你环境的方法即可。如果仍有问题,请提供更多集群网络细节(如 Ingress 类型、节点 IP 是否可达等)。
热门推荐
黄酒春夏秋冬:四季饮用场景与秋冬健康益处
电冰箱功率大吗?家用电器耗电量解析
旧凉鞋改造指南:8种创意DIY方法让旧鞋重获新生
老年人认知障碍原因及治疗全解析
老人出现幻觉说胡话怎么回事
如何起草一份完善的外包合同?
酒精性肝病患者,戒酒后肝功能会恢复吗?
台式机如何通过网线连接路由器实现上网
成都龙泉驿赏桃花攻略:五大景点全解析
如何明确各类期货的交易成本?这些交易成本如何进行合理控制?
不同评级的期货公司在服务质量上有哪些区别?
闽南有哪些茶? 细数闽南9种乌龙茶
五毒情降:揭秘神秘仪式背后的传统文化
葡萄牙留学与移民政策解读指南
长期、低强度噪音暴露,或弄丢你的听力
如何走出女性困境?《还有明天》给出了7种可能——
水彩笔写不出来怎么办?解决各种水彩笔绘画难题的实用指南!
跷二郎腿伤腰、伤骨盆!「这个姿势」杀伤力更可怕!
跷二郎腿伤腰、伤骨盆!「这个姿势」杀伤力更可怕!
头小脑不小,数字重建改写鸟类智慧认知
从零开始讲变速箱:原理、结构与类型全解析
中原考察之旅之龙门石窟与白马寺
火电厂电气自动化解决方案
海南汽油价格走势分析
HR必读|员工辞退流程中的3大法律雷区与合规操作指南
举例说明各级别大学校长是什么行政级别?
帕金森“最有效”的治疗方式,大部分患者其实都知道?
李沆简介:北宋时期名相,以清静无为治国,注重吏事
遭遇急腹症千万别做这些,医生提醒要特别注意!
电瓶车载人合法吗?相关规定和安全指南是什么?