【LINUX】端口号 及pow(2,n)表

/* Linux下端口的划分使用是由IANA(Internet Assigned Numbers Authority,因特网已分配数值权威机构)维护的,端口号被划分为3个段。

1、0~1023,(10)这些端口有IANA分配和控制,可能的话,相同端口号就分配给TCP、UDP和SCTP的同一给定服务。如80端口被赋予web服务

2、1024~49151,这些端口不受IANA控制,不过由IANA登记并提供他们的使用情况清单,已方便整个群体。相同端口号也分配给TCP和UDP的同一给定服务。如6000~6003端口分配给这两种协议的X Window服务器。

3、49152~65535,(16)动态端口。IANA不管这些端口,就是我们所说的临时端口。(49152这个魔数是65536的四分之三)。
*/
#include <iostream>
using namespace std;
int main()
{
	cout << "pow(2,n)" << endl;
	for(int i=0,tmp=1;i<20;i++)
	{
	cout<<i<<" "<<tmp<<endl;    
	tmp*=2;
	}
	return 0;
}
/*
0 1
1 2
2 4
3 8
4 16
5 32
6 64
7 128
8 256
9 512
10 1024
11 2048
12 4096
13 8192
14 16384
15 32768
16 65536
17 131072
18 262144
19 524288

vi /etc/services
第一类
http://www.linuxidc.com/Linux/2007-06/4744.htm

1 tcpmux TCP 端口服务多路复用 
5 rje 远程作业入口 
7 echo Echo 服务 
9 discard 用于连接测试的空服务 
11 systat 用于列举连接了的端口的系统状态 
13 daytime 给请求主机发送日期和时间 
17 qotd 给连接了的主机发送每日格言 
18 msp 消息发送协议 
19 chargen 字符生成服务;发送无止境的字符流 
20 ftp-data FTP 数据端口 
21 ftp 文件传输协议(FTP)端口;有时被文件服务协议(FSP)使用 
22 ssh 安全 Shell(SSH)服务 
23 telnet Telnet 服务 
25 smtp 简单邮件传输协议(SMTP) 
37 time 时间协议 
39 rlp 资源定位协议 
42 nameserver 互联网名称服务 
43 nicname WHOIS 目录服务 
49 tacacs 用于基于 TCP/IP 验证和访问的终端访问控制器访问控制系统 
50 re-mail-ck 远程邮件检查协议 
53 domain 域名服务(如 BIND) 
63 whois++ WHOIS++,被扩展了的 WHOIS 服务 
67 bootps 引导协议(BOOTP)服务;还被动态主机配置协议(DHCP)服务使用 
68 bootpc Bootstrap(BOOTP)客户;还被动态主机配置协议(DHCP)客户使用 
69 tftp 小文件传输协议(TFTP) 
70 gopher Gopher 互联网文档搜寻和检索 
71 netrjs-1 远程作业服务 
72 netrjs-2 远程作业服务 
73 netrjs-3 远程作业服务 
73 netrjs-4 远程作业服务 
79 finger 用于用户联系信息的 Finger 服务 
80 http 用于万维网(WWW)服务的超文本传输协议(HTTP) 
88 kerberos Kerberos 网络验证系统 
95 supdup Telnet 协议扩展 
101 hostname SRI-NIC 机器上的主机名服务 
102 iso-tsap ISO 开发环境(ISODE)网络应用 
105 csnet-ns 邮箱名称服务器;也被 CSO 名称服务器使用 
107 rtelnet 远程 Telnet 
109 pop2 邮局协议版本2 
110 pop3 邮局协议版本3 
111 sunrpc 用于远程命令执行的远程过程调用(RPC)协议,被网络文件系统(NFS)使用 
113 auth 验证和身份识别协议 
115 sftp 安全文件传输协议(SFTP)服务 
117 uucp-path Unix 到 Unix 复制协议(UUCP)路径服务 
119 nntp 用于 USENET 讨论系统的网络新闻传输协议(NNTP) 
123 ntp 网络时间协议(NTP) 
137 netbios-ns 在红帽企业 Linux 中被 Samba 使用的 NETBIOS 名称服务 
138 netbios-dgm 在红帽企业 Linux 中被 Samba 使用的 NETBIOS 数据报服务 
139 netbios-ssn 在红帽企业 Linux 中被 Samba 使用的NET BIOS 会话服务 
143 imap 互联网消息存取协议(IMAP) 
161 snmp 简单网络管理协议(SNMP) 
162 snmptrap SNMP 的陷阱 
163 cmip-man 通用管理信息协议(CMIP) 
164 cmip-agent 通用管理信息协议(CMIP) 
174 mailq MAILQ 
177 xdmcp X 显示管理器控制协议 
178 nextstep NeXTStep 窗口服务器 
179 bgp 边界网络协议 
191 prospero Cliffod Neuman 的 Prospero 服务 
194 irc 互联网中继聊天(IRC) 
199 smux SNMP UNIX 多路复用 
201 at-rtmp AppleTalk 选路 
202 at-nbp AppleTalk 名称绑定 
204 at-echo AppleTalk echo 服务 
206 at-zis AppleTalk 区块信息 
209 qmtp 快速邮件传输协议(QMTP) 
210 z39.50 NISO Z39.50 数据库 
213 ipx 互联网络分组交换协议(IPX),被 Novell Netware 环境常用的数据报协议 
220 imap3 互联网消息存取协议版本3 
245 link LINK 
347 fatserv Fatmen 服务器 
363 rsvp_tunnel RSVP 隧道 
369 rpc2portmap Coda 文件系统端口映射器 
370 codaauth2 Coda 文件系统验证服务 
372 ulistproc UNIX Listserv 
389 ldap 轻型目录存取协议(LDAP) 
427 svrloc 服务位置协议(SLP) 
434 mobileip-agent 可移互联网协议(IP)代理 
435 mobilip-mn 可移互联网协议(IP)管理器 
443 https 安全超文本传输协议(HTTP) 
444 snpp 小型网络分页协议 
445 microsoft-ds 通过 TCP/IP 的服务器消息块(SMB) 
464 kpasswd Kerberos 口令和钥匙改换服务 
468 photuris Photuris 会话钥匙管理协议 
487 saft 简单不对称文件传输(SAFT)协议 
488 gss-http 用于 HTTP 的通用安全服务(GSS) 
496 pim-rp-disc 用于协议独立的多址传播(PIM)服务的会合点发现(RP-DISC) 
500 isakmp 互联网安全关联和钥匙管理协议(ISAKMP) 
535 iiop 互联网内部对象请求代理协议(IIOP) 
538 gdomap GNUstep 分布式对象映射器(GDOMAP) 
546 dhcpv6-client 动态主机配置协议(DHCP)版本6客户 
547 dhcpv6-server 动态主机配置协议(DHCP)版本6服务 
554 rtsp 实时流播协议(RTSP) 
563 nntps 通过安全套接字层的网络新闻传输协议(NNTPS) 
565 whoami whoami 
587 submission 邮件消息提交代理(MSA) 
610 npmp-local 网络外设管理协议(NPMP)本地 / 分布式排队系统(DQS) 
611 npmp-gui 网络外设管理协议(NPMP)GUI / 分布式排队系统(DQS) 
612 hmmp-ind HMMP 指示 / DQS 
631 ipp 互联网打印协议(IPP) 
636 ldaps 通过安全套接字层的轻型目录访问协议(LDAPS) 
674 acap 应用程序配置存取协议(ACAP) 
694 ha-cluster 用于带有高可用性的群集的心跳服务 
749 kerberos-adm Kerberos 版本5(v5)的“kadmin”数据库管理 
750 kerberos-iv Kerberos 版本4(v4)服务 
765 webster 网络词典 
767 phonebook 网络电话簿 
873 rsync rsync 文件传输服务 
992 telnets 通过安全套接字层的 Telnet(TelnetS) 
993 imaps 通过安全套接字层的互联网消息存取协议(IMAPS) 
994 ircs 通过安全套接字层的互联网中继聊天(IRCS) 
995 pop3s 通过安全套接字层的邮局协议版本3(POPS3) linux
*/

前提:首先你必须知道,端口不是独立存在的,它是依附于进程的。某个进程开启,那么它对应的端口就开启了,进程关闭,则该端口也就关闭了。下次若某个进程再次开启,则相应的端口也再次开启。而不要纯粹的理解为关闭掉某个端口,不过可以禁用某个端口。

  1. 可以通过"~$ netstat -anp" 来查看哪些端口被打开。

  (注:加参数‘-n‘会将应用程序转为端口显示,即数字格式的地址,如:nfs->2049, ftp->21,因此可以开启两个终端,一一对应一下程序所对应的端口号)

  2. 然后可以通过"~$ lsof -i:$PORT"查看应用该端口的程序($PORT指对应的端口号)。或者你也可以查看文件/etc/services,从里面可以找出端口所对应的服务。

  (注:有些端口通过netstat查不出来,更可靠的方法是"~$ sudo nmap -sT -O localhost")

  3. 若要关闭某个端口,则可以:

  1)通过iptables工具将该端口禁掉,如:

  "~$ sudo iptables -A INPUT -p tcp --dport $PORT -j DROP"

  "~$ sudo iptables -A OUTPUT -p tcp --dport $PORT -j DROP"

  2)或者关掉对应的应用程序,则端口就自然关闭了,如:

  "~$ kill -9 PID" (PID:进程号)

  如: 通过"~$ netstat -anp | grep ssh"

  有显示: tcp 0 127.0.0.1:2121 0.0.0.0:* LISTEN 7546/ssh

  则: "~$ kill -9 7546"

  (可通过"~$ chkconfig"查看系统服务的开启状态)

http://www.3lian.com/edu/2015/08-06/236829.html

时间: 2024-08-11 16:13:00

【LINUX】端口号 及pow(2,n)表的相关文章

windows端口号速查表

windows端口号速查表 1 tcpmux TCP 端口服务多路复用  5 rje 远程作业入口  7 echo Echo 服务  9 discard 用于连接测试的空服务  11 systat 用于列举连接了的端口的系统状态  13 daytime 给请求主机发送日期和时间  17 qotd 给连接了的主机发送每日格言  18 msp 消息发送协议  19 chargen 字符生成服务:发送无止境的字符流  20 ftp-data FTP 数据端口  21 ftp 文件传输协议(FTP)端口

Linux对外提供服务 网络连接 端口操作 1.开启服务监听端口 2.设置防火墙,放行访问端口的包 iptables&amp;netfilter 四表五链和通堵策略

应用举例: Linux上安装Tomcat后,客户端要能够访问服务器上的Tomcat 操作: 1.网络操作 本机必须能够ping通目标主机(本地虚拟机或者远程主机) 2.端口操作 1.开启服务监听端口 2.设置防火墙,放行访问该端口的数据包 关键iptables和netfilter: iptables中的四表五链和堵通策略 CentOS6.7端口操作最佳实践: 查看iptables命令的帮助: iptables --help 不详细 man iptables 一般详细 手册页 info iptab

linux 查看端口号命令

Linux下如果我们需要知道2809号端口的情况的话,我们可以这样,如下命令: $netstat -pan|grep 24800 tcp        0      0 0.0.0.0:24800           0.0.0.0:*               LISTEN      4496/synergys        tcp        0      0 192.168.1.104:24800     192.168.1.106:49479     ESTABLISHED 4496

linux下进程、端口号相互查看方法

linux下通过进程名查看其占用端口: 1.先查看进程pid ps -ef | grep 进程名 2.通过pid查看占用端口 netstat -nap | grep 进程pid 例:通过nginx进程查看对应的端口号 #查看nginx进程pid: 命令: ps -ef | grep nginx 结果: root 9836 1 0 Jul11 ? 00:00:00 nginx: master process /usr/local/nginx/sbin/nginx nobody 9841 9836

linux解决端口号被占用

Linux下我们经常需要解决端口占用的问题,解决方法如下: linux: 1 某个端口号被占用,查看pid##根据端口查看进程信息 lsof -i:14700 ##根据进程号查看进程对应的可执行程序 ps -f -p 进程号 还可用netstatnetstat 的常用参数: - t.- u.- w和- x分别表示TCP.UDP.RAW和UNIX套接字连接.-a标记,还会显示出等待连接(也就是说处于监听模式)的套接字.-l 显示正在被监听(listen)的端口, -n表示直接显示端口数字而不是通过

Linux下Tomcat端口号以及进程

 Linux下Tomcat端口号以及进程 1,查看tomcat进程: ps -aux | grep tomcat(或者ps -ef | grep tomcat都行) 可以看到现在运行着两个tomcat进程,一个进程的pid为9974,另一个pid为23422.  2,根据进程查看端口号: sudo netstat -naop | grep 23422 这是查看pid为23422的进程占用的端口号: 可以看到9300和9399端口号被占用,其中9399是tomact Server的SHUTDOWN

春哥技术博客:宝塔Linux如何修改SSH端口号教程

今天春哥技术博客就客户咨询关于如何修改设置宝塔Linux默认SSH端口号的问题,下面春哥统一写文章教程,大家直接看就可以了. 为了提供服务器的安全性,部分站长需要修改SSH端口,默认端口为22,怎么修改SSH自定义端口呢,比如修改为8899,是否需要在防火墙放行? 其实和其他端口放行操作方法一样的,直接在宝塔的防火墙里面放行就可以了.具体操作方法如下: 登陆宝塔面板后台,在顶部有是否启动SSH 和 SSH 端口 22 这两个操作按钮如上图:直接将22改为自定义端口,然后点击 更改 .宝塔防火墙自

linux系统下,查看端口号被哪个应用占用

netstat -tunlp 会把所有端口和所有对应的程序显示出来. 用grep管道可过滤出来需要的信息.比如,17059端口号被占用了. 第一步:netstat -tunlp | grep 17059 第二步:ps -ef | grep 32563 即可看到什么应用占用的了.

linux查看端口号是否被占用

netstat -ntupl n表示不查询dns t表示tcp协议 u表示udp协议 p表示查询占用的程序 l表示查询正在监听的程序   查看那个进程占用了xxx端口 lsof -i:xxx 查看进程号为xxx的进程在哪里 ps -ef|grep xxx ps -ef |grep  程序名 netstat -nltp |grep 端口号或服务名