导航:首页 > 编程系统 > linuxbio

linuxbio

发布时间:2023-07-28 16:19:24

linux内核设计与实现的目录

译者序
序言
前言
作者简介
第1章Linux内核简介1
1.1Unix的历史1
1.2追寻Linus足迹:Linux简介2
1.3操作系统和内核简介3
1.4Linux内核和传统Unix内核的比较5
1.5Linux内核版本7
1.6Linux内核开发者社区8
1.7小结8
第2章从内核出发10
2.1获取内核源码10
2.1.1使用Git10
2.1.1安装内核源代码10
2.1.3使用补丁11
2.2内核源码树11
2.3编译内核12
2.3.1配置内核12
2.3.2减少编译的垃圾信息14
2.3.3衍生多个编译作业 14
2.3.4安装新内核14
2.4内核开发的特点15
2.4.1无libc库抑或无标准头文件15
2.4.2GNU C16
2.4.3没有内存保护机制18
2.4.4不要轻易在内核中使用浮点数18
2.4.5容积小而固定的栈18
2.4.6同步和并发18
2.4.7可移植性的重要性19
2.5小结19
第3章进程管理20
3.1进程20
3.2进程描述符及任务结构 21
3.2.1分配进程描述符22
3.2.2进程描述符的存放23
3.2.3进程状态23
3.2.4设置当前进程状态25
3.2.5进程上下文25
3.2.6进程家族树25
3.3进程创建26
3.3.1写时拷贝27
3.3.2fork()27
3.3.3vfork()28
3.4线程在Linux中的实现28
3.4.1创建线程29
3.4.2内核线程30
3.5进程终结31
3.5.1删除进程描述符32
3.5.2孤儿进程造成的进退维谷32
3.6小结34
第4章进程调度35
4.1多任务35
4.2Linux 的进程调度36
4.3策略36
4.3.1I/O消耗型和处理器消耗型的进程36
4.3.2进程优先级37
4.3.3时间片38
4.3.4调度策略的活动38
4.4Linux调度算法39
4.4.1调度器类39
4.4.2Unix 系统中的进程调度40
4.4.3公平调度41
4.5Linux调度的实现42
4.5.1时间记账42
4.5.2进程选择44
4.5.3调度器入口48
4.5.4睡眠和唤醒49
4.6抢占和上下文切换51
4.6.1用户抢占53
4.6.2内核抢占53
4.7实时调度策略54
4.8与调度相关的系统调用54
4.8.1与调度策略和优先级相关的系统调用55
4.8.2与处理器绑定有关的系统调用55
4.8.3放弃处理器时间56
4.9小结56
第5章系统调用57
5.1与内核通信57
5.2API、POSIX和C库57
5.3系统调用58
5.3.1系统调用号59
5.3.2系统调用的性能59
5.4系统调用处理程序60
5.4.1指定恰当的系统调用60
5.4.2参数传递60
5.5系统调用的实现61
5.5.1实现系统调用61
5.5.2参数验证62
5.6系统调用上下文64
5.6.1绑定一个系统调用的最后步骤65
5.6.2从用户空间访问系统调用67
5.6.3为什么不通过系统调用的方式实现68
5.7小结68
第6章内核数据结构69
6.1链表69
6.1.1单向链表和双向链表69
6.1.2环形链表70
6.1.3沿链表移动71
6.1.4Linux 内核中的实现71
6.1.5操作链表73
6.1.6遍历链表75
6.2队列78
6.2.1kfifo79
6.2.2创建队列79
6.2.3推入队列数据79
6.2.4摘取队列数据80
6.2.5获取队列长度80
6.2.6重置和撤销队列80
6.2.7队列使用举例 81
6.3映射 81
6.3.1初始化一个idr82
6.3.2分配一个新的UID82
6.3.3查找UID83
6.3.4删除UID84
6.3.5撤销idr84
6.4二叉树84
6.4.1二叉搜索树84
6.4.2自平衡二叉搜索树 85
6.5数据结构以及选择 87
6.6算法复杂度88
6.6.1算法88
6.6.2大o 符号88
6.6.3大θ符号89
6.6.4时间复杂度89
6.7小结 90
第7章中断和中断处理91
7.1中断91
7.2中断处理程序92
7.3上半部与下半部的对比93
7.4注册中断处理程序93
7.4.1中断处理程序标志94
7.4.2一个中断例子95
7.4.3释放中断处理程序95
7.5编写中断处理程序96
7.5.1共享的中断处理程序97
7.5.2中断处理程序实例97
7.6中断上下文99
7.7中断处理机制的实现100
7.8/proc/interrupts102
7.9中断控制103
7.9.1禁止和激活中断103
7.9.2禁止指定中断线105
7.9.3中断系统的状态105
7.10小结106
第8章下半部和推后执行的工作107
8.1下半部107
8.1.1为什么要用下半部108
8.1.2下半部的环境108
8.2软中断110
8.2.1软中断的实现111
8.2.2使用软中断113
8.3tasklet114
8.3.1tasklet的实现114
8.3.2使用tasklet116
8.3.3老的BH机制119
8.4工作队列120
8.4.1工作队列的实现121
8.4.2使用工作队列124
8.4.3老的任务队列机制126
8.5下半部机制的选择127
8.6在下半部之间加锁128
8.7禁止下半部128
8.8小结129
第9章内核同步介绍131
9.1临界区和竞争条件131
9.1.1为什么我们需要保护132
9.1.2单个变量133
9.2加锁134
9.2.1造成并发执行的原因135
9.2.2了解要保护些什么136
9.3死锁137
9.4争用和扩展性138
9.5小结140
第10章内核同步方法141
10.1原子操作141
10.1.1原子整数操作142
10.1.264位原子操作144
10.1.3原子位操作145
10.2自旋锁147
10.2.1自旋锁方法148
10.2.2其他针对自旋锁的操作149
10.2.3自旋锁和下半部150
10.3读-写自旋锁150
10.4信号量152
10.4.1计数信号量和二值信号量153
10.4.2创建和初始化信号量154
10.4.3使用信号量154
10.5读-写信号量155
10.6互斥体156
10.6.1信号量和互斥体158
10.6.2自旋锁和互斥体158
10.7完成变量158
10.8BLK:大内核锁159
10.9顺序锁160
10.10禁止抢占161
10.11顺序和屏障162
10.12小结165
第11章定时器和时间管理166
11.1内核中的时间概念166
11.2节拍率:HZ167
11.2.1理想的HZ值168
11.2.2高HZ的优势169
11.2.3高HZ的劣势169
11.3jiffies170
11.3.1jiffies的内部表示171
11.3.2jiffies 的回绕172
11.3.3用户空间和HZ173
11.4硬时钟和定时器174
11.4.1实时时钟174
11.4.2系统定时器174
11.5时钟中断处理程序174
11.6实际时间176
11.7定时器178
11.7.1使用定时器178
11.7.2定时器竞争条件180
11.7.3实现定时器180
11.8延迟执行181
11.8.1忙等待181
11.8.2短延迟182
11.8.3schele_timeout()183
11.9小结185
第12章内存管理186
12.1页186
12.2区187
12.3获得页189
12.3.1获得填充为0的页190
12.3.2释放页191
12.4kmalloc()191
12.4.1gfp_mask标志192
12.4.2kfree()195
12.5vmalloc()196
12.6slab层197
12.6.1slab层的设计198
12.6.2slab分配器的接口200
12.7在栈上的静态分配203
12.7.1单页内核栈203
12.7.2在栈上光明正大地工作203
12.8高端内存的映射204
12.8.1永久映射204
12.8.2临时映射204
12.9每个CPU的分配20512.10新的每个CPU接口206
12.10.1编译时的每个CPU数据206
12.10.2运行时的每个CPU数据207
12.11使用每个CPU数据的原因208
12.12分配函数的选择209
12.13小结209
第13章虚拟文件系统210
13.1通用文件系统接口210
13.2文件系统抽象层211
13.3Unix文件系统212
13.4VFS 对象及其数据结构213
13.5超级块对象214
13.6超级块操作215
13.7索引节点对象217
13.8索引节点操作219
13.9目录项对象222
13.9.1目录项状态222
13.9.2目录项缓存223
13.10目录项操作224
13.11文件对象225
13.12文件操作226
13.13和文件系统相关的数据结构230
13.14和进程相关的数据结构232
13.15小结233
第14章块I/O层234
14.1剖析一个块设备234
14.2缓冲区和缓冲区头235
14.3bio结构体237
14.3.1I/O向量238
14.3.2新老方法对比239
14.4请求队列240
14.5I/O调度程序240
14.5.1I/O调度程序的工作241
14.5.2Linus 电梯241
14.5.3最终期限I/O调度程序242
14.5.4预测I/O调度程序244
14.5.5完全公正的排队I/O调度程序244
14.5.6空操作的I/O调度程序245
14.5.7I/O调度程序的选择245
14.6小结246
第15章进程地址空间247
15.1地址空间247
15.2内存描述符248
15.2.1分配内存描述符249
15.2.2撤销内存描述符250
15.2.3mm_struct 与内核线程250
15.3虚拟内存区域251
15.3.1VMA标志251
15.3.2VMA 操作253
15.3.3内存区域的树型结构和内存区域的链表结构254
15.3.4实际使用中的内存区域254
15.4操作内存区域255
15.4.1find_vma()256
15.4.2find_vma_prev()257
15.4.3find_vma_intersection()257
15.5mmap()和do_mmap():创建地址区间258
15.6mummap()和do_mummap():删除地址区间259
15.7页表260
15.8小结261
第16章页高速缓存和页回写262
16.1缓存手段262
16.1.1写缓存262
16.1.2缓存回收263
16.2Linux 页高速缓存264
16.2.1address_space对象264
16.2.2address_space 操作266
16.2.3基树267
16.2.4以前的页散列表268
16.3缓冲区高速缓存268
16.4flusher线程268
16.4.1膝上型计算机模式270
16.4.2历史上的bdflush、kupdated 和pdflush270
16.4.3避免拥塞的方法:使用多线程271
16.5小结271
第17章设备与模块273
17.1设备类型273
17.2模块274
17.2.1Hello,World274
17.2.2构建模块275
17.2.3安装模块277
17.2.4产生模块依赖性277
17.2.5载入模块278
17.2.6管理配置选项279
17.2.7模块参数280
17.2.8导出符号表282
17.3设备模型283
17.3.1kobject283
17.3.2ktype284
17.3.3kset285
17.3.4kobject、ktype和kset的相互关系285
17.3.5管理和操作kobject286
17.3.6引用计数287
17.4sysfs288
17.4.1sysfs中添加和删除kobject 290
17.4.2向sysfs中添加文件291
17.4.3内核事件层293
17.5小结294
第18章调试295
18.1准备开始295
18.2内核中的bug296
18.3通过打印来调试296
18.3.1健壮性296
18.3.2日志等级297
18.3.3记录缓冲区298
18.3.4syslogd和klogd298
18.3.5从printf()到printk()的转换298
18.4oops298
18.4.1ksymoops300
18.4.2kallsyms300
18.5内核调试配置选项301
18.6引发bug并打印信息301
18.7神奇的系统请求键302
18.8内核调试器的传奇303
18.8.1gdb303
18.8.2kgdb304
18.9探测系统304
18.9.1用UID作为选择条件304
18.9.2使用条件变量305
18.9.3使用统计量305
18.9.4重复频率限制305
18.10用二分查找法找出引发罪恶的变更306
18.11使用Git进行二分搜索307
18.12当所有的努力都失败时:社区308
18.13小结308
第19章可移植性309
19.1可移植操作系统309
19.2Linux移植史310
19.3字长和数据类型311
19.3.1不透明类型313
19.3.2指定数据类型314
19.3.3长度明确的类型314
19.3.4char型的符号问题315
19.4数据对齐315
19.4.1避免对齐引发的问题316
19.4.2非标准类型的对齐316
19.4.3结构体填补316
19.5字节顺序318
19.6时间319
19.7页长度320
19.8处理器排序320
19.9SMP、内核抢占、高端内存321
19.10小结321
第20章补丁、开发和社区322
20.1社区322
20.2Linux编码风格322
20.2.1缩进323
20.2.2switch 语句323
20.2.3空格324
20.2.4花括号325
20.2.5每行代码的长度326
20.2.6命名规范326
20.2.7函数326
20.2.8注释326
20.2.9typedef327
20.2.10多用现成的东西328
20.2.11在源码中减少使用ifdef328
20.2.12结构初始化328
20.2.13代码的事后修正329
20.3管理系统329
20.4提交错误报告329
20.5补丁330
20.5.1创建补丁330
20.5.2用Git创建补丁331
20.5.3提交补丁331
20.6小结332
参考资料333

