Windows netstat 查看端口、进程占用

开始--运行--cmd 进入命令提示符 输入netstat -ano 即可看到所有连接的PID 之后在任务管理器中找到这个PID所对应的程序如果任务管理器中没有PID这一项,可以在任务管理器中选"查看"-"选择列"

经常,我们在启动应用的时候发现系统需要的端口被别的程序占用,如何知道谁占有了我们需要的端口,很多人都比较头疼,下面就介绍一种非常简单的方法,希望对大家有用

假如我们需要确定谁占用了我们的9050端口

1、Windows平台
在windows命令行窗口下执行:

C:/>netstat -aon|findstr "9050"

TCP 127.0.0.1:9050 0.0.0.0:0 LISTENING 2016

看到了吗,端口被进程号为2016的进程占用,继续执行下面命令:

C:/>tasklist|findstr "2016"

tor.exe 2016 Console 0 16,064 K

很清楚吧,tor占用了你的端口。

查看文件夹目录结构

tree > list.txt

tree /f >list.txt

输入输出重定向

echo -c   -c:不换行,linux下则是-n

输入输出重定向:

每执行一个命名,都会有3个与之相关的文件.标准输入文件,标准输出文件,错误输出文件.

因为unix/linux下把任何一个设备都当作文件看待,所有实际上标准输入文件是键盘,

标准输出和错误输出文件是屏幕.

>      输出重定向

<      输入重定向

<<   输入追加

>>   输入追加

文件描述符:

每一个文件可以用文件描述符来描述,系统提供12个,3-9可以任意定义.0-2系统定义如下:

0  标准输入  键盘

1  标准输出  显示器

2  错误输出  显示器

即可以用0-2代表上面的3个文件.

例如:cmd>file     //cmd的输出重定向到file文件

cmd>>file    //cmd的输出追加到file中,无则创建

cmd 1>file   //把运行cmd的shell的标准输出重定向到file中,1代表标准输出

cmd>file 2>&1  //把cmd的输出重定向到file,同时把2(错误输出)重定向到1(标准输出).

2 > 1 则会把1当成文件,所有把错误定向到1必须使用&1.

cmd 2>file    //把错误输出定向到file中

cmd>>file 2>&1  //把错误和cmd输出追加到file中,cmd>>file,追加;2>&1,错误定向到

标准输出,标准输入又追加到file中,所以错误和cmd输出都追加到file

cmd 1>>file 2>&1  //可以把此命令等效于上一个命令

cmdfile2   //cmd的输入是file1,结果输出到file2

cmd<<END          //cmd使用标准输入,直到遇到END则退出.END可为任意一个字符

理解:cmd使用默认的标准输入,运行,碰到END,则追加,但是标准输入输出

不能追加,于是出错退出.

注:经试验理解不对,据linux shell编程25章的说法,

这是shell定的语法.可以直接理解成END为分隔符.

cmd<&m          //把文件描述符m作为cmd的输入

cmd>&m          //把文件描述符m作为cmd的输出

cmd<&-          //关闭标准输入.

!!!注意:

1. 输入输出定向符前面不要加空格,否则容易出意想不到的问题

2. 0 1 2不能使用>>或<<定向符,例: 2>>&1 出错

for循环命令

基本用法:

格式:FOR [参数] %%变量名 IN (相关文件或命令) DO 执行的命令

作用:对一个或一组文件,字符串或命令结果中的每一个对象执行特定命令,达到我们想要的结果。

注意:在批处理文件中使用 FOR命令时,指定变量请使用%%variable,而不要用%variable。变量名称是区分大小写的,所以 %i 不同于 %I.

关于:for命令可以带参数或不带参数,带参数时支持以下参数:/d /l /r /f

实例

咱们用一个实例来熟悉下for循环的用法。将ports-desc.txt中的端口号取出来存入另一个文件ports.txt文件中,代码:

ports-desc.txt内容如下:

1 传输控制协议端口服务多路开关选择器 2 compressnet 管理实用程序 3 压缩进程 5 远程作业登录 ...

首先 新建一个bat文件test.bat(在cmd窗口直接输入名称运行),获取文件每行的信息,用到一个循环:

@echo offfor /f "tokens=1* delims=:" %%i in ('findstr /n ".*" basic_port.txt') do ( echo %%j))pause打印:1:1 传输控制协议端口服务多路开关选择器 2:2 compressnet 管理实用程序 3:3 压缩进程 4:5 远程作业登录 ...

因为使用了/n参数,所以每行首有序列号及冒号。这里详解下:

('findstr /n ".*" basic_port.txt') 会返回多行信息类似数组,for循环遍历每行字符串

delims=: 代表将每行字符串利用=后的字符进行分割

tokens=1* 1表示取每行分割后的第一列(可以理解为数组第一个arr[0])并存入变量%%i,后面所有的元素存入$$j()

以第一行为例,%%i等于1;$$j等于“1 传输控制协议端口服务多路开关选择器”

其次,遍历每行字符串,因此需要用到第二个循环,并且嵌套在其中:

第二个循环命令中,需要使用第一个循环%%j(即每行字符串)的值,必须使用变量的方式。而一般变量表示为%变量%,这里比较特殊,需要用!变量!的方式。像这样:

%%k in ("!string!") do(code...)

现在代码为:

@echo offfor /f "tokens=1* delims=:" %%i in ('findstr /n ".*" basic_port.txt') do ( set set string=%%j for /f "tokens=1* delims= " %%k in ("!string!") do ( echo %%k ))pause打印:!string!!string!!string!!string!!string!...

运行后,结果不对。度娘后发现嵌套循环的问题:变量延迟。需要在第一行加上“setlocal enabledelayedexpansion”

加上后:

@echo off&;setlocal enabledelayedexpansionfor /f "tokens=1* delims=:" %%i in ('findstr /n "^[0-9]* " basic_port.txt') do ( set string=%%j for /f "tokens=1* delims= " %%k in ("!string!") do ( echo %%k ))pause

现在就可以把数据一条条存入目标文件ports.txt文件中:

最后代码:

@echo off&;setlocal enabledelayedexpansionfor /f "tokens=1* delims=:" %%i in ('findstr /n "^[0-9]* " basic_port.txt') do ( set string=%%j for /f "tokens=1* delims= " %%k in ("!string!") do ( %%k>>ports.txt ))pause

>> 表示将数据追加到文件中。首次会新建这个文件。

> 一个时表示直接覆盖

最新文章

  1. 使用GRUB 添加新的启动项 (menu entry)
  2. XE3随想14:关于 SO 与 SA 函数
  3. 用pygame学习初级python(二) 15.5.11
  4. python类的特性
  5. IE 兼容模式下不支持DIV CSS样式display:inline-block,解决
  6. mysql没有delete操作,那是delete from操作,
  7. Android中的Handler机制
  8. netsh winsock reset 11003
  9. CentOs环境下PHP支持PDO_MYSQL
  10. mysql启动问题access denied for user &#39;root&#39;@&#39;localhost&#39;(using password:YES)
  11. PHP第一课:开发环境配置
  12. 利用servlet做转发,实现js跨域解决同源问题
  13. android脚步---跟随手指动的小球
  14. RTMP、HTTP-FLV、HLS,你了解常见的三大直播协议吗
  15. mybatis学习四 mybatis的三种查询方式
  16. 常用 Git 操作
  17. python测试笔试题1
  18. February 23 2017 Week 8 Thursday
  19. Codeforces 219D Choosing Capital for Treeland 2次DP
  20. 解决Eclipse和myeclipse在进行 html,jsp等 页面编辑时,自动格式化变丑的问题

热门文章

  1. 4.9Python数据处理篇之Matplotlib系列(九)---子图分布
  2. LeetCode算法题-Number of Boomerangs(Java实现)
  3. Spring的jdbc模板1
  4. linux中如何查看进程的启动时间
  5. UEditor学习笔记1
  6. Linux crm 运行
  7. 设计模式のMediatorPattern(中介者模式)----行为模式
  8. c#窗体获取系统时间、回车触发按钮事件、实现验证码功能
  9. 启动线程用start方法
  10. SDOI2014 R1做题笔记