时间计算机网络论文基于CS的时间同步服务器的实现

cs服务器  时间:2021-01-30  阅读:()

武汉理工大学

计算机网络课程论文题 目 基于C/S的时间同步服务器的实现

作 者

学 院

专 业

学 号

指 导

教 师 李方敏

二〇一六年四月十一日

武汉理工大学信息工程学院课程论文诚信声明

本人声明所呈交的课程论文是本人在指导老师的指导下独立开展工作所取得的成果成果不存在知识产权争议除文中已经注明引用的内容外本课程论文不含任何其他个人或集体已经发表或创作过的作品成果。对本文工作做出重要贡献的个人和集体均已在文中以明确方式标明。本人完全意识到本声明的法律结果由本人承担。

本科课程论文作者签名

二〇一六年四月十一日

摘要

计算机网络是指将地理位置不同的具有独立功能的多台计算机及其外部设备通过通信线路连接起来在网络操作系统网络管理软件及网络通信协议的管理和协调下实现资源共享和信息传递的计算机系统。本次计算机网络的论文题目为基于C/S的时间同步服务器的实现。时间服务器是在局域网中作为发布统一时间的服务器它利用电脑网络把时间信息传递给用户。参照现有的时间服务器的原理以及效果实现一个时间服务器的服务端和客户端。服务器端开放指定的端口发布时间到网络中其他客户端从网络中获取该时间并将本地时间与之同步。本次设计以Visual Studio 2010为开发平台从选题背景方案论证过程论述结果分析和结论总结五方面来论述本次设计的观点的过程。

关键词时间同步 客户端 服务端 TCP/I P

目录

一选题背景. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .1

1.1 问题提出. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .1

1.2软件使用. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .1

1.3预期目标. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2

二方案论证. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2

三过程论述. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3

3.1相关原理. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3

3.2设计过程. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4

3.3算法流程图. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .5

四结果分析. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .6

五结论总结. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .8

参考文献. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .10

附录一程序源代码. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .11

致谢. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .15

课程论文成绩评定表. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .16

计算机网络论文《基于C/S的时间同步服务器的实现》

一选题背景

1.1问题提出

对于一个由计算机组成的系统中其中各个节点计算机都有自己的额系统时间计算机网络控制系统中各子系统时间段额一致性是网络控制系统中的核心问题之一它的准确性对网络控制系统的实时性和准确性有重大影响。但是由于在运行中受到设计缺陷、环境温度变化、电磁干扰、负载等多种因素的影响计算机的时钟大多是不精确的随着时间的推移这种误差逐渐累积时间的偏差将越来越大。在一些重要的应用中(如实时数据采集、监控、工业控制网络以及电信等) 时间的准确性要求更为严格和苛刻因此时间同步变得尤为重要并且实现一个精确地系统时间变得更加重要。时间同步的实现方法常见的有硬件和软件的方法硬件同步是通过各仿真节点都连入专用的时钟信号线来完成的它的精度相对来说比较高但成本也高操作相对比较复杂软件同步方法是完全利用软件来完成分布式系统中各时钟的同步。对于软件同步的方法目前常用的时间协议有NTP协议、 SNTP协议以及PTP协议等。对于这些时间同步协议的一般实现方法是通过计算机网络等方式通讯实现的但是由于计算机网络的一些潜在的威胁如偶然或恶意的原因遭到破环、更改、泄露是网络系统不能连续可靠性的正常运行从而导致时间同步系统不能正常的运转。由于资源和时间有限本次基于C/S的时间同步服务器的实现先采用软件的方法来实现。

1.2软件使用

基于C/S的时间同步服务器的实现运用Visual Studio2010来实现。VisualStudio 2010是微软公司推出的开发环境是目前最流行的Windows平台应用程序开发环境。Visual Studio 2010的C++编译器现在支持lambda表达式、右值引用 rvaluereferences 、编译时断言compi le- timeassertions 、表达式类型发现expressiontypediscovery和C++0X标准的自动类型deduction。VisualStudio 2010的C++编译器有一种模式可以向后兼容Visual Studio 2008的工具和类库。这会给开发者的个人升级提供很大的方便即使团队中有其他人还不想切换到Visual Studio 2010。在Visual Studio的任何版本中都可以创建和使用文本模板无需任何其他组件。在引入了预处理文本模板的Visual Studio 2010中从应用程序生成任何类型的文本文件已变得更加容易。还通过与生成系统的更好集成改进了对代码集成的支持从而使生成的源代码始终会在对源模型进行任何更改后保持更新。Visual Studio 2010是一个功能强大的可视化软件开发工具。Visual Studio 2010对网络编程有socket支持WinInet支持MAPI和

1

计算机网络论文《基于C/S的时间同步服务器的实现》

ISAPI支持等。其中Windows Sockets API是TCP/IP网络环境里也是Internet上进行开发最为通用的API。在TCP/IP网络通信环境下Socket数据传输是一种特殊的I/O它也相当于一种文件描述符具有一个类似于打开文件的函数调用Socket()。 Socket是面向客户/服务器模型而设计的针对客户和服务器程序提供不同的Socket系统调用。客户随机申请一个Socket相当于一个想打电话的人可以在任何一台入网电话上拨号呼叫 系统为之分配一个Socket号服务器拥有全局公认的Socket 任何客户都可以向它发出连接请求和信息请求相当于一个被呼叫的电话拥有一个呼叫方知道的电话号码。Socket利用客户/服务器模式巧妙地解决了进程之间建立通信连接的问题。服务器Socket半相关为全局所公认非常重要。读者不妨考虑一下两个完全随机的用户进程之间如何建立通信假如通信双方没有任何一方的Socket固定就好比打电话的双方彼此不知道对方的电话号码要通话是不可能的。

1.3预期目标

本次设计以Visual Studio 2010为开发平台基于C/S的时间同步服务器的实现。时间服务器是在局域网中作为发布统一时间的服务器它利用电脑网络把时间信息传递给用户。参照现有的时间服务器的原理以及效果实现一个时间服务器的服务端和客户端。服务器端开放指定的端口发布时间到网络中其他客户端从网络中获取该时间并将本地时间与之同步。给出相关的原理、设计思想和设计过程画出时间同步服务器端与客户端的算法流程图实现服务器端和客户端并给出使用说明测试服务器端与客户端写出测试结果。

二方案论证

Cl ient/Server结构的关系数据库系统因为具有高性能、 高效率、开放、易扩充、可伸缩等优越的特性,所以得到了广泛的应用。 在Cl ient/Server结构的关系数据库应用系统中,不乏这样的应用:要求用户在客户端中插入、修改数据时,要在数据库的相应表中记录这些数据插入、修改的时间以供统计分析使用。为了保证今后按时间进行的统计分析的准确性,各个客户端向数据库服务器DBMS提供的必须是统一的时间。硬件同步是通过各仿真节点都连入专用的时钟信号线来完成的它的精度相对来说比较高但成本也高操作相对比较复杂软件同步方法是完全利用软件来完成分布式系统中各时钟的同步。软件同步相对于硬件同步来说简单、快捷、方便、易用适合我们学生党来做计算机网络的相关研究效果比较好所以此次试验采用Visual Studio 2010为平台基于C/S的时间同步服务器的实现。

2

计算机网络论文《基于C/S的时间同步服务器的实现》

三过程论述

3.1相关原理

根据连接启动的方式以及本地套接字要连接的目标套接字之间的连接过程可以分为三个步骤服务器监听客户端请求连接确认。

 1 服务器监听是服务器端套接字并不定位具体的客户端套接字而是处于等待连接的状态实时监控网络状态。

2客户端请求是指由客户端的套接字提出连接请求要连接的目标是服务器端的套接字。为此客户端的套接字必须首先描述它要连接的服务器的套接字指出服务器端套接字的地址和端口号然后就向服务器端套接字提出连接请求。

3连接确认是指当服务器端套接字监听到或者说接收到客户端套接字的连接请求它就响应客户端套接字的请求建立一个新的线程把服务器端套接字的描述发给客户端一旦客户端确认了此描述连接就建立好了。而服务器端套接字继续处于监听状态继续接收其他客户端套接字的连接请求。

NTP的基本工作原理如下图所示。Device A和Device B通过网络相连它们都有自己独立的系统时钟需要通过NTP实现各自系统时钟的自动同步。为便于理解作如下假设

 在Device A和Device B的系统时钟同步之前Device A的时钟设定为

10:00:00amDevice B的时钟设定为1 1 :00:00am。

 Device B作为NTP时间服务器即Device A将使自己的时钟与Device B

的时钟同步。

 NTP报文在Device A和Device B之间单向传输所需要的时间为1秒。