Ⅱ linux怎么把block层的bio request发给scsi底层驱动从submit

plug的用于延时处理,以便收集多个request之后再批量发送给底层磁盘。
不过现在磁盘越来越快,这个plug引入延时缓存的技术已经是没必要的啦? 至少ssd磁盘应该不会再用了。
所以很多plug延时相关的接口都变了,struct request_queue 里面plug_fn都没有了,相关的定时器也被删了。
如果少数情况要使用plug的话,应该是类似下面这种on-stack plug的用法了。

Ⅲ 请给出常用应用程序所用的端口

0 通常用于分析操作系统。这一方法能够工作是因为在一些系统中“0”是无效端口,当你试图使用一种通常的闭合端口连接它时将产生不同的结果。一种典型的扫描:使用IP地址为0.0.0.0,设置ACK位并在以太网层广播。

1 tcpmux 这显示有人在寻找SGI Irix机器。Irix是实现tcpmux的主要提供者,缺省情况下tcpmux在这种系统中被打开。Iris机器在发布时含有几个缺省的无密码的帐户,如lp, guest, uucp, nuucp, demos, tutor, diag, EZsetup, OutOfBox, 和4Dgifts。许多管理员安装后忘记删除这些帐户。因此Hacker们在Internet上搜索tcpmux并利用这些帐户。

