写一个linux脚本,查看k8s占用的所有端口号,包含服务内部的

时间: 2023-01-11 17:55:36 浏览: 133
在 Linux 中,可以使用 `ss` 命令查看占用的所有端口号。要查看 k8s 占用的所有端口,可以使用以下脚本: ```bash #!/bin/bash # 查看所有的 k8s 端口 ss -lptn 'sport = :6443 or sport = :2379 or sport = :2380 or sport = :10250 or sport = :10251 or sport = :10252' ``` 上述脚本将会查看 k8s 所使用的所有内部端口。其中: - `6443` 端口是 kubernetes API server 的默认端口。 - `2379` 和 `2380` 端口是 etcd 服务的默认端口。 - `10250` 端口是 kubelet 服务的默认端口。 - `10251` 和 `10252` 端口是 kube-scheduler 和 kube-controller-manager 服务的默认端口。 如果你想查看更多 k8s 端口,可以将上述脚本中的 `sport` 参数更改为所需的端口。 希望这个脚本对你有帮助!
相关问题

写一个linux脚本,查看k8s、docker所有占用的端口号,包括使用ss、netstat命令查不到的

### 回答1: 这是一个可以实现您要求的脚本。注意,这个脚本需要使用 sudo 权限执行,因为它需要访问系统底层的信息。 ```bash #!/bin/bash # 查看所有已经使用的端口 echo "Using netstat:" netstat -tulpn echo # 查看所有正在运行的 Docker 容器使用的端口 echo "Using Docker:" docker ps --format '{{.Names}}: {{.Ports}}' echo # 查看所有在 Kubernetes 集群中的 Pod 使用的端口 echo "Using Kubernetes:" kubectl get pods --all-namespaces -o jsonpath='{.items[*].spec.containers[*].ports[*].containerPort}' ``` 执行这个脚本之后,您将能够看到所有使用的端口。使用 netstat 命令可以查看系统中所有已经使用的端口,使用 Docker 命令可以查看所有正在运行的 Docker 容器使用的端口,使用 Kubernetes 命令可以查看所有在 Kubernetes 集群中的 Pod 使用的端口。 ### 回答2: 以下是一个可以查看k8s和docker所有占用的端口号的Linux脚本: ```shell #!/bin/bash # 首先获取k8s的所有Pod列表 k8s_pods=$(kubectl get pods --all-namespaces -o jsonpath='{range .items[*]}{.metadata.name}{"\n"}{end}') # 遍历每个Pod,获取其IP地址和端口号 for pod in $k8s_pods; do pod_ip=$(kubectl describe pod $pod --namespace $(kubectl get pods -o jsonpath="{.items[?(@.metadata.name=='$pod')].metadata.namespace}") | grep IP: | awk '{print $2}') echo "Kubernetes Pod: $pod" echo "IP地址: $pod_ip" # 获取Pod的网络命名空间 pid=$(kubectl get pod $pod --namespace $(kubectl get pods -o jsonpath="{.items[?(@.metadata.name=='$pod')].metadata.namespace}") -o jsonpath="{.metadata.annotations['kubernetes\.io/config\.mirror']}" | awk -F / '{print $(NF)}') # 使用nsenter进入网络命名空间,查找该命名空间下所有的端口号 sudo nsenter -t $pid -n ss -tln | awk 'NR>1 {split($4,arr,":"); print arr[length(arr)]}' done # 获取所有的docker容器ID docker_containers=$(docker ps -q) # 遍历每个容器,获取其IP地址和端口号 for container in $docker_containers; do container_ip=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $container) echo "Docker容器: $container" echo "IP地址: $container_ip" # 使用docker exec进入容器,查找该容器下所有的端口号 sudo docker exec $container ss -tln | awk 'NR>1 {split($4,arr,":"); print arr[length(arr)]}' done ``` 运行该脚本后,会依次输出k8s的每个Pod的名称、对应的IP地址以及占用的端口号;然后输出每个docker容器的ID、对应的IP地址以及占用的端口号。注意运行该脚本需要具有足够的权限,可能需要使用sudo命令。 ### 回答3: 要编写一个Linux脚本来查看K8s和Docker所有占用的端口号,包括无法通过ss和netstat命令找到的端口。 下面是一个示例脚本: ```shell #!/bin/bash # 获取K8s中的所有容器ID k8s_pods=$(kubectl get pods -o jsonpath='{range .items[*]}{.metadata.name}{"\n"}{end}') for pod in $k8s_pods; do # 获取容器的PID pid=$(kubectl get pod $pod -o jsonpath='{.status.containerStatuses[0].containerID}' | cut -d/ -f3) # 处理容器的网络命名空间 if [ -z "$pid" ]; then continue fi ns_path="/var/run/netns/$pid" if [ ! -e "$ns_path" ]; then mkdir -p "$(dirname "$ns_path")" # 创建目录 ln -s /proc/$pid/ns/net "$ns_path" # 建立软链接 fi # 获取容器的占用端口号 ports=$(nsenter -n -t $pid ss -lntp | awk 'NR>1{print $5}' | cut -d: -f2) if [ -n "$ports" ]; then echo "K8s Pod $pod is using ports $ports" fi rm "$ns_path" # 删除软链接 done # 获取Docker中的所有容器ID docker_containers=$(docker ps -q) for container in $docker_containers; do # 获取容器的占用端口号 ports=$(docker inspect --format='{{range $p, $conf := .NetworkSettings.Ports}}{{(index $conf 0).HostPort}} {{end}}' $container) if [ -n "$ports" ]; then echo "Docker Container $container is using ports $ports" fi done ``` 该脚本首先通过kubectl命令获取K8s中的所有容器ID,并使用nsenter命令进入容器的网络命名空间。然后使用ss命令找到容器占用的端口号,最后输出结果。 接下来,脚本使用docker命令获取Docker中的所有容器ID,并使用docker inspect命令获取容器的占用端口号,同样输出结果。 注意,为了运行该脚本,需要确保你拥有足够的权限来执行这些命令,并且在运行脚本之前,确保已经安装了kubectl、nsenter和Docker。

