1.代码
服务端:
TimeServer.java
package com.ccy.IO.pools; import java.io.IOException; import java.net.ServerSocket; import java.net.Socket; public class TimeServer { public static void main(String[] args) throws IOException { int port = 8080; if(args!=null && args.length>0){ port = Integer.valueOf(args[0]); } ServerSocket server = null; try { server = new ServerSocket(port); Socket socket =null; TimeServerHandlerExecutePool pool = new TimeServerHandlerExecutePool(512, 1024); while(true){ socket = server.accept(); pool.excute(new TimeServerHandler(socket)); } } catch (Exception e) { e.printStackTrace(); }finally{ if(server!=null){ server.close(); server = null; } } } }
TimeServerHandlerExecutePool.java
package com.ccy.IO.pools; import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.ExecutorService; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit; public class TimeServerHandlerExecutePool { private ExecutorService executor; public TimeServerHandlerExecutePool(int maxPoolSize,int queueSize){ executor = new ThreadPoolExecutor(Runtime.getRuntime().availableProcessors(), maxPoolSize, 120L, TimeUnit.SECONDS,new ArrayBlockingQueue<Runnable>(queueSize)); } public void excute(java.lang.Runnable task){ executor.execute(task); } }
TimeServerHandler.java
package com.ccy.IO.pools; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.Socket; import java.text.SimpleDateFormat; public class TimeServerHandler implements Runnable{ private Socket socket; public TimeServerHandler(Socket socket){ this.socket = socket; } @Override public void run() { System.out.println("TIME SERVER IS LISTENING!!!"); BufferedReader reader =null; PrintWriter writer = null; try { reader = new BufferedReader(new InputStreamReader(this.socket.getInputStream())); writer = new PrintWriter(this.socket.getOutputStream(),true); String msg =null; SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); while(true){ msg = reader.readLine(); if(msg == null){ break; }else{ System.out.println("received msg is:"+msg); writer.println(format.format(new java.util.Date())); } } } catch (Exception e) { e.printStackTrace(); }finally{ if(reader!=null){ try { reader.close(); } catch (IOException e) { e.printStackTrace(); } reader = null; } if(writer!=null){ writer.close(); writer = null; } if(this.socket != null){ try { this.socket.close(); } catch (IOException e) { e.printStackTrace(); } this.socket = null; } } } }
客户端:
TimeClient.java
package com.ccy.IO.pools; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.Socket; public class TimeClient { public static void main(String[] args) { Socket socket = null; PrintWriter writer = null;; BufferedReader reader = null; try { socket = new Socket("127.0.0.1", 8080); reader = new BufferedReader(new InputStreamReader(socket.getInputStream())); writer = new PrintWriter(socket.getOutputStream(),true); writer.println("what time is it now?"); String resp = reader.readLine(); System.out.println("Now is:"+resp); } catch (Exception e) { e.printStackTrace(); }finally{ if(reader!=null){ try { reader.close(); } catch (IOException e) { e.printStackTrace(); } reader = null; } if(writer!=null){ writer.close(); writer = null; } if(socket != null){ try { socket.close(); } catch (IOException e) { e.printStackTrace(); } socket = null; } } } }
代码来自:李林峰《Netty权威指南》
2.分析:
采用线程池实现IO通信框架,避免了为每一个请求创建一个线程而造成的资源枯竭问题。但是依然采用IO同步阻塞模型,无法从根本上解决我们高并发,高性能的需求!
先模仿在创造吧!
更多精彩内容请继续关注我的博客:http://blog.csdn.net/caicongyang
记录与分享,你我共成长 -fromcaicongyang
相关推荐
在Java编程中,多线程是并发处理任务的关键技术,它可以极大地提高程序的执行效率,尤其是在服务器端应用中。本文将深入探讨一个轻量级的Java多线程池实现,这个实现允许线程间的通信,并提供了类似Akka Actor的调度...
5. **并发编程**:考虑到多设备管理和实时性需求,Javademo可能使用了线程或者线程池来实现并发操作。开发者需要了解Java并发API,如ExecutorService和Future,以及并发控制策略。 6. **日志记录**:良好的日志系统...
Java高级客户端提供了与Elasticsearch服务器通信的能力,支持复杂的查询、索引和聚合操作。它比基于HTTP的RestHighLevelClient更强大,能够更好地处理网络异常和序列化问题,同时提供了更丰富的API来操作数据。 3. ...
服务器端会创建一个`ServerBootstrap`,配置线程池、通道工厂、管道等,然后绑定一个端口开始监听。客户端使用`Bootstrap`,配置好对应的参数,连接到服务器。在服务器和客户端的管道中,都需要添加`ObjectDecoder`...
10. **性能优化**:在高并发场景下,可能需要考虑使用线程池批量发送短信,避免因大量请求而对服务器造成过大压力。 以上就是关于“java 第三方短信接口 demo及文档”的核心知识点。通过理解和实践这些步骤,开发者...
本示例“Java服务器和多客户端之间的建议通讯 demo”聚焦于如何利用Java实现一个简单的服务器,它能同时处理多个客户端的连接请求,这在多人在线游戏、实时聊天应用或者分布式系统中是非常常见的场景。我们将深入...
对于POST请求,服务器需要解析请求体中的数据,并可能需要执行一些业务逻辑,如存储数据到数据库。 在Delphi中,可以使用 Indy(Internet Direct) 或 Synapse 这样的库来简化HTTP服务器的开发。Indy 是一个功能...
此外,这个demo可能还包含了线程池管理,用于处理客户端的请求,以及心跳机制,保持连接的活跃性。心跳机制通常是由客户端定时向服务器发送空消息,服务器接收到后回复确认,以此判断连接是否正常。 总之,这个基于...
在服务器端,你需要创建一个ServerBootstrap实例,配置所需的参数,如线程池、套接字选项等。然后,通过bind方法指定监听的端口,启动服务器。服务器的Pipeline通常会包含一个ByteToMessageDecoder,用于将接收到的...
本项目是一个基于Java实现的多人聊天系统,它包括客户端(ClientDemo.java)和服务器端两部分,旨在提供一个实时、互动的通信平台,允许多个用户通过网络进行对话交流。这个系统的核心在于利用Java的Socket编程来...
在这个“grpc-server-demo”项目中,我们将深入理解如何使用Java实现gRPC服务器。 1. **gRPC基础概念** - **RPC**:RPC允许一个程序调用另一个不在同一台机器上的程序,就像调用本地函数一样简单。 - **ProtoBuf*...
在Android中,我们通常使用`java.util.concurrent`包下的`ExecutorService`和`ThreadPoolExecutor`来创建线程池。线程池可以避免频繁创建和销毁线程带来的性能开销,提高系统资源的利用率。通过合理配置线程池的参数...
在"quartzDemo任务调度例子"中,我们将探讨如何利用Quartz实现Java应用程序中的定时任务。 1. **Quartz简介** Quartz是Cron-like和Calendar-based任务调度库,用于在Java应用程序中安排和管理作业。它提供了丰富的...
在Java编程领域,高并发和多线程是关键的技术之一,尤其在服务器端应用和大数据处理中至关重要。这个"高并发多线程处理demo-java.rar"压缩包提供了一个实际的Java实现,展示了如何构建一个并发队列来接收数据,并...
在Java开发中,JSON-RPC框架可以帮助开发者实现客户端与服务器之间的高效通信,常用于分布式系统或者微服务架构。本项目实战主要基于JSON-RPC进行,我们将探讨如何使用Java实现一个简单的JSON-RPC服务端和客户端。 ...
同时,服务器会有一个定时任务(例如使用Java的ScheduledExecutorService)来定期检查客户端列表,如果发现有超过预设时间未收到心跳包的客户端,就将其视为断开连接并从列表中移除。 在实现心跳机制时,我们需要...
标题 "springMVC+redis+线程池+ibatis的demo做pv统计" 提供了关于一个基于Java Web开发的PV(Page View)统计系统的简要概述。这个系统结合了多个核心组件,包括Spring MVC作为MVC框架,Redis作为缓存数据库,线程池...
【标题】"java生产项目常用的demo.zip" 描述了这个压缩包的核心内容,它是一个集成了Java实际开发中常见示例的资源集合。这通常意味着它包含了一系列用于演示和学习Java编程语言在真实生产环境中的应用的代码示例。...
Java Socket编程是网络编程的基础,尤其在实现服务器与客户端间通信时扮演着重要角色。"异步长连接"是Java Socket编程中一种高效且广泛使用的通信模式,它允许客户端和服务器保持连接状态,以便在需要时快速交换数据...
后端Java Demo程序则是为微信小程序提供数据支持和服务的服务器端代码示例。这个压缩包“微信小程序的后端Java Demo程序.zip”包含了使用Java语言开发的微信小程序后端服务的源代码,我们可以从以下几个方面来理解和...