首页
学习
活动
专区
圈层
工具
发布

在 Laravel 中当 MySQL 异常宕机时强制返回空数据

起因 之前线上遇到一个问题, 就是当MySQL挂了, 然后导致整个服务崩塌, Redis在前面完全没分担任何压力....业务常规的查询逻辑如下: 从redis中获取数据, 有则返回 当第一步redis无数据, 去MySQL查询数据 把第二步查询到的数据写入redis 返回数据 问题分析 redis当然不会有问题, 问题是在第二步的时候...去MySQL查询数据,数据库服务已经宕机, 这时候请求阻塞住 阻塞超时,然后抛出异常,导致无法走到第三步 下一次请求来, 又继续去连接MySQL,无限阻塞,把业务服务器也拖垮 解决方案 这是我们的解决方案...当MySQL宕机强制缓存空数据到redis,允许部分页面为空.而不是无法提供服务 解决思路 设置好合理的MySQL连接超时时间 mysqlnd.net_read_timeout = 3 当数据库连接超时之后...])) { // 记录日志, 通知xxx // Log::error($e); // 强制返回空集合

93410

Apollo 源码解析 —— Config Service 通知配置变化

在 notifications/v2 中,当请求的 Namespace 暂无新通知时,会将该 Namespace 对应的 Watch Key 们,注册到 deferredResults 中。...也就说,当有几个 配置发生变化的 Namespace ,返回几个对应的 ApolloConfigNotification 。另外,客户端接收到返回后,会增量合并到本地的配置通知信息。...12: // 例如,数据库中 Namespace 名为 Fx.Apollo ,而客户端 Namespace 名为 fx.Apollo 13: // 通过归一化后...例如,数据库中 Namespace 名为 "Fx.Apollo" ,而客户端 Namespace 名为 "fx.Apollo" 。通过归一化后,统一为 "Fx.Apollo" 。...因为客户端在填写 Namespace 时,写错了名字的大小写。在 Config Service 中,会进行归一化“修复”,方便逻辑的统一编写。

3.5K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Apollo 源码解析 —— Config Service 配置读取接口

    在 《Apollo 官方文档 —— 其它语言客户端接入指南 —— 1.3 通过不带缓存的Http接口从Apollo读取配置》 中,有该接口的接口定义说明。...messagesAsString 请求参数,客户端当前请求的 Namespace 的通知消息明细,在【第 23 行】中,调用 #transformMessages(messagesAsString)...在 《Apollo 源码解析 —— Config Service 通知配置变化》 中,我们已经看到通知变更接口返回的就包括 ApolloNotificationMessages 对象。...当有多个 Release 时,使用 "+" 作为字符串的分隔。 第 64 至 69 行:对比 Client 的合并 Release Key 。若相等,说明配置没有改变,返回状态码为 302 的响应。...详细解析,在 《Apollo 源码解析 —— Portal 灰度发布》 中。

    2.7K20

    apollo客户端通知原理

    ,手动通知C端,然后失效缓存,也就是半自动化刷新 自动失效缓存不展开分析,半自动化刷新实现也很简单,基于Apollo的客户端通知机制就可以实现,在配置中心发布变更主体,然后在应用层监听变更内容并做出响应操作即可...的 github 文档中有介绍: 1.客户端和服务端保持了一个长连接,从而能第一时间获得配置更新的推送 2.客户端还会定时从Apollo配置中心拉取应用的最新配置 这是一个fallback...3.客户端从Apollo配置中心获取应用的最新配置后,会保存在内存中 4.客户端会把从服务端获取到的配置在本地缓存一份 遇到服务不可用,或网络不通时,依然能从本地恢复配置 5应用程序可以从...Apollo客户端获取最新的配置、订阅配置更新通知 长连接是更新配置的主要手段,定时刷新是辅助手段,避免长轮训失败造成数据更新丢失。...基于前一小结,如果用户发布了属性变更,RemoteConfigRepository的定时刷新或长轮询逻辑会从Apollo Server拉取最新数据到本地,然后和本地缓存(上一个版本数据)做对比,如果发现不一样则触发配置变更

    3.6K60

    开源配置管理中心apollo使用方法

    通过带缓存的Http接口从Apollo读取配置 该接口会从缓存中获取配置,适合频率较高的配置拉取请求,如简单的每30秒轮询一次配置。...Http接口从Apollo读取配置 该接口会直接从数据库中获取配置,可以配合配置推送通知实现实时更新配置。...配置访问密钥 Apollo从1.6.0版本开始增加访问密钥机制,从而只有经过身份验证的客户端才能访问敏感配置。如果应用开启了访问密钥,客户端发出请求时需要增加签名,否则无法获取配置。...另外,配置值从内存中获取,所以不需要应用自己做缓存。...等优先级高于数据库中的配置 调整ApolloPortalDB配置 配置项统一存储在ApolloPortalDB.ServerConfig表中,也可以通过管理员工具 - 系统参数页面进行配置,无特殊说明则修改完一分钟实时生效

    3.4K10

    (很全面)SpringBoot 集成 Apollo 配置中心

    四、启动项目进行测试 . 1、测试是否能够获取 Apollo 中设置的值 . 2、测试当 Apollo 中修改参数值后客户端是否能及时刷新 . 3、测试当 Apollo 执行配置回滚操作时客户端是否能及时改变.... 4、测试当不能访问 Apollo 时客户端的变化 . 5、测试当 Apollo 中将参数删除后客户端的变化 ....客户端从 Apollo 配置中心服务端获取到应用的最新配置后,会保存在内存中。 客户端会把从服务端获取到的配置在本地文件系统缓存一份 在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置。...4、测试当不能访问 Apollo 时客户端的变化 这里我们将 JVM 参数中 Apollo 配置中心地址故意改错: -Dapollo.configService=http://192.168.2.100...考虑到由于 Apollo 会在本地将配置缓存一份,出现上面原因,估计是缓存生效。当客户端不能连接到 Apollo 配置中心时候,默认使用本地缓存文件中的配置。

    19.8K53

    Apollo在基础架构中的实践经验

    profile profile 是一个逻辑的分组,当 bean 向容器中注册的时候,仅当配置激活时生效。...3.2 客户端 ? 客户端和服务端保持了一个长连接,从而能第一时间获得配置更新的推送。 客户端还会定时从 Apollo 配置中心服务端拉取应用的最新配置。...客户端从Apollo配置中心服务端获取到应用的最新配置后,会保存在内存中 客户端会把从服务端获取到的配置在本地文件系统缓存一份 在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置 应用程序从Apollo...客户端获取最新的配置、订阅配置更新通知 长连接实现上是使用的异步+轮询实现 4 Apollo 高可用部署 在 Apollo 架构说明中我们提到过 client 和 portal 都是在客户端负载均衡,根据...,Portal无影响 客户端重启时,可以读取本地缓存配置文件 某台admin service下线 无影响 Admin service无状态,Portal重连其它admin service 所有admin

    1.9K10

    我们放弃了Nacos作为配置中心,转而选择了这款神器~

    1.6、本地缓存 Apollo客户端会把从服务端获取到的配置在本地文件系统缓存一份,用于在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置,不影响应用正常运行。...客户端从 Apollo 配置中心服务端获取到应用的最新配置后,会保存在内存中。 客户端会把从服务端获取到的配置在本地文件系统缓存一份 在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置。...4.2、测试当 Apollo 中修改参数值后客户端是否能及时刷新 修改 Apollo 配置中心参数 test 值为 666666 ,然后再次发布。...4.4、测试当不能访问 Apollo 时客户端的变化 这里我们将 JVM 参数中 Apollo 配置中心地址故意改错: -Dapollo.configService=http://192.168.2.100...考虑到由于 Apollo 会在本地将配置缓存一份,出现上面原因,估计是缓存生效。当客户端不能连接到 Apollo 配置中心时候,默认使用本地缓存文件中的配置。

    76100

    Apollo在基础架构中的实践经验

    profile profile 是一个逻辑的分组,当 bean 向容器中注册的时候,仅当配置激活时生效。...3.2 客户端 ? 客户端和服务端保持了一个长连接,从而能第一时间获得配置更新的推送。 客户端还会定时从 Apollo 配置中心服务端拉取应用的最新配置。...客户端从Apollo配置中心服务端获取到应用的最新配置后,会保存在内存中 客户端会把从服务端获取到的配置在本地文件系统缓存一份 在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置 应用程序从Apollo...客户端获取最新的配置、订阅配置更新通知 长连接实现上是使用的异步+轮询实现 4 Apollo 高可用部署 在 Apollo 架构说明中我们提到过 client 和 portal 都是在客户端负载均衡,根据...,Portal无影响 客户端重启时,可以读取本地缓存配置文件 某台admin service下线 无影响 Admin service无状态,Portal重连其它admin service 所有admin

    1.6K10

    我们放弃了Nacos作为配置中心,转而选择了这款神器~

    1.6、本地缓存 Apollo客户端会把从服务端获取到的配置在本地文件系统缓存一份,用于在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置,不影响应用正常运行。...客户端从 Apollo 配置中心服务端获取到应用的最新配置后,会保存在内存中。 客户端会把从服务端获取到的配置在本地文件系统缓存一份 在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置。...4.2、测试当 Apollo 中修改参数值后客户端是否能及时刷新 修改 Apollo 配置中心参数 test 值为 666666 ,然后再次发布。...4.4、测试当不能访问 Apollo 时客户端的变化 这里我们将 JVM 参数中 Apollo 配置中心地址故意改错: -Dapollo.configService=http://192.168.2.100...考虑到由于 Apollo 会在本地将配置缓存一份,出现上面原因,估计是缓存生效。当客户端不能连接到 Apollo 配置中心时候,默认使用本地缓存文件中的配置。

    1.4K10

    怎样使用 apollo-link-state 管理本地数据

    在 Apollo Client 1.0 时期,这是一个可行的方案。但当 Apollo Client 进入 2.0 版本,不再依赖于 Redux,如何去同步本地和远端的数据,变得比原来更加棘手。...在查询应用状态时,GraphQL query 也能以一种声明式的方式描述出组件所需要的数据。...Apollo Link 使得在 Apollo Client 中管理本地的数据成为可能,从一个 GraphQL 服务器中获取数据,可以使用 HttpLink,而从 Apollo 的缓存中请求数据,则需要使用一个新的...Defaults 前文的 defaults 字段是一个用于表示状态初始值的 object,当 state link 刚创建时,这个默认值会被写入 Apollo Client 的缓存。...Resolvers 在使用 Apollo Client 管理应用状态后,Apollo cache 成为了应用的单一数据源,包括了本地和远端的数据。那么我们应当如何查询和更新缓存中的数据呢?

    3K100

    Apollo,真香!

    6、本地缓存 Apollo客户端会把从服务端获取到的配置在本地文件系统缓存一份,用于在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置,不影响应用正常运行。...客户端从 Apollo 配置中心服务端获取到应用的最新配置后,会保存在内存中。 客户端会把从服务端获取到的配置在本地文件系统缓存一份 在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置。...2、测试当 Apollo 中修改参数值后客户端是否能及时刷新 修改 Apollo 配置中心参数 test 值为 666666 ,然后再次发布。...4、测试当不能访问 Apollo 时客户端的变化 这里我们将 JVM 参数中 Apollo 配置中心地址故意改错: -Dapollo.configService=http://192.168.2.100...考虑到由于 Apollo 会在本地将配置缓存一份,出现上面原因,估计是缓存生效。当客户端不能连接到 Apollo 配置中心时候,默认使用本地缓存文件中的配置。

    85610

    告别Eureka!Nacos也落伍了!这款配置中心才是新宠!

    (2)、environment 在实际开发中,我们的应用经常要部署在不同的环境中,一般情况下分为开发、测试、生产等等不同环境,不同环境中的配置也是不同的,在 Apollo 中默认提供了四种环境: FAT...1.6、本地缓存 Apollo客户端会把从服务端获取到的配置在本地文件系统缓存一份,用于在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置,不影响应用正常运行。...客户端从 Apollo 配置中心服务端获取到应用的最新配置后,会保存在内存中。 客户端会把从服务端获取到的配置在本地文件系统缓存一份 在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置。...应用程序从 Apollo 客户端获取最新的配置、订阅配置更新通知。 配置更新推送实现 前面提到了 Apollo 客户端和服务端保持了一个长连接,从而能第一时间获得配置更新的推送。...,Portal无影响 客户端重启时,可以读取本地缓存配置文件 某台 admin service 下线 无影响 Admin service无状态,Portal重连其它 admin service

    54510

    React 设计模式 0x6:数据获取

    它是同构的(即可以在浏览器和 nodejs 中使用相同的代码库)。在服务器端,它使用本地的 node.js http 模块,而在客户端(浏览器)中,它使用 XMLHttpRequests。...GraphQL 提供了 API 中数据的完整且易于理解的描述,使客户端能够精确地请求所需的数据,避免了不必要的数据传输,使得 API 能够随着时间的推移更容易地发展,并提供了强大的开发者工具。...然而,当组件重新渲染时,这些数据并不总是需要重新计算或重新获取。有几种方法可以在 React 中实现数据缓存。...React 应用程序中缓存数据并使用它的方法。...从 API 缓存的数据可以存储在我们的状态管理中,然后在我们的应用程序中全局使用。尽管数据被缓存,但在刷新页面时,它将丢失数据,需要重新获取。

    2.1K20

    一图理解Apollo配置中心,配置变更如何及时通知客户端的

    ---- Apollo 2.2.0-SNAPSHOT 配置变更及时通知客户端流程: 1、Apollo客户端启动时,会启动异步线程,循环发起一个Http Long Polling请求到Config...如果在60秒内没有该客户端关心的配置发布,那么会返回Http状态码304给客户端。...变更通知时会根据key从缓存中获取DeferredResult,设置值,让挂起的请求返回给客户端,达到通知客户端的功能。...#sendMessage) 4、Config Service后台异步线程默认每秒扫描更新通知消息表,如果有配置发布动作,会从步骤2中的DeferredResult缓存获取对应的DeferredResult...客户端从返回的结果中获取到配置变化的namespace后,会立即请求Config Service获取该namespace的最新配置。

    2.1K30

    【译】Graphql, gRPC和端对端类型检验

    GraphQL 当听到我们需要在这个项目中“整合许多不同的数据源”时,我立即意识到使用GraphQL作为API网关会是一个不错的选择。...只需要在我们的schema中增加查询(queries)和变更(mutations)字段,就可以在应用中使用(consuming)这些数据了。...使用apollo-client和react-apollo简化了前端代码对缓存和数据的管理。 灵活的查询方式方便我们在未来构建移动端以及内部应用。...我们所有的解析器(resolvers)都是遵循以下模式:从后端服务请求一些数据,可能会做轻量的数据转化工作,使得返回的数据复合我们的schema。在这些解析器中几乎木有业务逻辑。...然而,不像.jsx/.js之间那样宽松,当文件中包含任何JSX代码时,你必须使用.tsx扩展名,这样TypeScript才能消除JSX和其他TypeScript语言特性之间的歧义。

    3.6K20

    Apollo配置中心使用篇

    客户端从返回的结果中获取到配置变化的namespace后,会立即请求Config Service获取该namespace的最新配置。...客户端从Apollo配置中心服务端获取到应用的最新配置后,会保存在内存中 客户端会把从服务端获取到的配置在本地文件系统缓存一份 在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置 应用程序可以从...服务配置中心新建项目时候,配置的appid一致 apollo.meta作用是:当apollo客户端从apollo-env.properties配置的configservice无法取得连接时,会找apollo.meta...pro.meta=http://apollo.xxx.com 默认本地缓存路径 Apollo客户端会把从服务端获取到的配置在本地文件系统缓存一份,用于在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置...自定义缓存路径 Apollo 1.0.0版本开始支持以下方式自定义缓存路径,按照优先级从高到底分别为: 通过Java System Property apollo.cacheDir 在Java程序启动脚本中

    11.6K61

    Apollo配置中心搭建+配置+测试全攻略!0到1详解!

    在登录后创建项目时,选择部门默认只能选择 Apollo 自带的 测试部门1与测试部门2两个选项。...2、测试当 Apollo 中修改参数值后客户端是否能及时刷新 修改 Apollo 配置中心参数 test 值为 666666 ,然后再次发布。...3、测试当 Apollo 执行配置回滚操作时客户端是否能及时改变 回滚完成后状态将变为未发布状态,则时候输入地址 http://localhost:8080/test 查看: test的值为:123456...4、测试当不能访问 Apollo 时客户端的变化 这里我们将 JVM 参数中 Apollo 配置中心地址故意改错: -Dapollo.configService=http://192.168.2.100...考虑到由于 Apollo 会在本地将配置缓存一份,出现上面原因,估计是缓存生效。当客户端不能连接到 Apollo 配置中心时候,默认使用本地缓存文件中的配置。

    3.3K21
    领券