7 Echo 你能看到许多人们搜索Fraggle放大器时,发送到x.x.x.0和x.x.x.255的信息。常见的一种DoS攻击是echo循环(echo-loop),攻击者伪造从一个机器发送到另一个机器的UDP数据包,而两个机器分别以它们最快的方式回应这些数据包。另一种东西是由DoubleClick在词端口建立的TCP连接。有一种产品叫做“Resonate Global Dispatch”,它与DNS的这一端口连接以确定最近的路由。Harvest/squid cache将从3130端口发送UDP echo:“如果将cache的source_ping on选项打开,它将对原始主机的UDP echo端口回应一个HIT reply。”这将会产生许多这类数据包。

11 sysstat 这是一种UNIX服务,它会列出机器上所有正在运行的进程以及是什么启动了这些进程。这为入侵者提供了许多信息而威胁机器的安全,如暴露已知某些弱点或帐户的程序。这与UNIX系统中“ps”命令的结果相似。再说一遍:ICMP没有端口,ICMP port 11通常是ICMP type=11。

19 chargen 这是一种仅仅发送字符的服务。UDP版本将会在收到UDP包后回应含有垃圾字符的包。TCP连接时,会发送含有垃圾字符的数据流知道连接关闭。Hacker利用IP欺骗可以发动DoS攻击。伪造两个chargen服务器之间的UDP包。由于服务器企图回应两个服务器之间的无限的往返数据通讯一个chargen和echo将导致服务器过载。同样fraggle DoS攻击向目标地址的这个端口广播一个带有伪造受害者IP的数据包,受害者为了回应这些数据而过载。

21 ftp 最常见的攻击者用于寻找打开“anonymous”的ftp服务器的方法。这些服务器带有可读写的目录。Hackers或Crackers 利用这些服务器作为传送warez (私有程序) 和pr0n(故意拼错词而避免被搜索引擎分类)的节点。

22 ssh PcAnywhere 建立TCP和这一端口的连接可能是为了寻找ssh。这一服务有许多弱点。如果配置成特定的模式,许多使用RSAREF库的版本有不少漏洞。(建议在其它端口运行ssh)。还应该注意的是ssh工具包带有一个称为make-ssh-known-hosts的程序。它会扫描整个域的ssh主机。你有时会被使用这一程序的人无意中扫描到。UDP(而不是TCP)与另一端的5632端口相连意味着存在搜索pcAnywhere的扫描。5632(十六进制的0x1600)位交换后是0x0016(使进制的22)。

23 Telnet 入侵者在搜索远程登陆UNIX的服务。大多数情况下入侵者扫描这一端口是为了找到机器运行的操作系统。此外使用其它技术,入侵者会找到密码。

25 smtp 攻击者(spammer)寻找SMTP服务器是为了传递他们的spam。入侵者的帐户总被关闭,他们需要拨号连接到高带宽的e-mail服务器上,将简单的信息传递到不同的地址。SMTP服务器(尤其是sendmail)是进入系统的最常用方法之一,因为它们必须完整的暴露于Internet且邮件的路由是复杂的(暴露+复杂=弱点)。

