Roh*_*yas 5 vue.js graphql apollo-server apollo-client prisma
我正在使用带有Prisma和vuejs + apollo客户端的GraphQL订阅
在本地系统中,我在http:// localhost:8080运行vuejs,在http:// localhost:4000运行服务器。
我想在仪表板上显示最近添加和更新的记录。
我已经在本地系统中实现了订阅,并且可以正常工作。
我将所有服务器端和客户端代码推送到服务器,但订阅在那儿无法正常工作。
我正在使用AWS服务器。除订阅外,其他所有内容均正常运行。我设置了websockets,它也可以正常工作。
有时我遇到以下错误:WebSocket与“ wss:// URL:4000 / graphql”的连接失败:WebSocket在建立连接之前已关闭
我在下面遵循文档 https://www.apollographql.com/docs/react/data/subscriptions/
我尝试了不同的方法,但没有成功。连接稳定/断开连接后重新连接。
在服务器端,我添加了用于Web套接字的侦听器,并且该侦听器正在连接。
这是我的vue-apollo.js文件的代码
import Vue from 'vue';
import VueApollo from 'vue-apollo';
import { ApolloClient } from 'apollo-client';
import { HttpLink } from 'apollo-link-http';
import { InMemoryCache } from 'apollo-cache-inmemory';
// imports for subscription
import { split } from 'apollo-link';
import { WebSocketLink } from 'apollo-link-ws';
import { getMainDefinition } from 'apollo-utilities';
const uriHttp = process.env.VUE_APP_SERVER_URL;
const uriWs = process.env.VUE_APP_WS_SERVER_URL;
const headers = { authorization: localStorage.getItem('token') };
const httpLink = new HttpLink({ uri: uriHttp, headers });
const wsLink = new WebSocketLink({
uri: uriWs,
options: {
reconnect: true,
connectionParams() {
return { headers };
},
},
});
wsLink.subscriptionClient.on('connecting', () => {
console.log('connecting');
});
wsLink.subscriptionClient.on('connected', () => {
console.log('connected');
});
wsLink.subscriptionClient.on('reconnecting', () => {
console.log('reconnecting');
});
wsLink.subscriptionClient.on('reconnected', () => {
console.log('reconnected');
});
wsLink.subscriptionClient.on('disconnected', () => {
console.log('disconnected');
});
wsLink.subscriptionClient.maxConnectTimeGenerator.duration = () => wsLink.subscriptionClient.maxConnectTimeGenerator.max;
const link = split(({ query }) => {
const { kind, operation } = getMainDefinition(query);
return kind === 'OperationDefinition' && operation === 'subscription';
}, wsLink, httpLink);
export const defaultClient = new ApolloClient({
link,
cache: new InMemoryCache(),
connectToDevTools: true,
});
const apolloProvider = new VueApollo({
defaultClient,
defaultOptions: {
$loadingKey: 'loading',
},
});
Vue.use(VueApollo);
export default apolloProvider;
Run Code Online (Sandbox Code Playgroud)
最后,我得到了这个问题。实际上,我使用的Classical load balancer是不支持WebSocket请求的。
我配置了应用程序负载均衡器并将其附加到我的服务器实例。现在工作正常。
我的代码是正确的。
| 归档时间: |
|
| 查看次数: |
78 次 |
| 最近记录: |