写一个Linux shell脚本,查看目录下所有子目录占用空间

可以使用 `du` 命令来查看目录的大小,加上 `-h` 参数可以以易读的方式显示目录大小,加上 `-d` 参数可以指定查看的目录深度。结合 `find` 命令可以查找指定目录下的所有子目录。 下面是一个查看指定目录下所有子目录占用空间的 shell 脚本示例: ```bash #!/bin/bash # 指定要查看的目录 dir="/path/to/directory" # 查找指定目录下的所有子目录,并遍历输出它们的空间占用情况 find "$dir" -type d -print0 | while read -d $'\0' path; do # 使用 du 命令计算目录大小,并以易读的方式显示 size=$(du -sh "$path" | cut -f1) echo "$size $path" done ``` 在上面的脚本中,`find` 命令会查找指定目录下的所有子目录,并将它们的路径以 null 字符 (`\0`) 分隔输出。接着使用 `while` 循环读取每个子目录的路径,并使用 `du` 命令计算它们的大小。最后将目录大小和路径输出。

相关推荐

最新推荐

recommend-type

使用python脚本自动生成K8S-YAML的方法示例

主要介绍了使用python脚本自动生成K8S-YAML的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

一个Linux系统安全设置的Shell脚本的分享(适用CentOS)

主要介绍了一个设置Linux系统安全的Shell脚本的分享,适用CentOS,包含大部份的安全设置,只需执行脚本就可以得到一个相对安全的Linux系统了,需要的朋友可以参考下
recommend-type

linux服务器安全加固shell脚本代码

有时候安装完服务器以后,需要一些安全设置,这段脚本就是为了安全加固所写,需要的朋友可以参考下
recommend-type

linux服务器中批量运行脚本文件的方法

很多刚刚接触服务器的小白科研档跟我一样,自己设定了一堆abaqus作业命令,本来在window服务器下可以运行,但是,毕竟自己的电脑计算...因此我制作了如何在linux服务器中批量运行脚本文件详细步骤,希望对大家有用。
recommend-type

Java调用linux shell脚本的方法

主要介绍了Java调用linux shell脚本的方法,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【实战演练】MATLAB用遗传算法改进粒子群GA-PSO算法

![MATLAB智能算法合集](https://static.fuxi.netease.com/fuxi-official/web/20221101/83f465753fd49c41536a5640367d4340.jpg) # 2.1 遗传算法的原理和实现 遗传算法(GA)是一种受生物进化过程启发的优化算法。它通过模拟自然选择和遗传机制来搜索最优解。 **2.1.1 遗传算法的编码和解码** 编码是将问题空间中的解表示为二进制字符串或其他数据结构的过程。解码是将编码的解转换为问题空间中的实际解的过程。常见的编码方法包括二进制编码、实数编码和树形编码。 **2.1.2 遗传算法的交叉和
recommend-type

openstack的20种接口有哪些

以下是OpenStack的20种API接口: 1. Identity (Keystone) API 2. Compute (Nova) API 3. Networking (Neutron) API 4. Block Storage (Cinder) API 5. Object Storage (Swift) API 6. Image (Glance) API 7. Telemetry (Ceilometer) API 8. Orchestration (Heat) API 9. Database (Trove) API 10. Bare Metal (Ironic) API 11. DNS
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。