前端 微服务demo

什么是微前端

微前端是一种多个团队通过独立发布功能的方式来共同构建现代化 web 应用的技术手段及方法策略。

微前端架构具备以下几个核心价值:

  • 技术栈无关
    主框架不限制接入应用的技术栈,微应用具备完全自主权

  • 独立开发、独立部署
    微应用仓库独立,前后端可独立开发,部署完成后主框架自动完成同步更新

  • 增量升级

    在面对各种复杂场景时,我们通常很难对一个已经存在的系统做全量的技术栈升级或重构,而微前端是一种非常好的实施渐进式重构的手段和策略

  • 独立运行时
    每个微应用之间状态隔离,运行时状态不共享

微前端架构旨在解决单体应用在一个相对长的时间跨度下,由于参与的人员、团队的增多、变迁,从一个普通应用演变成一个巨石应用(Frontend Monolith)后,随之而来的应用不可维护的问题。这类问题在企业级 Web 应用中尤其常见。

 

 

 

single-SPA  与qiankun 实现库 对比

特点:功能比较弱   样式隔离没有解决  没有js执行隔离   仅仅 single-SPA实现了路由劫持和应用加载。

qiankun乾坤基于SPA  解决了沙箱,文件导入 ,提供了开箱即用的API 和技术栈无关、并且接入简单  像iframe一样简单 

 

single-SPA 使用样式隔离问题解决:

1.子应用之间与子应用之间的样式隔离

2.BEM (block Element Modifier)约定的项目前缀

3.css-Modules 打包时生成不冲突的选择器名

4.shadow DOM 真正意义上的隔离

 

使用方式:

接入协议: 子应用必须有相关的协议 导出固定的方法,父应用去调用这些方法加载子应用,  (子应用需要提供bootstrap 、mount、unmount方法) 

这样可以做到和主应用完全解耦,和技术栈无关。而且是运行时 动态加载子应用。

 

single-SPA 安装方式 npm  install  single-spa-vue 或者yarn  add  single-spa-vue 

qiankun  安装方式 npm  install  qiankun  或 yarn add qiankun

 

iframe 存在的问题,为何不用iframe?

 1. 使用iframe ,iframe中的子应用切换路由时刷新数据页面就尴尬了 (状态会丢失)

 

应用通讯: 

1.基于URL进行数据传递,但是传递消息能力弱

2.基于CustomEvent 实现通信   即:window 原生api

3.基于props主子应用间通信

4.使用全部变量、redux进行通信

 

 

总结:

single-SPA 核心 路由劫持和应用加载

qiankun 是在single-SPA基础二次封装 用起来更简单、 便捷。子应用可以独立构建,运行时动态加载主自应用完全解耦,技术栈无关 靠的是协议接入 子应用必须导出bootstrap mount unmount方法

 

写了两个demo,分别Single和qiankun

Single-SPA demo:https://github.com/jingjing9061/microFont

qiankun demo :https://github.com/jingjing9061/microFont2

 

Single-spa学习地址:https://zh-hans.single-spa.js.org/docs/getting-started-overview

qiankun 学习地址 :https://zh-hans.single-spa.js.org/docs/getting-started-overview/

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 以下是一个使用 Swoole 实现的简单的微服务 demo: 服务端代码: ```php <?php // 创建 Server 对象 $server = new Swoole\Http\Server("0.0.0.0", 9501); // 处理请求 $server->on('Request', function ($request, $response) { // 获取请求的 URL $url = $request->server['request_uri']; // 根据 URL 路由到对应的处理函数 switch ($url) { case '/hello': $response->end('Hello World!'); break; case '/time': $response->end('Current time: ' . date('Y-m-d H:i:s')); break; default: $response->end('Invalid URL'); break; } }); // 启动服务器 $server->start(); ``` 客户端代码: ```php <?php // 创建 HTTP 客户端对象 $client = new Swoole\Http\Client('127.0.0.1', 9501); // 发送请求 $client->get('/hello', function ($client) { echo $client->body; }); $client->get('/time', function ($client) { echo $client->body; }); // 关闭连接 $client->close(); ``` 这个 demo 实现了一个简单的 HTTP 微服务,当客户端请求 `/hello` 时,返回 `Hello World!`,请求 `/time` 时,返回当前时间。客户端通过 Swoole 提供的 HTTP 客户端发送请求,并等待响应返回。需要注意的是,在 Swoole 中,客户端和服务端都是异步非阻塞的,这意味着客户端发送请求后不会阻塞等待响应,而是立即执行后续代码,直到收到响应后再执行回调函数。 ### 回答2: Swoole是一款基于PHP语言的高性能网络通信引擎,同时也是一个强大的异步、并发服务器框架。微服务是一种架构风格,将一个大型的应用程序拆分成多个小而独立的服务,每个服务在自己的进程中运行,通过网络互相通信。在Swoole中实现一个微服务demo可以具体分为以下几个步骤: 1. 环境准备:首先确保已经安装好PHP以及Swoole扩展,并且启用了Swoole扩展。 2. 定义服务:根据需求,确定需要实现的服务,并编写相应的代码。可以针对不同的服务定义不同的类或函数。 3. 实现服务:在编写服务代码时,可以使用Swoole提供的异步IO特性来提高性能。比如,可以使用协程来处理请求,避免阻塞。 4. 通信与协议:考虑服务之间的通信方式和协议。Swoole提供了多种协议支持,例如TCP、UDP、HTTP等。可以根据实际需求选择合适的协议。 5. 部署与运行:将不同的服务部署在不同的进程中,并通过网络通信连接起来。可以使用Swoole提供的进程管理器或者自定义脚本来管理服务的启动、停止等操作。 6. 测试与调试:对已经实现的微服务demo进行测试和调试,确保服务之间的通信正常,功能达到预期。 总结来说,Swoole微服务demo的实现主要包括环境准备、定义服务、实现服务、通信与协议、部署与运行、测试与调试等步骤。通过Swoole的高性能和强大的异步IO特性,我们可以在PHP领域中实现高效、可扩展的微服务架构。 ### 回答3: Swoole微服务demo是一种基于Swoole扩展开发的微服务示例。Swoole是PHP的一款高性能网络通信框架,可以用于构建高并发、高性能的服务器和网络应用。而微服务是一种软件架构风格,将一个应用拆分为一系列小而独立的服务,每个服务都运行在自己的进程或容器中,通过网络通信进行协作。 Swoole微服务demo的目的是展示如何使用Swoole来构建一个简单的微服务体系。这个示例可以包含多个微服务,每个微服务都具有独立的功能且可以独立部署和运行。 在这个demo中,我们可以使用Swoole来创建一个HTTP服务器,监听特定的端口,并处理来自客户端的HTTP请求。每个微服务可以使用Swoole的协程来处理请求,提高服务器的并发处理能力。 示例中的每个微服务可以实现不同的功能,例如用户管理、订单处理、数据分析等。每个微服务可以将其功能暴露为API接口供其他微服务或客户端调用。微服务之间可以通过HTTP或其他适当的通信协议进行通信,实现服务间的协作和数据交换。 为了更好地管理和监控微服务,我们还可以引入和集成其他开源工具和框架,如Consul、ETCD、Prometheus等,以实现微服务的服务发现、负载均衡、监控和日志分析等功能。 总之,Swoole微服务demo通过使用Swoole框架和微服务架构风格,可以帮助我们更好地理解和实践高性能网络应用和微服务架构的开发,提升系统的并发处理能力和可扩展性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值