热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

打造一个属于本身的server

什么是server在最先打造本身的效劳器之前,我们起首明白一下效劳器的定义:一个治理资本并为用户供应效劳的计算机软件。根据功用效劳器分为两类staticwebserver,比方罕见

什么是server

在最先打造本身的效劳器之前,我们起首明白一下效劳器的定义:一个治理资本并为用户供应效劳的计算机软件。

根据功用效劳器分为两类

  • static web server,比方罕见的nginx apache等等
  • dynamic web server,比方罕见的tomcat,jboss,resin等等

动静态效劳器区分

关于静态效劳器来讲平常就是读取资本然后返回给browser;动态效劳器意味着返回给browser的文件是经由逻辑处置惩罚动态发生的。

效劳用具有的功用特征
  • nginx,tomcat这个两个之前用过,也研讨过,所以拿这两个举一下示例,不过如今很少用了,如今基本上都是运用node相干的,所以末了构建的serve会基于node。

nginx

nginx特性

  • 设置简朴,天真(只要一个主设置文件nginx.conf)
  • 支撑高并发(静态小文件)
  • 占用资本相对较少(2w并发,开启10个线程,内存斲丧只要几百M)
  • 功用品种多(比方proxy,cache,Log,Gzip等等)

nginx运用场景

静态效劳器(图片,js,css等等)

server {
listen 8080;
server_name localhost;
location / {
root html;
index index.html index.htm;
}
}

申明 上面是nginx设置,指定接见根目次和默认主页,以及监听端口

➜ ~ clear
➜ ~ curl -i http://127.0.0.1:8080
HTTP/1.1 200 OK
Server: nginx/1.12.2 //效劳器范例和版本
Date: Fri, 02 Mar 2018 08:49:44 GMT
Content-Type: text/html
Content-Length: 11
Last-Modified: Fri, 02 Mar 2018 08:46:27 GMT //支撑Last-Modified缓存机制
Connection: keep-alive //支撑耐久衔接
ETag: "5a990f63-b" //支撑ETag缓存机制
Accept-Ranges: bytes // 支撑断点续传
hello jsdt% //相应体

申明 上面是当地测试要求,从相应头中能够看到支撑许多功用

反向代办,负载平衡

《打造一个属于本身的server》
申明 上面是实验结果

upstream jsdt.com {
server 127.0.0.1:8083 max_fails=3 fail_timeout=30s weight=1;
server 47.97.xxx.xxx:8084 max_fails=3 fail_timeout=30s weight=2; //为了平安 隐蔽实在ip地点
}
server {
listen 8080;
server_name localhost;
location / {
root html;
# index index.html index.htm;
proxy_pass http://jsdt.com;
proxy_redirect default;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}}

申明 上面我摘取了症结的部份设置,采用了轮训+weight算法,别的另有ip_hash、url_hash等算法。实在的运用状况,还须要斟酌许多题目,比方集群的session同步,记得大学练习时期,当时公司用的是COOKIE+memcache集群的计划。

tomcat

tomcat特性

tomcat运转在jvm上,跨平台,是一个Servlet容器(能够运转Servlet,编译jsp),完成了在http要求相应处置惩罚中所须要的http接口相干完成类。除此之外也支撑虚拟主机,session同享,静态文件处置惩罚等等,只不过没那末专业罢了。

tomcat运用场景

《打造一个属于本身的server》
申明 如上所示,我们能够在页面中增加动态的处置惩罚逻辑,返回的数据根据用户可定制化(比拟静态效劳器长处),终究.jsp被tomcat编译为.java,然后被javac编译为通用字节码文件,终究运转在jvm上。

怎样完成一个本身的效劳器

在完成本身的效劳器之前,起首我们明白一下server的实质,server属于运用层的协定,基于tcp的封装, 而tcp的运用完成是基于socket(无论是node,照样java都有socket)的封装。

socket监听某个端口,猎取面向流的数据data,我们的server所要做的就是对data举行剖析封装,以使其相符http的范例。

接下来完成本身的静态server

由于有http模块,所以node当中完成一个基本server很简朴。然则假如附加分外的功用,比方紧缩,缓存,断点续传,反向代办什么的就须要本身增加了。
接下来起首看一下项目构造,bin目次主如果放启动剧本相干的,主逻辑在app.js中,然后根据功用将代码拆分红差别的模块。templatet目次安排编译的原始模板。

|____bin
| |____.DS_Store
| |____deamon.js
| |____start
| |____yargsConfig.js
|____node_modules
|____package-lock.json
|____package.json
|____readme.md
|____src
| |____.DS_Store
| |____app.js
| |____asset
| |____cacheSupport.js
| |____config.js
| |____picGuard.js
| |____template
| |____util.js

在server运转前,起首我们经由历程yargs模块猎取剖析好的命令行参数。以下所示

if(argv.D){
let sp = cp.spawn(process.execPath, ['deamon.js'],{
cwd: __dirname,
stdio: ['ignore','ignore','ignore'],
env: argv,
detached: true //http://nodejs.cn/api/child_process.html#child_process_child_process_spawn_command_args_options
} )
sp.unref()
} else {
let cOnfig= Object.assign({}, defautConfig, argv)
let server = new Server(config);
server.start();
console.log('server already started')
}

申明 假如开启deamon形式,则经由历程子历程的体式格局让效劳在背景运转,反之则直接启动server实例

在启动server以后,最先接收并处置惩罚要求,下面以断点续传功用模块作为示例

function byteRangeStream(req, res, filepath, statObj) {
let start = 0
let end = statObj.size-1
let range = req.headers['range']
if (range){
res.setHeader('Accept-Range','bytes')
res.statusCode = 206 //a part of content
let result = range.match(/bytes=(\d*)-(\d*)/);
if (result) {
start = isNaN(result[1]) ? start : parseInt(result[1]);
end = isNaN(result[2]) ? end : parseInt(result[2]) - 1;
}
}
return fs.createReadStream(filepath,{
start,
end
})
}
module.exports ={
byteRangeStream
}

申明 在主模块app.js中,导入上述模块,如代码中所示起首推断客户端是不是支撑断点续传,根据range要求头,假如有要求局限,直接返回要求局限内的数据,不然悉数读取返回,靠的是browser和server的协商机制,须要两边都支撑才完成全部历程。
更多功用模块能够参考我的github, 迎接star。

总结

写这篇文章,总结了下server的相干学问,参考了之前大学时做的笔记,看到之前做的纪录,回想当时在学校进修和公司练习的阅历,感慨万千。时间易逝,做好当下的本身。


推荐阅读
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • 本文介绍了OkHttp3的基本使用和特性,包括支持HTTP/2、连接池、GZIP压缩、缓存等功能。同时还提到了OkHttp3的适用平台和源码阅读计划。文章还介绍了OkHttp3的请求/响应API的设计和使用方式,包括阻塞式的同步请求和带回调的异步请求。 ... [详细]
  • Servlet多用户登录时HttpSession会话信息覆盖问题的解决方案
    本文讨论了在Servlet多用户登录时可能出现的HttpSession会话信息覆盖问题,并提供了解决方案。通过分析JSESSIONID的作用机制和编码方式,我们可以得出每个HttpSession对象都是通过客户端发送的唯一JSESSIONID来识别的,因此无需担心会话信息被覆盖的问题。需要注意的是,本文讨论的是多个客户端级别上的多用户登录,而非同一个浏览器级别上的多用户登录。 ... [详细]
  • Tomcat安装与配置教程及常见问题解决方法
    本文介绍了Tomcat的安装与配置教程,包括jdk版本的选择、域名解析、war文件的部署和访问、常见问题的解决方法等。其中涉及到的问题包括403问题、数据库连接问题、1130错误、2003错误、Java Runtime版本不兼容问题以及502错误等。最后还提到了项目的前后端连接代码的配置。通过本文的指导,读者可以顺利完成Tomcat的安装与配置,并解决常见的问题。 ... [详细]
  • mui框架offcanvas侧滑超出部分隐藏无法滚动如何解决
    web前端|js教程off-canvas,部分,超出web前端-js教程mui框架中off-canvas侧滑的一个缺点就是无法出现滚动条,因为它主要用途是设置类似于qq界面的那种格 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
author-avatar
超级放开祢旳掱
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有