百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

在linux ubuntu 系统下,宿主机里看不到监听端口,但容器访问正常

nanshan 2024-10-16 10:48 22 浏览 0 评论

在linux ubuntu 系统下,宿主机里看不到监听端口,但容器访问正常

现象:

root@bwoil:/data/redis# ls

conf data docker-compose.yaml redis.7.0.7.tgz

root@bwoil:/data/redis# nerdctl compose ps

NAME IMAGE COMMAND SERVICE STATUS PORTS

redis docker.io/library/redis:7.0.7 "redis-server /usr/l…" redis running 0.0.0.0:6379->6379/tcp

root@bwoil:/data/redis# more docker-compose.yaml

version: '3'

services:

redis:

hostname: redis

image: redis:7.0.7

container_name: redis

privileged: true

ports:

- 6379:6379

sysctls:

- net.core.somaxconn=1024

volumes:

- ./data:/data

- ./conf:/usr/local/etc/redis

- /etc/localtime:/etc/localtime:ro

entrypoint: redis-server /usr/local/etc/redis/redis.conf

restart: always

mem_limit: 4g

networks:

- meta

networks:

meta:

external: true

root@bwoil:/data/redis# netstat -ntpl |grep 6379

root@bwoil:/data/redis# ss |grep 6379

root@bwoil:/data/redis# sudo lsof -iTCP:6379 -sTCP:LISTEN

root@bwoil:/data/redis#


为什么呢?

查看防火墙规则:

root@bwoil:/data/redis# sudo iptables -L -n |grep 6379

root@bwoil:/data/redis# iptables -nvL|grep 6379

root@bwoil:/data/redis# sudo iptables -t nat -L -n |grep 6379

CNI-HOSTPORT-SETMARK tcp -- 10.4.2.0/24 0.0.0.0/0 tcp dpt:6379

CNI-HOSTPORT-SETMARK tcp -- 127.0.0.1 0.0.0.0/0 tcp dpt:6379

DNAT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp dpt:6379 to:10.4.2.159:6379

CNI-DN-635091dd85894072ba7c2 tcp -- 0.0.0.0/0 0.0.0.0/0 /* dnat name: "meta" id: "k8s.io-5af4d10ddad658ac61103431f71ec0407007b4bac055902820f1ce940a3be89b" */ multiport dports 6379


CNI-HOSTPORT-SETMARK tcp -- 10.4.2.0/24 0.0.0.0/0 tcp dpt:6379

这条规则用于标记来自特定子网10.4.2.0/24的流量,以便后续的处理

CNI-HOSTPORT-SETMARK tcp -- 127.0.0.1 0.0.0.0/0 tcp dpt:6379

这条规则标记来自本机的6379端口的流量

DNAT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp dpt:6379 to:10.4.2.159:6379

这条规则将所有发往6379端口的流量转发到IP地址为10.4.2.159的主机的6379端口。这是典型的DNAT(目的地址转换)规则,常用于将外部流量转发到内部服务

CNI-DN-635091dd85894072ba7c2 tcp -- 0.0.0.0/0 0.0.0.0/0 /* dnat name: "meta" id: "k8s.io-5af4d10ddad658ac61103431f71ec0407007b4bac055902820f1ce940a3be89b" */ multiport dports 6379

这条规则是一个注释规则,表示它是由Kubernetes网络插件创建的,可能用于将流量转发到多个6379端口的服务。注释中包含了元数据,可能用于追踪或管理


如果iptables 中有DNAT 规则将数据量转发到容器,所以在宿主机里执行netstat /ss 才导致看不到对应的端口

在宿主机上执行 netstat 或 ss 命令时看不到容器端口的原因,确实与 iptables 中的 DNAT 规则有关

网络流量处理流程

  1. 外部请求到达宿主机: 当外部请求(如访问6379端口)到达宿主机时,数据包首先到达网络接口。
  2. 内核处理: 数据包进入Linux内核,经过网络协议栈的不同层次(链路层、网络层和传输层)。
  3. iptables 规则匹配: 数据包在到达应用层之前,会经过 iptables 的规则匹配。iptables 是在内核空间中管理网络流量的工具,使用 netfilter 框架。 如果存在 DNAT 规则(如将6379端口的流量转发到容器的6379端口),内核会将流量的目标地址修改为容器的IP地址。
  4. 数据包转发: 修改后的数据包被转发到目标容器的网络命名空间。容器内部的服务(如Redis)会接收这个流量。 容器内部处理: 容器内部的服务处理请求并生成响应。响应数据包会通过宿主机的网络栈返回。

为什么 netstat 或 ss 无法查看端口

  • 网络命名空间隔离: 容器使用网络命名空间来隔离网络环境,因此在宿主机上执行 netstat 或 ss 命令时,无法看到容器内部的端口状态。容器的网络栈与宿主机的网络栈是分开的
  • DNAT 规则的影响:由于有 DNAT 规则将流量转发到容器,宿主机的6379端口实际上并不直接监听来自外部的流量。即使在宿主机上有流量通过6379端口,netstat 和 ss 也不会显示这个端口,因为它的流量已经被重定向到容器。
  • 流量处理顺序:iptables 规则在数据包到达应用层之前处理数据包,因此它们的匹配和处理优先于 netstat 和 ss 的查询。这意味着,如果数据包在 iptables 规则中被处理或修改,宿主机的网络状态将无法反映出容器的端口状态


