服务器是干什么的,服务器价位及使用方法

服务器是干什么的,服务器价位及使用方法,第1张

服务器干什么的,服务器价位及使用方法 在前端面试过程中,有一个知识点特别容易被提及,即服务器问题。


01web服务器web服务器一般是指网站服务器,它是驻留在互联网上的一种计算机程序,主要作用是向浏览器等web客户端提供文档信息。


同时,也可以将浏览器的文档信息进行持久化保存。


目前来看,市面上主流的web服务器包括以下几种:1、Apache服务器图为Apache服务器logo2、Tomcat服务器图为Tomcat服务器logo3、Node.js服务器图为Node.js服务器的logo上面就是目前几种比较主流的服务器,当然Node.js作为后起之秀,是最符合前端工程师使用的一款服务器。


同样,这也是大家面试时,经常被问到的一点。


02服务器工作原理图为服务器工作原理上面这幅图,就是一张web服务器的工作原理图。


也许有同学很惊讶,这个图和之前说过的HTTP请求图差不多呀!其实,在软件开发与使用过程中,web服务器就等同于HTTP服务器。


虽然不同web服务器之间有细节上的不同,但是基础原理是一样的。


下面,我们就根据上面这幅图来一一分析:Step1:用户在地址栏输入一个网址,然后点击回车键;Step2:浏览器与服务器建立TCP连接;Step3:浏览器将用户的事件按照HTTP协议要求的格式打包成数据包,这个过程的本质就是在待发送缓冲区中有这一段HTTP协议格式的字节流;Step4:浏览器确认服务器可写,将该数据包推入Internet中,最终,该包被递交到服务端;Step5:服务器在接收到该数据包后,以同样的格式进行解析,获取客户端的意图;Step6:在获取了客户端的意图之后,服务器进行分类处理,或是提供某一文件,或是处理相关数据;Step7:将处理结果装入缓冲区,或者文档,或是其他内容;Step8:服务器将按照HTTP协议格式,将Step7中的数据进行打包;Step9:服务器确定对端可写,将数据包推入Internet,该包经过网络处理,最终返回至客户端;Step10:客户端拿到包之后,以HTTP协议格式进行解包,然后解析数据;Step11:客户端处理相关数据,并且展示在页面之上。


以上这11步,就是web服务器最基本的工作原理。


通过梳理,我们不难发现,这就是一个简单的网络通信过程。


换句话说,就是一个简单的发送数据、接收数据、处理数据的过程。


更高级的web服务器,无非也就是将上述的三个基础内容划分得更加详细一点而已。


03静态文件工作原理对于web服务器来说,它除了提供一些数据功能之外,另一个主要功能就是提供静态文件了。


图为web服务器实现静态文件服务上图就是一个以GET请求方式为模板的流程图,通过对图的观察,我们不难发现,整个静态文件处理过程与之前的动态数据处理基本保持一致,变化之处就在于红色&蓝色标注的位置。


Step1:当用户点击一个网页链接或者需要加载一些静态资源时(比如css文件、JPEG图片等)产生;Step2:服务程序解包之后,优先判断其请求方式,确定是GET请求,并且是对该服务器上某一特定资源的请求;Step3:服务器需要先确定路径是否存在,如果路径真实存在,再确定文件是否可以获取;Step4:确定了该路径合法、可获取之后,服务程序将根据该文件类型的不同,进行不同的装载过程,记录其类型作为Step8(上文有描述)中HTTP协议中对应的返回类型,并且加入响应头。


图为一个简易静态资源传输过程04web服务器数据提交原理如果只是网页浏览的功能,是无法真正实现网站功能的。


要想更好实现网站功能,那么客户端与服务端之间,进行数据交互必不可少。


什么叫做数据交互呢?比如我们注册/登录、资源上传、远程指令等等,都可以叫做客户端与服务器的数据交互。


图为客户端与服务器数据交互示意通过观察上图,我们可以发现,用户提交数据时,往往是通过单击一个功能按钮来实现。


那么单击这个功能按钮之后,又做了什么呢?首先,程序会将用户需要提交的数据以POST格式要求进行写入,并填入服务端需要提交到服务端的可执行程序路径;其次,服务端将参数与CGI进行绑定,复制进程,用管道传递参数、接收结果;最后,子进程执行CGI,接收父进程传来的参数,运算并返回结果,父进程将结果装入静态模板文件,放入缓冲区。


05动态技术通过上述内容的基本描述,我们可以得出一个结论,就是web服务器都是以短连接为主的,并且,获取到的数据在到达客户端的时候,一定是静态不变的。


这好像与我们所说的动态数据又有一些出入,这是因为所谓的动态实际上指的是这两种情况——情况一:用户POST提交数据到某个程序,程序根据该数据作为运行参数,得出的结果装入静态的模板页中,返回该静态页。


但是从用户的角度来看,同样一个页面,完成了一个 *** 作后页面数据不一样,就会认为这是动态页面。


情况二:用户GET请求一个JavaScript文件,服务端不做任何处理,直接返回该文件,由负责解析该文件的浏览器负责执行,在本地刷新页面。


用户POST请求提交数据到服务端,服务端根据提交的数据返回静态文件,浏览器接收执行。


以上就是Web服务器的工作原理,希望对大家在面试或工作中有所帮助。


如果同学们看完以后还有疑惑尚未理清,也可添加下方微信一起探讨哦~

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/596977.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-13
下一篇 2022-04-13

发表评论

登录后才能评论

评论列表(0条)

保存