53 DNS Hacker或crackers可能是试图进行区域传递(TCP),欺骗DNS(UDP)或隐藏其它通讯。因此防火墙常常过滤或记录53端口。需要注意的是你常会看到53端口做为UDP源端口。不稳定的防火墙通常允许这种通讯并假设这是对DNS查询的回复。Hacker常使用这种方法穿透防火墙。

67&68 Bootp和DHCP UDP上的Bootp/DHCP:通过DSL和cable-modem的防火墙常会看见大量发送到广播地址255.255.255.255的数据。这些机器在向DHCP服务器请求一个地址分配。Hacker常进入它们分配一个地址把自己作为局部路由器而发起大量的“中间人”(man-in-middle)攻击。客户端向68端口(bootps)广播请求配置,服务器向67端口(bootpc)广播回应请求。这种回应使用广播是因为客户端还不知道可以发送的IP地址。

69 TFTP(UDP) 许多服务器与bootp一起提供这项服务,便于从系统下载启动代码。但是它们常常错误配置而从系统提供任何文件,如密码文件。它们也可用于向系统写入文件。

79 finger Hacker用于获得用户信息,查询操作系统,探测已知的缓冲区溢出错误,回应从自己机器到其它机器finger扫描。

80 web站点默认80为服务端口,采用tcp或udp协议。

98 linuxconf 这个程序提供linux boxen的简单管理。通过整合的HTTP服务器在98端口提供基于Web界面的服务。它已发现有许多安全问题。一些版本setuid root,信任局域网,在/tmp下建立Internet可访问的文件,LANG环境变量有缓冲区溢出。此外因为它包含整合的服务器,许多典型的HTTP漏洞可能存在(缓冲区溢出,历遍目录等)

109 POP2 并不象POP3那样有名,但许多服务器同时提供两种服务(向后兼容)。在同一个服务器上POP3的漏洞在POP2中同样存在。

110 POP3 用于客户端访问服务器端的邮件服务。POP3服务有许多公认的弱点。关于用户名和密码交换缓冲区溢出的弱点至少有20个(这意味着Hacker可以在真正登陆前进入系统)。成功登陆后还有其它缓冲区溢出错误。