在宿主机上执行 netstat 或 ss 时无法查看到容器的6379端口,是因为:

  1. 容器和宿主机的网络命名空间隔离,导致宿主机无法直接查看容器内部的端口状态。
  2. DNAT 规则的作用,使得流量在到达容器之前被修改和转发,宿主机上6379端口的流量并不直接与宿主机的网络状态相对应。

要查看容器内部的端口状态,您需要进入容器内部执行相应的命令

相关推荐

如何为MySQL服务器和客户机启用SSL?

用户想要与MySQL服务器建立一条安全连接时,常常依赖VPN隧道或SSH隧道。不过,获得MySQL连接的另一个办法是,启用MySQL服务器上的SSL封装器(SSLwrapper)。这每一种方法各有其...

Mysql5.7 出现大量 unauthenticated user

线上环境mysql5.7突然出现大量unauthenticateduser,进mysql,showprocesslist;解决办法有:在/etc/hosts中添加客户端ip,如192.16...

MySQL 在 Windows 系统下的安装(mysql安装教程windows)

更多技术文章MySQL在Windows系统下的安装1.下载mysql和Framework链接链接:百度网盘请输入提取码提取码:6w3p双击mysql-installer-communit...

MySql5.7.21.zip绿色版安装(mysql数据库绿色版安装)

1、去网上下载满足系统要求的版本(mysql-5.7.21-winx64.zip)2、直接解压3、mysql的初始化(1)以管理员身份运行cmd,在mysql中的bin目录下shift+右键-在...

MySQL(8.0)中文全文检索 (亲测有效)

在一堆文字中找到含有关键字的应用。当然也可以用以下语句实现:SELECT*FROM<表名>WHERE<字段名>like‘%ABC%’但是它的效率太低,是全盘扫描。...

新手教程,Linux系统下MySQL的安装

看了两三个教程。终于在哔哩哔哩找到一个简单高效的教程,成功安装,up主名叫bili逍遥bili,感兴趣可以去看看。下面这个是我总结的安装方法环境:CentOS764位1.下载安装包,个人觉得在...

麒麟服务器操作系统安装 MySQL 8 实战指南

原文连接:「链接」Hello,大家好啊,今天给大家带来一篇麒麟服务器操作系统上安装MySQL8的文章,欢迎大家分享点赞,点个在看和关注吧!MySQL作为主流开源数据库之一,被广泛应用于各种业务...

用Python玩转MySQL的全攻略,从环境搭建到项目实战全解析

这是一篇关于“MySQL数据库入门实战-Python版”的教程,结合了案例实战分析,帮助初学者快速掌握如何使用Python操作MySQL数据库。一、环境准备1.安装Python访问Pytho...

安装MySQL(中标麒麟 安装mysql)

安装MySQL注意:一定要用root用户操作如下步骤;先卸载MySQL再安装1.安装包准备(1)查看MySQL是否安装rpm-qa|grepmysql(2)如果安装了MySQL,就先卸载rpm-...

Mysql最全笔记,快速入门,干货满满,爆肝

目录一、MySQL的重要性二、MySQL介绍三、软件的服务架构四、MySQL的安装五、SQL语句六、数据库相关(DDL)七、表相关八、DML相关(表中数据)九、DQL(重点)十、数据完...

MAC电脑安装MySQL操作步骤(mac安装mysqldb)

1、在官网下载MySQL:https://dev.mysql.com/downloads/mysql/根据自己的macOS版本,选择适配的MySQL版本根据自己需求选择相应的安装包,我这里选择macO...

mysql主从(mysql主从切换)

1、本章面试题什么是mysql主从,主从有什么好处什么是读写分离,有什么好处,使用mycat如何实现2、知识点2.1、课程回顾dubboORM->MVC->RPC->SOApro...

【linux学习】以MySQL为例,带你了解数据库

做运维的小伙伴在日常工作中难免需要接触到数据库,不管是MySQL,mariadb,达梦还是瀚高等其实命令都差不多,下面我就以MySQL为例带大家一起来了解下数据库。有兴趣的小伙伴不妨评论区一起交流下...

玩玩WordPress - 环境简介(0)(玩玩网络科技有限公司)

简介提到开源博客系统,一般都会直接想到WordPress!WordPress是使用PHP开发的,数据库使用的是MySQL,一般会在Linux上运行,Nginx作为前端。这时候就需要有一套LNMP(Li...

服务器常用端口都有哪些?(服务器端使用的端口号范围)

下面为大家介绍一下,服务器常用的一些默认端口,以及他们的作用:  21:FTP服务所开放的端口,用于上传、下载文件。  22:SSH端口,用于通过命令行模式远程连接Linux服务器或vps。  23:...

取消回复欢迎 发表评论: