<\/p>\n
\uc2a4\ud504\ub9c1 \ubd80\ud2b8\uc640 \uc6f9\uc18c\ucf13\uc744 \uc774\uc6a9\ud558\uc5ec GraphQL \uc11c\ube0c\uc2a4\ud06c\ub9bd\uc158\uc744 \uad6c\ud604\ud558\ub294 \ubc29\ubc95\uc5d0 \ub300\ud574 \uc54c\uc544\ubcf4\uaca0\uc2b5\ub2c8\ub2e4. GraphQL \uc11c\ube0c\uc2a4\ud06c\ub9bd\uc158\uc740 \uc2e4\uc2dc\uac04 \ub370\uc774\ud130\ub97c \ucc98\ub9ac\ud574\uc57c\ud558\ub294 \uc0c1\ud669\uc5d0\uc11c \uc720\uc6a9\ud558\uac8c \uc0ac\uc6a9\ub429\ub2c8\ub2e4. \uc774 \uae30\ub2a5\uc740 GraphQL \uc2a4\ud0a4\ub9c8\uc5d0\uc11c subscription \ud0c0\uc785\uc73c\ub85c \uc815\uc758\ub418\uc5b4 \uc788\uc73c\uba70, \ud074\ub77c\uc774\uc5b8\ud2b8\uac00 \uad6c\ub3c5\uc744 \uc0dd\uc131\ud558\uba74 \uc11c\ubc84\uac00 \ud574\ub2f9 \ub370\uc774\ud130\uc758 \ubcc0\uacbd \uc0ac\ud56d\uc744 \uc2e4\uc2dc\uac04\uc73c\ub85c \uc54c\ub824\uc90d\ub2c8\ub2e4. \uc774\ub97c \ud1b5\ud574 \ud074\ub77c\uc774\uc5b8\ud2b8\ub294 \uc6f9\uc18c\ucf13 \uc5f0\uacb0\uc744 \ud1b5\ud574 \uc11c\ubc84\uc640 \uc2e4\uc2dc\uac04\uc73c\ub85c \ub370\uc774\ud130\ub97c \uc8fc\uace0\ubc1b\uc744 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\n
\uc774\ubc88 \uae00\uc5d0\uc11c\ub294 GraphQL \uc11c\ube0c\uc2a4\ud06c\ub9bd\uc158\uc758 \uac1c\ub150\uacfc \uc0ac\uc6a9, \uc2a4\ud504\ub9c1 \ubd80\ud2b8\uc640 \uc6f9\uc18c\ucf13\uc744 \ud1b5\ud55c \uad6c\ud604 \ubc29\ubc95, \uc8fc\uc758\ud560 \uc810\uacfc \ubb38\uc81c \ud574\uacb0 \ubc29\ubc95\uc5d0 \ub300\ud574 \uc54c\uc544\ubcf4\uaca0\uc2b5\ub2c8\ub2e4.<\/p>\n
GraphQL \uc11c\ube0c\uc2a4\ud06c\ub9bd\uc158\uc740 GraphQL \uc2a4\ud0a4\ub9c8\uc5d0\uc11c subscription \ud0c0\uc785\uc73c\ub85c \uc815\uc758\ub429\ub2c8\ub2e4. \uc774 \ud0c0\uc785\uc740 \uc77c\ubc18\uc801\uc778 Query\uc640 Mutation\uacfc \uac19\uc740 \uad6c\uc870\ub97c \uac00\uc9c0\uace0 \uc788\uc9c0\ub9cc, \ud074\ub77c\uc774\uc5b8\ud2b8\ub294 \ud574\ub2f9 subscription \ud0c0\uc785\uc744 \uad6c\ub3c5\ud558\uace0 \uc788\uc73c\uba74, \uc11c\ubc84\uc5d0\uc11c \ud574\ub2f9 \ud0c0\uc785\uc5d0 \ub300\ud55c \ubcc0\uacbd \uc0ac\ud56d\uc774 \ubc1c\uc0dd\ud558\uba74 \uc774\ub97c \uc2e4\uc2dc\uac04\uc73c\ub85c \uc804\ub2ec\ubc1b\uc744 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\n
\uc608\ub97c \ub4e4\uc5b4, \uc2e4\uc2dc\uac04 \ucc44\ud305 \uc560\ud50c\ub9ac\ucf00\uc774\uc158\uc744 \uad6c\ud604\ud55c\ub2e4\uace0 \uac00\uc815\ud574\ubcf4\uaca0\uc2b5\ub2c8\ub2e4. \uc774 \uc560\ud50c\ub9ac\ucf00\uc774\uc158\uc5d0\uc11c\ub294 \uc0ac\uc6a9\uc790\uac00 \uba54\uc2dc\uc9c0\ub97c \uc785\ub825\ud558\uba74 \ub2e4\ub978 \uc0ac\uc6a9\uc790\ub4e4\uc5d0\uac8c \uc774\ub97c \uc2e4\uc2dc\uac04\uc73c\ub85c \uc804\ub2ec\ud574\uc57c\ud569\ub2c8\ub2e4. \uc774\ub97c \uc704\ud574 GraphQL subscription\uc744 \uc0ac\uc6a9\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc0ac\uc6a9\uc790\uac00 \uba54\uc2dc\uc9c0\ub97c \uc785\ub825\ud558\uba74 \uc11c\ubc84\uc5d0\uc11c \ud574\ub2f9 \uba54\uc2dc\uc9c0\ub97c \ubc1b\uc544\ub4e4\uc774\uace0, \ud574\ub2f9 \uba54\uc2dc\uc9c0\ub97c \uad6c\ub3c5\ud558\uace0 \uc788\ub294 \ubaa8\ub4e0 \ud074\ub77c\uc774\uc5b8\ud2b8\ub4e4\uc5d0\uac8c \uba54\uc2dc\uc9c0\ub97c \uc804\ub2ec\ud569\ub2c8\ub2e4. \uc774\ub97c \ud1b5\ud574 \ubaa8\ub4e0 \ud074\ub77c\uc774\uc5b8\ud2b8\ub4e4\uc740 \uc11c\ubc84\uc640 \uc2e4\uc2dc\uac04\uc73c\ub85c \ub370\uc774\ud130\ub97c \uc8fc\uace0\ubc1b\uc744 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\n
GraphQL \uc11c\ube0c\uc2a4\ud06c\ub9bd\uc158\uc740 \uc774\uc678\uc5d0\ub3c4 \ub2e4\uc591\ud55c \uc2e4\uc2dc\uac04 \ub370\uc774\ud130 \ucc98\ub9ac\uc5d0 \uc720\uc6a9\ud558\uac8c \uc0ac\uc6a9\ub420 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc608\ub97c \ub4e4\uc5b4, \uc8fc\uc2dd \uc2dc\uc7a5\uc5d0\uc11c \uc8fc\uc2dd \uac00\uaca9\uc774 \ubcc0\uacbd\ub420 \ub54c\ub9c8\ub2e4 \ud074\ub77c\uc774\uc5b8\ud2b8\ub4e4\uc5d0\uac8c \uc774\ub97c \uc2e4\uc2dc\uac04\uc73c\ub85c \uc804\ub2ec\ud558\ub294 \uae30\ub2a5\uc744 \uad6c\ud604\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc774\ub97c \ud1b5\ud574 \ud074\ub77c\uc774\uc5b8\ud2b8\ub4e4\uc740 \uc2dc\uc7a5 \uc0c1\ud669\uc744 \uc2e4\uc2dc\uac04\uc73c\ub85c \ud30c\uc545\ud558\uace0, \uc774\uc5d0 \ub530\ub978 \uc804\ub7b5\uc744 \uc218\ub9bd\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\n
\uc2a4\ud504\ub9c1 \ubd80\ud2b8\uc640 \uc6f9\uc18c\ucf13\uc744 \uc774\uc6a9\ud558\uc5ec GraphQL \uc11c\ube0c\uc2a4\ud06c\ub9bd\uc158\uc744 \uad6c\ud604\ud558\uae30 \uc704\ud574\uc11c\ub294 \uba87 \uac00\uc9c0 \uc900\ube44 \uc791\uc5c5\uc774 \ud544\uc694\ud569\ub2c8\ub2e4. \uba3c\uc800, \uc2a4\ud504\ub9c1 \ubd80\ud2b8 \ud504\ub85c\uc81d\ud2b8\ub97c \uc0dd\uc131\ud558\uace0, GraphQL \uc2a4\ud0a4\ub9c8\ub97c \uc791\uc131\ud574\uc57c\ud569\ub2c8\ub2e4. \uc774\ud6c4\uc5d0\ub294 \uc6f9\uc18c\ucf13\uacfc GraphQL \uc11c\ube0c\uc2a4\ud06c\ub9bd\uc158\uc744 \uad6c\ud604\ud560 \ucf54\ub4dc\ub97c \uc791\uc131\ud558\uba74 \ub429\ub2c8\ub2e4.<\/p>\n
\uba3c\uc800, \uc2a4\ud504\ub9c1 \ubd80\ud2b8 \ud504\ub85c\uc81d\ud2b8\ub97c \uc0dd\uc131\ud569\ub2c8\ub2e4. \uc774\ub97c \uc704\ud574 https:\/\/start.spring.io\/<\/a> \uc5d0 \uc811\uc18d\ud558\uc5ec \ud504\ub85c\uc81d\ud2b8 \uc124\uc815\uc744 \uc9c4\ud589\ud569\ub2c8\ub2e4. \uc5ec\uae30\uc5d0\uc11c\ub294 Gradle \uae30\ubc18\uc758 \ud504\ub85c\uc81d\ud2b8\ub97c \uc0dd\uc131\ud558\ub3c4\ub85d \ud558\uaca0\uc2b5\ub2c8\ub2e4.<\/p>\n
\ud504\ub85c\uc81d\ud2b8\ub97c \uc0dd\uc131\ud55c \ud6c4, \uc758\uc874\uc131\uc744 \ucd94\uac00\ud574\uc57c\ud569\ub2c8\ub2e4. \uc774\ub97c \uc704\ud574 build.gradle \ud30c\uc77c\uc5d0 \ub2e4\uc74c\uacfc \uac19\uc774 \uc758\uc874\uc131\uc744 \ucd94\uac00\ud569\ub2c8\ub2e4.<\/p>\n
implementation 'com.graphql-java-kickstart:graphql-spring-boot-starter:11.2.0'\nimplementation 'com.graphql-java-kickstart:graphql-java-tools:11.0.0'\nimplementation 'com.graphql-java-kickstart:graphql-java-tools-async:11.0.0'\nimplementation 'org.springframework.boot:spring-boot-starter-websocket'<\/code><\/pre>\n\uc704 \uc758\uc874\uc131\uc744 \ucd94\uac00\ud558\uba74 GraphQL \uc2a4\ud0a4\ub9c8 \uc815\uc758\ub97c \uc704\ud55c graphql-java-tools\uc640, GraphQL \uc11c\ubc84\ub97c \uad6c\ud604\ud558\uae30 \uc704\ud55c graphql-spring-boot-starter\uac00 \ucd94\uac00\ub429\ub2c8\ub2e4. \ub610\ud55c, \uc6f9\uc18c\ucf13\uc744 \uc0ac\uc6a9\ud558\uae30 \uc704\ud55c spring-boot-starter-websocket \uc758\uc874\uc131\ub3c4 \ucd94\uac00\ub429\ub2c8\ub2e4.<\/p>\n
GraphQL \uc2a4\ud0a4\ub9c8 \uc791\uc131<\/h2>\n
\uc758\uc874\uc131\uc744 \ucd94\uac00\ud55c \ud6c4, GraphQL \uc2a4\ud0a4\ub9c8\ub97c \uc791\uc131\ud574\uc57c\ud569\ub2c8\ub2e4. GraphQL \uc2a4\ud0a4\ub9c8\ub294 .graphql \ud30c\uc77c \ud615\ud0dc\ub85c \uc791\uc131\ub429\ub2c8\ub2e4. \uc774\ubc88 \uc608\uc2dc\uc5d0\uc11c\ub294 \ub2e4\uc74c\uacfc \uac19\uc740 \uc2a4\ud0a4\ub9c8\ub97c \uc791\uc131\ud558\uaca0\uc2b5\ub2c8\ub2e4.<\/p>\n
type Query {\n hello: String\n}\n\ntype Subscription {\n greeting: String\n}\n\nschema {\n query: Query\n subscription: Subscription\n}<\/code><\/pre>\n\uc704 \uc2a4\ud0a4\ub9c8\uc5d0\uc11c\ub294 Query \ud0c0\uc785\uacfc Subscription \ud0c0\uc785\uc744 \uc815\uc758\ud569\ub2c8\ub2e4. Query \ud0c0\uc785\uc740 hello \ud544\ub4dc\ub97c \uac00\uc9c0\uba70, \ud574\ub2f9 \ud544\ub4dc\ub97c \ud638\ucd9c\ud558\uba74 "world" \ubb38\uc790\uc5f4\uc744 \ubc18\ud658\ud569\ub2c8\ub2e4. Subscription \ud0c0\uc785\uc740 greeting \ud544\ub4dc\ub97c \uac00\uc9c0\uba70, \ud574\ub2f9 \ud544\ub4dc\ub97c \uad6c\ub3c5\ud558\uba74 "Hello, world!" \ubb38\uc790\uc5f4\uc744 1\ucd08\ub9c8\ub2e4 \ubc18\ubcf5\ud574\uc11c \ubc18\ud658\ud569\ub2c8\ub2e4.<\/p>\n
GraphQL \uc11c\ubc84 \uad6c\ud604<\/h2>\n
GraphQL \uc2a4\ud0a4\ub9c8\ub97c \uc791\uc131\ud55c \ud6c4, \uc774\ub97c \uad6c\ud604\ud558\uae30 \uc704\ud55c \ucf54\ub4dc\ub97c \uc791\uc131\ud574\uc57c\ud569\ub2c8\ub2e4. \uc774\ub97c \uc704\ud574 \ub2e4\uc74c\uacfc \uac19\uc774 GraphQLConfig \ud074\ub798\uc2a4\ub97c \uc791\uc131\ud569\ub2c8\ub2e4.<\/p>\n
@Configuration\npublic class GraphQLConfig {\n\n @Autowired\n private GreetingPublisher greetingPublisher;\n\n @Bean\n public GraphQLSchema schema() {\n return new GraphQLSchemaGenerator()\n .withOperationsFromSingleton(greetingResolver(), Greeting.class)\n .withSubscriptionFromPublisher(Greeting.class, greetingPublisher)\n .generate();\n }\n\n @Bean\n public GreetingResolver greetingResolver() {\n return new GreetingResolver();\n }\n\n @Bean\n public GreetingPublisher greetingPublisher() {\n return new GreetingPublisher();\n }\n}<\/code><\/pre>\n\uc704 \ucf54\ub4dc\uc5d0\uc11c\ub294 GraphQL \uc2a4\ud0a4\ub9c8\ub97c \uc0dd\uc131\ud558\ub294 GraphQLSchemaGenerator\ub97c \uc0ac\uc6a9\ud569\ub2c8\ub2e4. \uc774 \ub54c, withOperationsFromSingleton \uba54\uc18c\ub4dc\ub97c \uc0ac\uc6a9\ud558\uc5ec GreetingResolver \ud074\ub798\uc2a4\ub97c singleton\uc73c\ub85c \ub4f1\ub85d\ud558\uace0, withSubscriptionFromPublisher \uba54\uc18c\ub4dc\ub97c \uc0ac\uc6a9\ud558\uc5ec Greeting \ud074\ub798\uc2a4\ub97c \uad6c\ub3c5\ud558\uace0 \uc788\ub294 \uad6c\ub3c5\uc790(GreetingPublisher)\ub97c \ub4f1\ub85d\ud569\ub2c8\ub2e4. \uc774\ub97c \ud1b5\ud574 greeting \ud544\ub4dc\ub97c \uad6c\ub3c5\ud558\uba74 GreetingPublisher\uc5d0\uc11c \ubc18\ud658\ud558\ub294 \uac12\uc744 \uc2e4\uc2dc\uac04\uc73c\ub85c \ubc1b\uc744 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\n
\npublic class GreetingPublisher implements Publisher {\n\n private final List<Subscriber<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"\uc2a4\ud504\ub9c1 \ubd80\ud2b8\uc640 \uc6f9\uc18c\ucf13\uc744 \uc774\uc6a9\ud55c GraphQL \uc11c\ube0c\uc2a4\ud06c\ub9bd\uc158 \uad6c\ud604 \ubc29\ubc95\uc744 \uc54c\uc544\ubcf4\uc790.<\/p>\n","protected":false},"author":1,"featured_media":12882,"comment_status":"closed","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[1957],"tags":[2421,2105,2188,2455,2156,5932,906],"class_list":["post-36446","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-development","tag-boot","tag-java","tag-public","tag-query","tag-spring","tag-spring-boot","tag-world"],"acf":[],"_links":{"self":[{"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/posts\/36446","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/comments?post=36446"}],"version-history":[{"count":1,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/posts\/36446\/revisions"}],"predecessor-version":[{"id":36546,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/posts\/36446\/revisions\/36546"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/media\/12882"}],"wp:attachment":[{"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/media?parent=36446"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/categories?post=36446"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/tags?post=36446"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}