- 浏览: 515681 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (173)
- CAS (2)
- J2SE (13)
- J2EE (5)
- Oracle (14)
- MySql (6)
- Hibernate (7)
- IBatis (5)
- JQuery (3)
- Html (9)
- Linux (3)
- CentOS (3)
- Test (3)
- SVN (4)
- Tomat (2)
- AJAX-ZK (2)
- Bug Track (1)
- Appfuse2 (6)
- MyEclipse (9)
- PowerDesign (1)
- Apache (1)
- Uml (1)
- 其它资料 (11)
- 读书笔记 (15)
- 读书笔记-《领域驱动设计》 (3)
- Android (12)
- SSL VPN (1)
- Struts (5)
- java 代理服务器 (1)
- 项目管理 (2)
- NOSQL 数据库 (1)
- 工作流 (0)
- 国内主要工作流厂商分析 (1)
- SparkIDE (2)
最新评论
-
吉米家:
JasperReports是不错,但是就是对代码编写要求太高了 ...
JasperReports给java web报表开发人员带来希望 -
asd51731:
谷超 写道如果html中有图片,如何把图片转换到word中呢? ...
使用Java将HTML转成Word格式文件 -
谷超:
如果html中有图片,如何把图片转换到word中呢?
使用Java将HTML转成Word格式文件 -
xwqiang:
没事看看,受教了
一个简单的基于注解的 Controller -
JC044008:
文章给力的。
一个简单的基于注解的 Controller
3.6 创建多线程的服务器
在本书第1章的1.5.1节的例程1-2的EchoServer中,其service()方法负责接收客户连接,以及与客户通信。service()方法的处理流程如下:
|
EchoServer接收到一个客户连接,就与客户进行通信,通信完毕后断开连接,然后再接收下一个客户连接。假如同时有多个客户请求连接,这些客户就必须排队等候EchoServer的响应。EchoServer无法同时与多个客户通信。
许多实际应用要求服务器具有同时为多个客户提供服务的能力。HTTP服务器就是最明显的例子。任何时刻,HTTP服务器都可能接收到大量的客户请求,每个客户都希望能快速得到HTTP服务器的响应。如果长时间让客户等待,会使网站失去信誉,从而降低访问量。
可以用并发性能来衡量一个服务器同时响应多个客户的能力。一个具有好的并发性能的服务器,必须符合两个条件:
◆能同时接收并处理多个客户连接;
◆对于每个客户,都会迅速给予响应。
服务器同时处理的客户连接数目越多,并且对每个客户作出响应的速度越快,就表明并发性能越高。
用多个线程来同时为多个客户提供服务,这是提高服务器的并发性能的最常用的手段。本节将按照3种方式来重新实现EchoServer,它们都使用了多线程。
◆为每个客户分配一个工作线程。
◆创建一个线程池,由其中的工作线程来为客户服务。
◆利用JDK的Java类库中现成的线程池,由它的工作线程来为客户服务。
3.6.1 为每个客户分配一个线程
服务器的主线程负责接收客户的连接,每次接收到一个客户连接,就会创建一个工作线程,由它负责与客户的通信。以下是EchoServer的service()方法的代码:
|
以上工作线程workThread执行Handler的run()方法。Handler类实现了Runnable接口,它的run()方法负责与单 个客户通信,与客户通信结束后,就会断开连接,执行Handler的run()方法的工作线程也会自然终止。如例程3-5所示是EchoServer类及 Handler类的源程序。
例程3-5 EchoServer.java(为每个任务分配一个线程)
|
3.6.2 创建线程池
在3.6.1节介绍的实现方式中,对每个客户都分配一个新的工作线程。当工作线程与客户通信结束,这个线程就被销毁。这种实现方式有以下不足之处。
◆服务器创建和销毁工作线程的开销(包括所花费的时间和系统资源)很大。如果服务器需要与许多客户通信,并且与每个客户的通信时间都很短,那么有可能服务器为客户创建新线程的开销比实际与客户通信的开销还要大。
◆除了创建和销毁线程的开销之外,活动的线程也消耗系统资源。每个线程本身都会占用一定的内存(每个线程需要大约1M内存),如果同时有大量客户连接服务器,就必须创建大量工作线程,它们消耗了大量内存,可能会导致系统的内存空间不足。
◆如果线程数目固定,并且每个线程都有很长的生命周期,那么线程切换也是相对固定的。不同操作系统有不同的切换周期,一般在20毫秒左右。这里所说 的线程切换是指在Java虚拟机,以及底层操作系统的调度下,线程之间转让CPU的使用权。如果频繁创建和销毁线程,那么将导致频繁地切换线程,因为一个 线程被销毁后,必然要把CPU转让给另一个已经就绪的线程,使该线程获得运行机会。在这种情况下,线程之间的切换不再遵循系统的固定切换周期,切换线程的 开销甚至比创建及销毁线程的开销还大。
线程池为线程生命周期开销问题和系统资源不足问题提供了解决方案。线程池中预先创建了一些工作线程,它们不断从工作队列中取出任务,然后执行该任务。当工作线程执行完一个任务时,就会继续执行工作队列中的下一个任务。线程池具有以下优点:
◆减少了创建和销毁线程的次数,每个工作线程都可以一直被重用,能执行多个任务。
◆可以根据系统的承载能力,方便地调整线程池中线程的数目,防止因为消耗过量系统资源而导致系统崩溃。
如例程3-6所示,ThreadPool类提供了线程池的一种实现方案。
例程3-6 ThreadPool.java
|
在ThreadPool类中定义了一个LinkedList类型的workQueue成员变量,它表示工作队列,用来存放线程池要执行的任务,每个 任务都是Runnable实例。ThreadPool类的客户程序(利用ThreadPool来执行任务的程序)只要调用ThreadPool类的 execute (Runnable task)方法,就能向线程池提交任务。在ThreadPool类的execute()方法中,先判断线程池是否已 经关闭。如果线程池已经关闭,就不再接收任务,否则就把任务加入到工作队列中,并且唤醒正在等待任务的工作线程。
发表评论
-
java static 变量的介绍
2009-11-18 09:54 1390java static 变量的介绍,写个例子说明一下: ... -
JAVA 通过使用 Openoffice3 将 MS word 解析成 html
2009-10-20 13:14 4178我使用 jodconverter-core-3.0-beta- ... -
maven2 下载包的时候内存溢出:
2009-10-14 11:35 2868maven2 下载包的时候内存溢出: mvn inst ... -
java写从键盘输入十个数并计算结果
2009-10-09 15:08 3678import java.io.*; public cla ... -
Java程序员到架构师的推荐阅读书籍
2009-09-14 16:23 1227一、Java编程入门类 对 ... -
java中读取文件的方式
2009-07-01 08:46 1679一、多种方式读文件内 ... -
批量导出记录,并且将内存中数据转换html,然后压缩成Zip下载。
2009-06-23 11:03 2058该功能主要是实现,将记录批量转换html然后,打包压缩成zip ... -
Java 版本 IP 数据库查询
2009-05-22 11:54 3625我在网上找了很多java查询IP数据的方法,但是没有人打 ... -
使用Java将HTML转成Word格式文件
2009-04-28 13:26 22596import java.io.ByteArrayInputSt ... -
Java网络编程精解之ServerSocket用法详解三
2009-04-27 15:33 25843.7 关闭服务器 前面介绍的EchoServer服务器都 ... -
Java网络编程精解之ServerSocket用法详解一2
2009-04-27 15:32 49523.2 接收和关闭与客 ... -
Java网络编程精解之ServerSocket用法详解一
2009-04-27 15:31 6850在客户/服务器通信模式中,服务器端需要创建监听特定端口的Ser ...
相关推荐
Java网络编程的核心在于客户端与服务器端的交互,而ServerSocket是Java中用于服务器端的类,它使得服务器能够监听特定端口,接收客户端的连接请求。本文将详细讲解ServerSocket的使用方法及其在多线程环境下的应用。...
《Java网络编程精解》是孙卫琴老师的一本经典教程,主要涵盖了Java语言在网络编程领域的深度解析。这本书深入浅出地介绍了如何使用Java进行网络通信,包括基本的TCP/IP协议、套接字编程、多线程技术以及HTTP、FTP等...
在深入探讨Java网络编程中的非阻塞与阻塞编程之前,我们先来了解这两个概念的基本含义。阻塞编程,通常指的是在程序执行过程中,当某一部分代码遇到I/O操作时,如读写文件或网络通信,整个程序会暂停运行,等待I/O...
读书笔记:JAVA网络编程精解
Java网络编程精解PPT课件.ppt 本资源摘要信息是关于Java网络编程的PPT课件,主要介绍了基于UDP的数据报和套接字的相关知识点。 UDP协议简介 UDP(User Datagram Protocol,用户数据报协议)是一种传输层协议,...
Java编程是信息技术领域中最受欢迎的编程语言之一,尤其在企业级应用开发中占据主导地位。"Java编程案例精解源代码"提供了丰富的实例,帮助学习者深入理解和掌握Java编程技术。这个压缩包文件包含了与书本配套的完整...
读书笔记:孙卫琴《Java网络编程精解》源码
Java编程是计算机科学领域中最广泛使用的编程语言之一,尤其在企业级应用开发中占据着核心地位。本资源“Java编程案例精解”旨在通过实际案例深入解析Java编程的各个方面,帮助学习者掌握Java编程的核心技术和实战...
本资源“Java编程案例精解素材.rar”包含了一系列实用的Java编程示例,旨在帮助学习者深入理解和掌握Java的核心概念与技术。 1. **使用邮件客户端工具**:JavaMail API是Java中用于处理电子邮件的库,它允许开发者...
在《Java编程案例精解》的光盘资料中,可能包含了大量的实战项目,比如简单的命令行应用、图形用户界面(GUI)程序、网络编程案例、多线程编程、数据库连接(JDBC)操作以及I/O流的使用。这些案例能帮助读者在实践中...
JavaScript 编程精解 中文第三版 JavaScript 编程精解 中文第三版
1. **Java网络API**: Java提供了一系列的API用于网络编程,包括Socket、ServerSocket、DatagramSocket和DatagramPacket等类。Socket用于实现TCP连接,ServerSocket则用于创建服务器端的监听套接字,而DatagramSocket...
"Java网络编程精解-孙卫琴.rar"可能是孙卫琴老师的著作,她是一位知名的Java教育专家。这本书可能详细解析了Java网络编程的各个方面,包括URL类的使用、HTTP协议的实现、NIO(非阻塞I/O)以及高级网络编程技巧。通过...
《Java网络编程精解》是孙卫琴先生的一本经典著作,主要针对Java开发者,深入讲解了Java在网络编程领域的核心知识。这本书涵盖了从基础概念到高级应用的多个方面,旨在帮助读者理解并掌握Java如何进行网络通信。以下...
Java编程精解(孙卫琴) 经典Java书籍,你值得拥有
Java数据库编程技术精解,是Java开发者必备的技能之一,主要围绕JDBC(Java Database Connectivity)接口进行深入探讨。JDBC是Java平台中用于与各种数据库进行交互的标准API,无论你是初学者还是经验丰富的开发人员...
javascript编程精解第三版中文版,来自github的翻译,epub电子书可在手机上看。
文件标题是“《JavaScript编程精解》.pdf”,描述中提到了“JavaScript 编程精解 中文第一版”,而标签同样为“JavaScript 编程精解”。部分内容重复提及了访问“稀酷客”网站的链接,这可能是出版商提供的额外资源...