Service worker 的概念和用法

查看源图像

Service workers 本质上充当 Web 应用程序、浏览器与网络(可用时)之间的代理服务器。这个 API 旨在创建有效的离线体验,它会拦截网络请求并根据网络是否可用采取来适当的动作、更新来自服务器的的资源。它还提供入口以推送通知和访问后台同步 API。

Service worker 的概念和用法

Service worker 是一个注册在指定源和路径下的事件驱动 worker。它采用 JavaScript 控制关联的页面或者网站,拦截并修改访问和资源请求,细粒度地缓存资源。你可以完全控制应用在特定情形(最常见的情形是网络不可用)下的表现。

Service worker 运行在worker上下文,因此它不能访问 DOM。相对于驱动应用的主 JavaScript 线程,它运行在其他线程中,所以不会造成阻塞。它设计为完全异步,同步API(如 XHRlocalStorage)不能在 service worker 中使用。

出于安全考量,Service workers 只能由 HTTPS 承载,毕竟修改网络请求的能力暴露给中间人攻击会非常危险。在 Firefox 浏览器的用户隐私模式,Service Worke不可用。

**注意:**Service workers可以更细致地控制每一件事情,支持当操作出错时终止操作

**注意:**Service workers大量使用 Promise,因为通常它们会等待响应后继续,并根据响应返回一个成功或者失败的操作。Promise 非常适合这种场景。

注册

使用 ServiceWorkerContainer.register() 方法首次注册 service worker。如果注册成功,service worker 就会被下载到客户端并尝试安装或激活(见下文),这将作用于整个域内用户可访问的 URL,或者其特定子集。

下载、安装和激活

此时,你

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Docker分布式集群管理是指使用Docker技术来管理和部署分布式集群的一种方法。在传统的集群管理中,需要手动配置和管理每个节点,而使用Docker可以简化这个过程。 Docker是一种轻量级的容器化技术,它可以将应用程序及其依赖项打包成一个独立的容器,使其能够在不同的计算机上运行。在分布式集群中,可以使用Docker来创建和管理多个容器,每个容器运行一个或多个应用程序实例。 Docker分布式集群管理的核心概念包括以下几个方面: 1. Docker Swarm:Docker Swarm是Docker官方提供的用于管理Docker集群的工具。它允许用户将多个Docker主机组成一个逻辑集群,并使用简单的命令来管理集群中的容器。Swarm使用Raft一致性算法来保持集群的一致性,并提供负载均衡和容器调度等功能。 2. 服务(Service):服务是Docker Swarm中的一个概念,它表示一个可以在集群中部署和扩展的应用程序。用户可以通过定义服务的规模、镜像和其他配置参数来创建一个服务。Swarm会自动将服务的实例分配到集群中的不同节点上,并提供负载均衡和故障恢复等功能。 3. 节点(Node):节点是Docker Swarm中的一个概念,它表示集群中的一个物理或虚拟机器,可以运行Docker容器。节点可以是Swarm集群的管理节点(manager node)或工作节点(worker node)。管理节点负责管理集群的状态和配置信息,而工作节点负责运行和管理容器。 4. 服务发现和负载均衡:Docker Swarm提供了内置的服务发现和负载均衡功能。它使用内部DNS来解析服务名称,并将请求路由到正确的容器实例。这样,用户可以通过服务名称来访问应用程序,而不需要关心容器运行在哪个节点上。 5. 容器编排:Docker Swarm可以根据用户定义的规则和策略来自动部署、扩展和管理容器。用户可以使用简单的命令或配置文件来描述容器的要求和依赖关系,Swarm会根据这些信息自动调度和管理容器。 总之,Docker分布式集群管理通过使用Docker Swarm等工具,可以简化分布式集群的部署和管理过程,提供高可用性、负载均衡和容器编排等功能,使应用程序更易于开发和运维。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

编程三昧

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值