-
Notifications
You must be signed in to change notification settings - Fork 189
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Single AppSync Api - Multi CloudFormation Stacks - Concurrency issue #595
Comments
Hi, What I'm not sure is why the service stacks update the schema? |
Each stack is updating the same GraphQL schema, essentially making each stack a complete 'app' that uses the plugin once. This occurs a total of 15 times - once to create the API and the others to use the API ID to add resolvers. |
Hey @bboure, thanks for replying quickly. We have the first service, in charge of deploying the API and the schema. export const appSyncMain = {
name: `api`,
authenticationType: 'API_KEY',
schema: '../appsync/dist/*.graphql',
apiKeys: [
{
name: 'api-key',
description: 'basic api key',
expiresAfter: '30d',
},
],
mappingTemplatesLocation: '.',
defaultMappingTemplates: {
request: false,
response: false,
},
mappingTemplates: [],
dataSources: [],
functionConfigurations: [],
}; Then we have all the other services, in charge of plugging resolvers and mapping templates to that API and schema. export const appSyncService = ({
apiId, dataSources, mappingTemplates, functionConfigurations,
}: AppSyncService) => ({
apiId,
schema: '../appsync/dist/*.graphql', // <---- HERE we have to pass the path of the schema again.
mappingTemplatesLocation: '.',
defaultMappingTemplates: {
request: false,
response: false,
},
mappingTemplates,
dataSources,
functionConfigurations,
}); The plugin requires specifying the path of the graphql schema. But that API / Schema has been deployed previously by the main service. We end up with multiple updates on the schema. The AWS Core team told us this was provoking our issues with resolvers that got detached from the API. We would like to know, how we can achieve to just do a reference to the APPSync API and Schema instead of modifying the resource. Since we provide the |
Okay seems that the v2 doesn't support So I believe the plugin doesn't support our use case of AppSync right @bboure? |
Should we fork and add our support ourselves or do you want us to do a PR to add this functionality? |
Hi there, I am looking forward to this because our team just reached the limit of resources per stack and so we have to split our mono service into multiple one keeping a single AppSync API. Is there any progress on this? Workaround? or even post-install patches? |
The workaround we are doing today is to do a depends_on in serverless-compose so we don't have concurrent updates (not ideal this the deployment time is very long now since we cannot do concurrent deployment on our microservices). |
@Hideman85, I think it's a common topic on this repository, so you might find better solutions for your need in previous issues |
Hey @jeremycare I have the same use case as you. I've opened a PR and hope it will be merged soon. For now, Im using my fork on dev, but so far, everything works fine. I also considered your point about schema and agree that it should be managed from one place. |
@bboure Any thoughts on that? |
This is a common debate/topic 🙂 I purposefully removed support for passing an Right now, the only valid use case I maybe see is when reaching the stack limit. In general, 500 should be plenty enough, but I understand that in some cases, it might be reached. The workaround/preferred way of solving that issue for now is using https://www.npmjs.com/package/serverless-plugin-split-stacks Eventually, I think what most of you are looking for is API federation/API merging. I'm open to discussing this further and would be happy to try and provide solutions for all, but at the same time I'd like avoid introducing pitfalls. |
Yes indeed this looks to be a big topic and when you are not aware and just face the issue it can be really frustrating. So some feedback about our experience through this issue. The first point about the limit 500, each lambda produces min 4 resources:
If you consider a pattern like CRUD that is like 16 resources per Type. In addition you tend to also link your types together with sub-resolver, provide feeds for realtime (most of the time to bypass the AppSync limitation you tend to do a none datasource called internally) you can really quickly reach the 500. Like us we have a relatively small project and boom 526, from one day to another, your deployment is stuck. Split stacks plugin, I got a look at it and it feels to be more like a workaround than a permanent solution. Even the author would consider more optimal to handle it manually than using the plugin. Now come, nested stacks vs standalone/root stacks. Actually, there is also a limitation that has been open here, hard limit of 2.5k resources updated in per CF update. Okey the limit start to be big enough to have already something. What about the performance? When you update with nested stack you have to update everything and it takes ages. We made the choice of multi services and 1 AppSync because it greatly follows the split of concerns/responsibility and we are able to quickly deploy only the part that has changed and by the members/team that own it. I fairly not see a way to correctly split a GQL schema in 2+ APIs (how would you sub-resolve something if not in this API? + pretty annoying to swap endpoints, I just dont see it possible) The last point about ApiGateway (havent used serverless for that we did manually in past) but in terms of CF this is the same, you have an ApiId that need to be linked to methods/resources and then you can create routes the same way AppSync does. In addition, in the past, not using serverless you can still cross stack import Outputs to another stack that how we dealt with it. If we want to go forward, standalone stack mean you can fine tune deployment permission using service role that you cant in nested since it use the root one. . You are also speaking about miss use of apiId? Do you think we can detect the valid usage and throw an error for the other usages? Maybe the question is does apiId can be use if you are not using service composition? Lets detect a compose file and warn/error the user about it? Last thing, this is pretty hidden piece of doc, but we discovered that serverless support TS config file. So since we needed to migrate from v1 to v2 and explode everything we just refactor in TS, made some helper functions to declare and split the resources and now it works just fine with serverless-compose. |
Thanks for all the feedback. I will take it into consideration and start thinking/planning about what is the best way to handle this. |
After some research, I found this in the sls doc. I will go through this to see how we can "port" this to AppSync |
It's important that the schema is not updatable when the APPSync API is referenced and not created by the plugin. We had to talk to AppSync service team to troubleshoot our issues, and if there are multiple schema updates at the same time, cloud formation doesn't handle it correctly and some resolvers might disappear. (It caused us a lot of time to troubleshoot and find the issue for that kind of error, CF was not showing errors correctly :) ) |
Any update on that? @bboure |
@Hideman85 We are facing exactly the same issue with both the 500 resources stack limit and the offline mode for team work. Did you find any way to make it work ? |
@plezan , we forked this plugin (on a private repo) to enable us to do the reference ourselves. It was not as bad as expected to add new params to do so. We are also moving away from appsync in our project to API Gateway (We don't benefit enough from graphql feature to make the complexity worth it). |
Since the original PR seams to be dead, I forked/updated it. It still needs a bit more testing but here is a draft PR: #647 |
Hi, thank you for this plugin!
My team and I are facing a bug when updating the GraphQL schema with multiple stacks while using the plugin. Since we have a huge project, we decided to split it into multiple entities and use the Serverless Compose Framework. Each entity has a dedicated stack with more or fewer resources, which allows us to deploy them individually. Additionally, we have a stack dedicated to AppSync to instantiate the API. The overall structure looks something like this :
Using the Serverless Compose Framework, we first deploy the AppSync service to provide API information to all other services (Entity X, Entity Y). Then, we deploy all other services simultaneously still using the serverless-appsync-plugin(v1), which is configured to use the API ID. The goal of these services is to add resolvers, data sources, and pipelines to the AppSync API that was deployed in the AppSync service.
However, after deploying all these services (15 for now), we noticed that the GraphQL schema is being updated too frequently, causing some resolvers to become unattached from a mutation/query. When we contacted AWS support, they suggested that too much concurrent updating of the GraphQL schema could be the cause of our problem.
IMHO, the ideal solution would be to have an option to prevent updating the GraphQL schema. This would allow the plugin to only modify external configurations such as resolvers, data sources, and pipelines. It's possible that I have overlooked this solution, and it may have other implications for other features of AppSync. What are your thoughts on this?
(Edit): The goal is to configure the AppSync service to deploy only the schema, while other services do not update it.
The text was updated successfully, but these errors were encountered: