分布式系统Socket编程.ppt

  1. 1、本文档共91页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
分布式系统Socket编程.ppt

网络API API:应用程序编程接口 Java网络应用程序编程接口( 包) Socket接口 RMI: Remote Method Invocation远程方法调用 UNIX Berkeley sockets RPC( Remote Procedure call) Windows Winsock 各种常见的应用程序编程接口 基于套接字的字节输入流和输出流的创建-网络编程实例 实例研究 时间协议 时间协议 时间协议-续 ABOUT NTP TCP/IP协议中,美国德拉瓦大学的David L. Mills教授于1985年提出同步时间的协议NTP协议 用来在Internet上使不同的机器能维持相同时间的一种通讯协议 可以估算封包在网络上的往返延迟 可获得毫秒级的精度 NTP 现在网上的许多时间校准软件,有些支持SNTP协议、有些支持TIME协议 免费提供标准时钟服务http: //上有列表 * while (true) { System.out.println(Looking for a client... ); // blocks until client connects final Socket clientSocket = serverSocket.accept(); // one request, one executor; one executor on thread. Runnable response = new Runnable() { public void run() { try { handleRequest(clientSocket); } catch (IOException ex) { System.err.println(ex.getMessage()); } } }; ec.execute(response); } ec.shutdown(); } * private static void handleRequest(Socket clientSocket) throws IOException { System.out.println(A client connected.); Scanner in = new Scanner(clientSocket.getInputStream()); PrintWriter out = new PrintWriter(clientSocket.getOutputStream(), true); out.println(Hello! Enter BYE to exit.); String line; while (true) { line = in.nextLine(); System.out.println(line); // Prints on server side if (line.trim().toUpperCase().startsWith(SIGN_OFF_TOKEN)) { out.println(Bye bye, See you later!); // client side output System.out.println(Client signed off); break; } } * } static private final int DEFAULT_PORT = 8189; static private final String SIGN_OFF_TOKEN = BYE; private static final int THREADS_THRESHOLD = 128; } * 线程池优点 线程池大小的参数防范了系统崩溃的风险,仔细地调整线程池大小的参

文档评论(0)

000 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档