当前位置: 首页 > news >正文

[apollo]vue3.x中apollo的使用

[apollo]vue3.x中apollo的使用

  • 通过客户端获取Apollo配置
    • 环境
    • 工具的安装
    • 获取Apollo配置
      • 相关代码
      • 错误提示
        • Uncaught (in promise) Error: Apollo client with id default not found. Use provideApolloClient() if you are outside of a component setup
  • 通过开放接口获取Apollo配置
    • 通过不带缓存的Http接口从Apollo读取配置
      • 参数说明
      • 浏览器方式
      • 请求交互方式

目前为止,前端获取动态数据,都是前端与服务端进行交互获取数据,但是如果只是获取简单的一些配置属性,并没有其它的接口需要服务端提供,此时在搭建一个服务器就是资源的浪费了,希望可以直接从 apollo的配置服务器中获取,无需额外的服务端接口

通过前端自身直接获取到apollo的配置目前看到官方支持的客户端是没有vue的,所以以下是前端获取到apollo数据的过程

通过客户端获取Apollo配置

环境

"vue": "^3.2.41",
"@vue/cli-service": "~5.0.8",

工具的安装

"@vue/apollo-composable": "^4.0.0-beta.2",
"@vue/apollo-option": "^4.0.0-beta.2",
"graphql": "^16.6.0",
"graphql-tag": "^2.12.6",

获取Apollo配置

相关代码

main.ts 配置建立链接

const httpLink = createHttpLink({// You should use an absolute URL hereuri: apiApollo,// credentials: 'include'
})
// Cache implementation
const cache = new InMemoryCache()// Create the apollo client
const apolloClient = new ApolloClient({link: httpLink,cache,
})
const apolloProvider = createApolloProvider({defaultClient: apolloClient,
})const app = createApp(App, {setup() {provide(DefaultApolloClient, apolloClient)}});

获取数据

import { useQuery } from "@vue/apollo-composable";
import gql from "graphql-tag";
export default defineComponent({name:"page-info",setup(){const { result, error, onResult, onError } = useQuery(gql`query getPartners {partners {label,value}}`)onResult(queryResult => {console.log("queryResultqueryResult", queryResult.data)console.log(queryResult.loading)console.log(queryResult.networkStatus)})onError(error => {console.log("queryResultqueryResult error", error.graphQLErrors)console.log(error.networkError)})}
})

错误提示

Use the @apollo/client/core import path otherwise you will also import React.

一定注意引入的位置是import { ApolloClient, createHttpLink, InMemoryCache } from "@apollo/client/core";而不是@apollo/client,否则就会报引入react错误

Uncaught (in promise) Error: Apollo client with id default not found. Use provideApolloClient() if you are outside of a component setup

该方式尝试多种方式都是提示该错误,并且vue3.x 该方式暂时还没有比较完整的文档说明,所以该方式等以后更成熟之后在考虑

通过开放接口获取Apollo配置

根据目前的环境使用客户端的方式获取Apollo配置失败,发现目前官方推荐的还有一种方式便是通过接口获取

通过不带缓存的Http接口从Apollo读取配置

接口URL格式: {config_server_url}/configs/{appId}/{clusterName}/{namespaceName}?releaseKey={releaseKey}&ip={clientIp}

Method方式: GET

参数说明

参数名是否必须参数值备注
config_server_urlApollo配置服务的地址,非UI界面的地址
appId应用的appId
clusterName集群名 一般情况下传入 default 即可。如果希望配置按集群划分,可以参考集群独立配置说明做相关配置,然后在这里填入对应的集群名。
namespaceNameNamespace的名字,如果没有新建过Namespace的话,传入application即可。如果创建了Namespace,并且需要使用该Namespace的配置,则传入对应的Namespace名字。需要注意的是对于properties类型的namespace,只需要传入namespace的名字即可,如application。对于其它类型的namespace,需要传入namespace的名字加上后缀名,如datasources.json
releaseKey上一次的releaseKey将上一次返回对象中的releaseKey传入即可,用来给服务端比较版本,如果版本比下来没有变化,则服务端直接返回304以节省流量和运算
ip应用部署的机器ip这个参数是可选的,用来实现灰度发布。

config_server_url:不是配置的UI界面的DNS,是服务器的DNS,并且两者没有关联,所以如果直接拿界面的DNS获取是获取不到数据的

浏览器方式

https://apollo-config.uat.XXXX/configs/项目ID/项目空间/application

返回数据:

{"appId": "xxxx","cluster": "default","namespaceName": "application","configurations": {//application 所有配置的值"title": "Apollo set value"},"releaseKey": "2023021"
}

请求交互方式

axios({method:'get',url:'/configs/{appId}/{clusterName}/{namespaceName}'
}).then((res:any)=>{console.log(res)
})

交互访问也会返回相同的数据

http://www.lryc.cn/news/16617.html

相关文章:

  • system()函数启用新进程占有原进程的文件描述符表的问题
  • nignx(安装,正反代理,安装tomcat设置反向代理,ip透传)
  • sklearn模块常用内容解析笔记
  • 我的 System Verilog 学习记录(2)
  • 【调研报告】Monorepo 和 Multirepo 的风格对比及使用示例
  • Retrofit源码分析
  • Mybatis-Plus入门系列(20) -兼容多种数据库
  • JetPack板块—Android X解析
  • C++学习笔记-数字
  • Nginx——Nginx的基础原理
  • 服务端开发Java之备战秋招面试篇1
  • 【C++的OpenCV】第三课-OpenCV图像加载和显示
  • 【面试1v1实景模拟】Spring事务 一文到底
  • Neuron Selectivity Transfer 原理与代码解析
  • vue项目关闭子页面,并更新父页面的数据
  • 第五次作业:修改redis的配置文件使得windows的图形界面客户端可以连接redis服务器
  • 【11】FreeRTOS的延时函数
  • Vue页面组成及常用属性
  • j6-IO流泛型集合多线程注解反射Socket
  • 创业能否成功?这几个因素很重要!
  • Bmp图片格式介绍
  • Day4 leetcode
  • Java设计模式-原型模式
  • 2023年度最新且最详细Ubuntu的安装教程
  • unix高级编程-fork之后父子进程共享文件
  • vue+echarts:柱状图横向展示和竖向展示
  • SealOS 一键安装 K8S
  • python网络编程详解
  • ICRA 2023 | 首个联合暗光增强和深度估计的自监督方法STEPS
  • 基于react+nodejs+mysql开发用户中心,用于项管理加入的项目的用户认证