111 sunrpc portmap rpcbind Sun RPC PortMapper/RPCBIND。访问portmapper是扫描系统查看允许哪些RPC服务的最早的一步。常见RPC服务有:rpc.mountd, NFS, rpc.statd, rpc.csmd, rpc.ttybd, amd等。入侵者发现了允许的RPC服务将转向提供服务的特定端口测试漏洞。记住一定要记录线路中的daemon, IDS, 或sniffer,你可以发现入侵者正使用什么程序访问以便发现到底发生了什么。

113 Ident auth 这是一个许多机器上运行的协议,用于鉴别TCP连接的用户。使用标准的这种服务可以获得许多机器的信息(会被Hacker利用)。但是它可作为许多服务的记录器,尤其是FTP, POP, IMAP, SMTP和IRC等服务。通常如果有许多客户通过防火墙访问这些服务,你将会看到许多这个端口的连接请求。记住,如果你阻断这个端口客户端会感觉到在防火墙另一边与e-mail服务器的缓慢连接。许多防火墙支持在TCP连接的阻断过程中发回RST,着将回停止这一缓慢的连接。

119 NNTP news 新闻组传输协议,承载USENET通讯。当你链接到诸如:news://comp.security.firewalls/. 的地址时通常使用这个端口。这个端口的连接企图通常是人们在寻找USENET服务器。多数ISP限制只有他们的客户才能访问他们的新闻组服务器。打开新闻组服务器将允许发/读任何人的帖子,访问被限制的新闻组服务器,匿名发帖或发送spam。

135 oc-serv MS RPC end-point mapper Microsoft在这个端口运行DCE RPC end-point mapper为它的DCOM服务。这与UNIX 111端口的功能很相似。使用DCOM和/或RPC的服务利用机器上的end-point mapper注册它们的位置。远端客户连接到机器时,它们查询end-point mapper找到服务的位置。同样Hacker扫描机器的这个端口是为了找到诸如:这个机器上运行Exchange Server吗?是什么版本?这个端口除了被用来查询服务(如使用epmp)还可以被用于直接攻击。有一些DoS攻击直接针对这个端口。

137 NetBIOS name service nbtstat (UDP) 这是防火墙管理员最常见的信息。

139 NetBIOS File and Print Sharing 通过这个端口进入的连接试图获得NetBIOS/SMB服务。这个协议被用于Windows“文件和打印机共享”和SAMBA。在Internet上共享自己的硬盘是可能是最常见的问题。大量针对这一端口始于1999,后来逐渐变少。2000年又有回升。一些VBS(IE5 VisualBasic Scripting)开始将它们自己拷贝到这个端口,试图在这个端口繁殖。

143 IMAP 和上面POP3的安全问题一样,许多IMAP服务器有缓冲区溢出漏洞运行登陆过程中进入。记住:一种Linux蠕虫(admw0rm)会通过这个端口繁殖,因此许多这个端口的扫描来自不知情的已被感染的用户。当RadHat在他们的Linux发布版本中默认允许IMAP后,这些漏洞变得流行起来。Morris蠕虫以后这还是第一次广泛传播的蠕虫。这一端口还被用于IMAP2,但并不流行。已有一些报道发现有些0到143端口的攻击源于脚本。

161 SNMP(UDP) 入侵者常探测的端口。SNMP允许远程管理设备。所有配置和运行信息都储存在数据库中,通过SNMP客获得这些信息。许多管理员错误配置将它们暴露于Internet。Crackers将试图使用缺省的密码“public”“private”访问系统。他们可能会试验所有可能的组合。SNMP包可能会被错误的指向你的网络。Windows机器常会因为错误配置将HP JetDirect remote management软件使用SNMP。HP OBJECT IDENTIFIER将收到SNMP包。新版的Win98使用SNMP解析域名,你会看见这种包在子网内广播(cable modem, DSL)查询sysName和其它信息。

162 SNMP trap 可能是由于错误配置

177 xdmcp 许多Hacker通过它访问X-Windows控制台, 它同时需要打开6000端口。

513 rwho 可能是从使用cable modem或DSL登陆到的子网中的UNIX机器发出的广播。这些人为Hacker进入他们的系统提供了很有趣的信息。

