微服务qiankun通信方式

qiankun:

是一种类似于微服务的架构,是将一个大型应用拆分成若干个更小、更简单,可以独立开发、测试和部署的子应用,然后由一个基座应用根据路由进行应用切换,主要是为了解决大型工程在变更、维护、扩展等方面的困难而提出的!

qiankun的五种通信方式

1、localStorage/sessionStorage

2、通过路由参数共享

3、官方提供的 props

4、官方提供的 actions

5、使用vuex或redux管理状态通过shared分享

1、localStorage/sessionStorage

不用区分域名,在 qiankun 中应用使用不同的域名也是可以获取得到,主要运行在主应用上所以还是运行在同一个域名上也就是主应用的域名。

父应用

objectivec 复制代码
localStorage.setItem('token', '我是保存在本地的数据')

子应用 获取数据

复制代码
const token = localStorage.getItem('token')

2、通过路由参数共享

url 上拼接一些参数,父子应用都可以通过 route 来获取到

const router = new VueRouter({ ... })

router.beforeEach((to, from, next) => {

// 路由参数获取

})

3、官方提供的 props

父应用把父路由的实例传递给子应用 props 接收

4、官方提供的 actions

返回action 实例并挂载了三个函数

1、onGlobalStateChange:在当前应用监听全局状态有变更触发

2、setGlobalState: 可以在应用中任何地方调用来修改全局状态

3、offGlobalStateChange:移除当前应用的状态监听微应用 umount 时会默认调用

具体示例:

objectivec 复制代码
actions.ts文件

import { initGlobalState, MicroAppStateActions } from 'qiankun';

const state = {
  cont:''
};

// 初始化 state
const actions: MicroAppStateActions = initGlobalState(state);

actions.onGlobalStateChange((state, prev) => {
  // state: 变更后的状态; prev 变更前的状态
});

// 定义一个获取state的方法下发到子应用
actions.getGlobalState = function () {
  return state
}

export default actions;

父应用

复制代码
import actions from './actions'
const apps = [
  {
    props: {
      parentActions: actions
    }
  }
];

子应用

objectivec 复制代码
// 在子应用中使用就可以访问到这个parentActions了
this.$root.parentActions.setGlobalState({ cont: '我是父应用传下来的数据' })

// 调用挂载在 actions 上的自定义方法获取当前的全局 state
this.$root.parentActions.getGlobalState()

5、shared 方案

父应用通过 vuex 或者 redux 维护一个 state然后创建一个 shared ,和 actions 类似

objectivec 复制代码
主应用 

// shared.ts

import store from "./store";

class Shared {
  /**
   * 获取 Token
   */
  public getToken(){
    return store.getState() || "";
  }

  /**
   * 设置 Token
   */
  public setToken(token){
    store.dispatch({
      type: "SET_TOKEN",
      payload: token
    });
  }
}

const shared = new Shared();

export default shared;

子应用

objectivec 复制代码
import shared from './shared';

// 获取Token
shared.getToken(); 
相关推荐
程序员侠客行1 分钟前
Mybatis二级缓存实现详解
java·数据库·后端·架构·mybatis
AutoMQ10 分钟前
🎉 庆祝 AutoMQ 在 GitHub 上突破 9k Stars!
架构
Xの哲學1 小时前
Linux CFS 调度器深度解析
linux·服务器·算法·架构·边缘计算
深圳行云创新1 小时前
行云创新 AI+CloudOS:AI + 云原生落地新范式
人工智能·云原生·系统架构
阳光普照世界和平2 小时前
2025年智能体架构与主流技术深度研究报告:从生成式AI迈向自主执行层
人工智能·架构
乾元2 小时前
Service Mesh 与网络抽象:AI 如何做服务层次网络策略生成(微服务 / 云原生)
网络·人工智能·安全·微服务·云原生·运维开发·service_mesh
码头工人3 小时前
【架构师系列】风控场景下超高并发频次计算服务的设计与实践
java·架构·风控·反爬
村口曹大爷4 小时前
【深度】OpenAI 推理架构演进:GPT-5.2(Internal版)性能实测与开发者接入路径分析
gpt·ai·chatgpt·架构·gpt5.2
踏浪无痕4 小时前
从 node-exporter 学如何写出可复用的监控指标
运维·后端·架构
Bypass--5 小时前
防护篇 | 云原生安全攻防实战
安全·云原生·容器·kubernetes