运维工具nc

nc命令全名为netcat,顾名思义就是通过TCP或UDP从网络读写数据。

1、传输文件

使用<>重定向符(只适用单文件,不推荐、失败时 ">" 产生空文件)

nc -l 8888 > demo.txt        # 在本机8888端口侦听TCP连接,将收到的数据写入文本文件

nc ip 8888 < demo.txt        # 将文件内容通过网络"cat"到远端

使用tar传输文件(推荐,好处是保留了原目录结构和权限)

tar cz demo1.txt demo_dir/ | nc -l 8888  # 监听8888端口,有连接时开始tar打包并"cat"到远端

nc ip 8888 | tar zx                                 # 连接、接收数据、解压一步到位。

2、建立网络管道

nc -l 8888                            # 接收消息

echo msg | nc ip 8888           # 发送消息

3、迁移生产机房数据到测试机房(运维电脑建管道)

tar cz demo1.txt demo_dir/ | nc -l 8888  # 生产机房ipA

nc -l 8888 | tar zx                                 # 测试机房ipB

nc ipA 8888 | nc ipB 8888                      # 运维个人电脑,连通两台机器的8888端口。

4、测试网络连通 (排查测试机房的lbg转发udp问题)

curl 调试http,即7层非常高效。但如何调试4层网络呢?答案就是nc

测试机房lbg做了公网udp服务的映射,但测试同学发现程序出错,怀疑网络问题,找运维同学排查。

nc -ul 9999                   # 服务ipS 监听9999端口 该端口映射到公网 ipVS:portVS

nc -zuv ipS 9999           # 内网udp连通成功   显示Connection to ipS 9999 port [udp/*] succeeded!

nc -zuv ipVS portVS       # 公网udp连通失败   显示Connection to ipVS portVS port [udp/*] fail!

一、上如何检查tcp?以上的参数u去掉,默认就是tcp。

二、进一步写出nagios插件,检查udp服务端口(以部署在PP的udp消息推送监控中)

5、代替telnet,测试mc,浮云等等。

echo stats | nc ipS portMC        # 非交换式查看mc的状态。

echo INFO | nc ipS portREDIS   # 非交换式查看redis的状态。

非交换的set、get检查浮云ds        # 已部署到PP的浮云监控。

6、使用nc发邮件,发生http请求等,反弹shell,端口转发等等,请man nc

echo -e "GET / HTTP/1.0\r\n" | nc uc.cn 80

时间: 2024-10-31 19:07:46

运维工具nc的相关文章

linux运维工具nc

Netcat被称为tcp/ip最好用的工具,也是linux开发/运维人员的必备技巧: 1.安装nc yum install nc -y 2.常用功能 2.1 端口测试 查看服务器的某个端口是否开启 nc -vz ip portnc -vz 192.168.1.1 80-v:显示多点信息-z:不发送数据 例如: 端口范围扫描 nc -v -v -w3 -z 192.168.1.1 80-88两次-v显示更详细的内容:-w3:设置扫描超时时间 3秒: 2.2 传输测试 192.168.1.1 nc

自动化运维工具介绍

运维目标有三个阶段,第一是追求稳定性,第二是追求标准化,第三是追求自动化.对于第三阶段来说,什么是运维自动化呢?简单地讲,运维自动化就是将日常重复性工作按照事先设定好的规则,在一定时间范围内自动化运行,而不需要人工参与.接下来简单介绍运维自动化工具,要了解运维平时用到的自动化工具,就需要了解运维人员的日常工作有哪些. 一.运维的日常工作 运维的日常工作可以总结为以下四个部分,分别是: (1) 系统安装 (2) 应用程序配置(Configuration) (3) 命令执行与控制(Command a

自动化运维工具之ansible

ansible ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric)的优点,实现了批量系统配置.批量程序部署.批量运行命令等功能. ansible是基于模块工作的,本身没有批量部署的能力.真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架. 主要包括: (1).连接插件connection plugins:负责和被监控端实现通信: (2).host inventory:指定

ansible轻量级运维工具使用

Linux轻量级自动运维工具- Ansible 创始人 Michael DeHanan 2012-03-09 同类自动化工具: Ansible Saltstack Puppet Chef Fabric Ansible 特点 agentless (去中心化) 只要保存管理机的认证信息,那么任何一台机器都可以变成管理机 Stupied Simple SSH by default YAML no code 定制剧本 基于python 实现 模块化:调用特定模块,完成特定任务,支持自定义模块 冥等性 -

运维工具ansible理论部分

1.运维工作介绍 运维工作的全部流程: 系统安装(物理机.虚拟机)--> 程序包安装.配置.服务启动 --> 批量操作 --> 程序发布  --> 监控 随着一些大公司的IT系统架构越来越复杂,服务器数量越来越多,标准化和自动化已经是运维工作的基本要素. 自动化运维经历了4个阶段:人工,这个阶段基本上是全部需要到机器上一步步操作:脚本,使用计划任务完成一些重复性工作:工具,这个阶段一个人可以管理大量的机器,常见的工具:puppet,saltstack,ansible:平台化,这时运

自动化运维工具之ansible的简单应用

ansible: ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric)的优点,实现了批量系统配置.批量程序部署.批量运行命令等功能.ansible是基于模块工作的,本身没有批量部署的能力.真正具有批量部署的是ansible所运行的模块,例如shell,copy,ping等,ansible只是提供一种框架.ansible的主要特性: 模块化:调用特定的模块,完成特定任务 基于Python语言实现,由Pa

自动化运维工具Ansible详细部署

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://sofar.blog.51cto.com/353572/1579894 ========================================================================================== 一.基础介绍 =========================================================

运维工具SaltStack之三Grains组件

运维工具SaltStack之三Grains组件 一.grains组件介绍 grains是收集Minion主机的静态.不常变化的基本信息,存储在Minion端本地,如:CPU.内核.操作系统.虚拟化等,并且服务器端可以根据这些信息进行灵活定制或个性化定制,是Saltstack最重要的组件之一,多用来做资产管理的信息收集,主要解决平台的差异性. 如可以使用以下命令: #salt 'minion01' grains.items  #获取minion01主机基本信息 二.grains组件自定义 自定义g

运维工具SaltStack之四Pillar组件

运维工具SaltStack之四Pillar组件 一.pillar组件介绍 跟grains的结构一样,存放需要提供给Minion端的信息,存储在master端.可根据各个机器环境的不同,分别定义变量,然后再sls文件里统一引用,官方表示pillar是存储敏感数据的,主要解决环境的差异性.同时与grains组件还有一个特别的区别:grains数据加载在内存里,即minion启动之后不会变,哪怕修改了grains,除非重启minion或者从master端同步.而pillar修改之后,再获取数据即生效了