553 CORBA IIOP (UDP) 如果你使用cable modem或DSL VLAN,你将会看到这个端口的广播。CORBA是一种面向对象的RPC(remote procere call)系统。Hacker会利用这些信息进入系统。

600 Pcserver backdoor 请查看1524端口。
一些玩script的孩子认为他们通过修改ingreslock和pcserver文件已经完全攻破了系统-- Alan J. Rosenthal.

635 mountd Linux的mountd Bug。这是人们扫描的一个流行的Bug。大多数对这个端口的扫描是基于UDP的,但基于TCP的mountd有所增加(mountd同时运行于两个端口)。记住,mountd可运行于任何端口(到底在哪个端口,需要在端口111做portmap查询),只是Linux默认为635端口,就象NFS通常运行于2049端口。

1024 许多人问这个端口是干什么的。它是动态端口的开始。许多程序并不在乎用哪个端口连接网络,它们请求操作系统为它们分配“下一个闲置端口”。基于这一点分配从端口1024开始。这意味着第一个向系统请求分配动态端口的程序将被分配端口1024。为了验证这一点,你可以重启机器,打开Telnet,再打开一个窗口运行“natstat -a”,你将会看到Telnet被分配1024端口。请求的程序越多,动态端口也越多。操作系统分配的端口将逐渐变大。再来一遍,当你浏览Web页时用“netstat”查看,每个Web页需要一个新端口。

1025,1026 参见1024

1080 SOCKS 这一协议以管道方式穿过防火墙,允许防火墙后面的许多人通过一个IP地址访问Internet。理论上它应该只允许内部的通信向外达到Internet。但是由于错误的配置,它会允许Hacker/Cracker的位于防火墙外部的攻击穿过防火墙。或者简单地回应位于Internet上的计算机,从而掩饰他们对你的直接攻击。WinGate是一种常见的Windows个人防火墙,常会发生上述的错误配置。在加入IRC聊天室时常会看到这种情况。

1114 SQL 系统本身很少扫描这个端口,但常常是sscan脚本的一部分。

1243 Sub-7木马(TCP)

1524 ingreslock 后门许多攻击脚本将安装一个后门Shell于这个端口(尤其是那些针对Sun系统中sendmail和RPC服务漏洞的脚本,如statd, ttdbserver和cmsd)。如果你刚刚安装了你的防火墙就看到在这个端口上的连接企图,很可能是上述原因。你可以试试Telnet到你的机器上的这个端口,看看它是否会给你一个Shell。连接到600/pcserver也存在这个问题。

2049 NFS NFS程序常运行于这个端口。通常需要访问portmapper查询这个服务运行于哪个端口,但是大部分情况是安装后NFS运行于这个端口,Hacker/Cracker因而可以闭开portmapper直接测试这个端口。

3128 squid 这是Squid HTTP代理服务器的默认端口。攻击者扫描这个端口是为了搜寻一个代理服务器而匿名访问Internet。你也会看到搜索其它代理服务器的端口:8000/8001/8080/8888。扫描这一端口的另一原因是:用户正在进入聊天室。其它用户(或服务器本身)也会检验这个端口以确定用户的机器是否支持代理。

5632 pcAnywere 你会看到很多这个端口的扫描,这依赖于你所在的位置。当用户打开pcAnywere时,它会自动扫描局域网C类网以寻找可能得代理(译者:指agent而不是proxy)。Hacker/cracker也会寻找开放这种服务的机器,所以应该查看这种扫描的源地址。一些搜寻pcAnywere的扫描常包含端口22的UDP数据包。

6776 Sub-7 artifact 这个端口是从Sub-7主端口分离出来的用于传送数据的端口。例如当控制者通过电话线控制另一台机器,而被控机器挂断时你将会看到这种情况。因此当另一人以此IP拨入时,他们将会看到持续的,在这个端口的连接企图。(译者:即看到防火墙报告这一端口的连接企图时,并不表示你已被Sub-7控制。)