3

计算机网络论文《基于C/S的时间同步服务器的实现》

图1 NTP协议工作原理图

 Device A发送一个NTP报文给Device B该报文带有它离开Device A时的时间戳该时间戳为10:00:00amT1 。

 当此NTP报文到达Device B时Device B加上自己的时间戳该时间戳为

1 1 :00:01amT2。

 当此NTP报文离开Device B时Device B再加上自己的时间戳该时间戳为1 1 :00:02amT3。

 当Device A接收到该响应报文时Device A的本地时间为 10:00:03amT4。

至此Device A已经拥有足够的信息来计算两个重要的参数

 NTP报文的往返时延Delay=T4-T1  - T3-T2=2秒。

 Device A相对Device B的时间差offset= T2-T1 +T3-T4 /2=1小时。

3.2设计过程

在局域网中有很多应用软件为了协同工作需要保证客户机上时间统一方法是客户机从一个时间相对正确的服务器读取时间以此来校正本地时间。按照C/S模型建立一个时间同步服务器此系统分为服务器端Server 和客户端Cl ient  分别对服务器端和客户端进行算法设计和软件编程使其各自都能进

4

计算机网络论文《基于C/S的时间同步服务器的实现》

行编译能够同时运行使其服务器端Server 按照时间协议的要求进行正常运转向客户端Cl ient 发送时间同步请求此时客户端Cl ient 正在等待服务器端Server 发来时间同步请求待客户端Cl ient 收到请求之后按照相应的设计的算法进行时间同步。这就达到了时间同步的目的。

3.3算法流程图

5

819云互联 香港 日本 美国 2核4G 18元 8核8G 39元 免费空间 免费CDN 香港 E3 16G 20M 230元/月

819云互联是海外领先的互联网业务平台服务提供商。专注为用户提供低价高性能云计算产品,致力于云计算应用的易用性开发,并引导云计算在国内普及。目前平台研发以及运营云服务基础设施服务平台(IaaS),面向全球客户提供基于云计算的IT解决方案与客户服务,拥有丰富的海外资源、香港,日本,美国等各国优质的IDC资源。官方网站:https://www.819yun.com香港特价物理服务器:地区CPU内存带宽...

618云上Go:腾讯云秒杀云服务器95元/年起,1C2G5M三年仅288元起

进入6月,各大网络平台都开启了618促销,腾讯云目前也正在开展618云上Go活动,上海/北京/广州/成都/香港/新加坡/硅谷等多个地区云服务器及轻量服务器秒杀,最低年付95元起,参与活动的产品还包括短信包、CDN流量包、MySQL数据库、云存储(标准存储)、直播/点播流量包等等,本轮秒杀活动每天5场,一直持续到7月中旬,感兴趣的朋友可以关注本页。活动页面:https://cloud.tencent...

CloudCone月付$48,MC机房可小时付费

CloudCone商家在前面的文章中也有多次介绍,他们家的VPS主机还是蛮有特点的,和我们熟悉的DO、Linode、VuLTR商家很相似可以采用小时时间计费,如果我们不满意且不需要可以删除机器,这样就不扣费,如果希望用的时候再开通。唯独比较吐槽的就是他们家的产品太过于单一,一来是只有云服务器,而且是机房就唯一的MC机房。CloudCone 这次四周年促销活动期间,商家有新增独立服务器业务。同样的C...

cs服务器为你推荐
手机内存卡数据恢复手机内存卡丢失数据如何恢复?国内免备案服务器国内的服务器是都要备案是吗?有没有不需要备案的?qq空间首页QQ空间的主页闪迪和金士顿哪个好固态硬盘哪个好,是金士顿好还是闪迪的宝来和朗逸哪个好大众朗逸好还是宝来好二手车网站哪个好二手车网站哪家好?哪个信息更可靠?手机音乐播放器哪个好手机音乐播放器音质好的APP是那款dnf魔枪士转职哪个好dnf魔枪士转职哪个好几个职业p图软件哪个好有什么P图工具比较好用考生个人空间登录如何找回 自考考生个人空间的密码?
56折 php探针 40g硬盘 e蜗 阿里云浏览器 100m空间 hostloc 美国免费空间 网通服务器 太原联通测速 深圳域名 免费网络空间 googlevoice winserver2008 server2008 cloudflare 域名商城 web服务器搭建软件 护卫神主机管理系统 web服务器下载 更多