6970 RealAudio RealAudio客户将从服务器的6970-7170的UDP端口接收音频数据流。这是由TCP7070端口外向控制连接设置的。

13223 PowWow PowWow 是Tribal Voice的聊天程序。它允许用户在此端口打开私人聊天的连接。这一程序对于建立连接非常具有“进攻性”。它会“驻扎”在这一TCP端口等待回应。这造成类似心跳间隔的连接企图。如果你是一个拨号用户,从另一个聊天者手中“继承”了IP地址这种情况就会发生:好象很多不同的人在测试这一端口。这一协议使用“OPNG”作为其连接企图的前四个字节。

17027 Concent 这是一个外向连接。这是由于公司内部有人安装了带有Concent "adbot" 的共享软件。Concent "adbot"是为共享软件显示广告服务的。使用这种服务的一种流行的软件是Pkware。有人试验:阻断这一外向连接不会有任何问题,但是封掉IP地址本身将会导致adbots持续在每秒内试图连接多次而导致连接过载:
机器会不断试图解析DNS名—ads.concent.com,即IP地址216.33.210.40 ;216.33.199.77 ;216.33.199.80 ;216.33.199.81;216.33.210.41。(译者:不知NetAnts使用的Radiate是否也有这种现象)

27374 Sub-7木马(TCP)

30100 NetSphere木马(TCP) 通常这一端口的扫描是为了寻找中了NetSphere木马。

31337 Back Orifice “elite” Hacker中31337读做“elite”/ei’li:t/(译者:法语,译为中坚力量,精华。即3=E, 1=L, 7=T)。因此许多后门程序运行于这一端口。其中最有名的是Back Orifice。曾经一段时间内这是Internet上最常见的扫描。现在它的流行越来越少,其它的木马程序越来越流行。

31789 Hack-a-tack 这一端口的UDP通讯通常是由于"Hack-a-tack"远程访问木马(RAT, Remote Access Trojan)。这种木马包含内置的31790端口扫描器,因此任何31789端口到317890端口的连接意味着已经有这种入侵。(31789端口是控制连接,317890端口是文件传输连接)

32770~32900 RPC服务 Sun Solaris的RPC服务在这一范围内。详细的说:早期版本的Solaris(2.5.1之前)将portmapper置于这一范围内,即使低端口被防火墙封闭仍然允许Hacker/cracker访问这一端口。扫描这一范围内的端口不是为了寻找portmapper,就是为了寻找可被攻击的已知的RPC服务。

33434~33600 traceroute 如果你看到这一端口范围内的UDP数据包(且只在此范围之内)则可能是由于traceroute。

Ⅳ 安装Bio-Linux时,无法将GRUB安装到/dev/sda

电脑出现grub问题开不了机,建议如下:
按F5跳过检索,建议开机后用网络卫士全面体检电脑
这个是硬盘读取问题,正常的,有时候电脑硬盘会出现

如果以上方法无效或者开不了机,建议修复引导boot或者重装系统。

阅读全文

与linuxbio相关的资料

热点内容
食品原材料到什么网站购买 浏览:649
一年级的小孩子学编程怎么样 浏览:863
ic考勤机怎么导出数据 浏览:922
网站设计编程如何开始学习 浏览:749
淘宝代码隐藏导航不见了 浏览:7
macbookpro如何修改文件内容 浏览:965
java稳定排序 浏览:53
oppo文件管理的图片 浏览:335
plc编程步数怎么计算 浏览:142
ipad看电脑文件 浏览:935
成都制作pdf文件 浏览:735
怎么样点开电脑里面的网络连接 浏览:755
微信怎么退出账号 浏览:32
w微信开发者工具 浏览:325
数据库还原附加 浏览:713
打包成exe执行文件 浏览:652
信丰营销app有哪些 浏览:463
苹果文件下载项如何下载 浏览:179
ps抠婚纱教程 浏览:203
如何在移动硬盘上隐藏文件夹 浏览:451

友情链接