CWN(CHANGE WITH NEWS) - MS, API 개발 설계 언어로 ′캐들′ 선택

  • 맑음남해20.1℃
  • 구름많음거창18.2℃
  • 구름조금수원19.9℃
  • 맑음목포21.9℃
  • 구름조금천안18.2℃
  • 구름조금고창군19.4℃
  • 구름많음의성20.6℃
  • 구름조금안동19.1℃
  • 맑음거제20.8℃
  • 맑음강진군19.5℃
  • 맑음북창원22.6℃
  • 구름많음대구22.4℃
  • 맑음통영21.4℃
  • 구름조금홍성19.4℃
  • 맑음대전19.6℃
  • 맑음의령군20.5℃
  • 구름조금양산시22.9℃
  • 구름많음북춘천18.7℃
  • 구름많음태백15.3℃
  • 맑음제주22.8℃
  • 구름조금해남18.7℃
  • 맑음함양군18.9℃
  • 구름많음진도군20.2℃
  • 구름많음청송군18.6℃
  • 맑음진주18.7℃
  • 구름많음문경18.0℃
  • 맑음순천17.1℃
  • 맑음강화18.2℃
  • 구름많음완도21.5℃
  • 흐림홍천18.8℃
  • 구름조금영월17.7℃
  • 맑음철원19.3℃
  • 구름많음정읍21.0℃
  • 구름많음장수16.3℃
  • 구름조금밀양21.9℃
  • 흐림강릉21.7℃
  • 맑음경주시20.0℃
  • 구름많음춘천19.0℃
  • 구름많음이천19.2℃
  • 맑음파주17.9℃
  • 구름많음합천22.1℃
  • 구름조금임실18.4℃
  • 구름조금서울21.0℃
  • 맑음포항22.3℃
  • 맑음광양시21.0℃
  • 구름많음금산18.7℃
  • 구름많음속초20.5℃
  • 구름많음동해20.3℃
  • 흐림양평19.8℃
  • 맑음순창군19.5℃
  • 구름많음울릉도19.9℃
  • 구름조금영천21.0℃
  • 맑음광주21.8℃
  • 구름많음봉화16.5℃
  • 흐림서귀포24.1℃
  • 구름많음부여19.3℃
  • 맑음백령도20.2℃
  • 구름조금상주19.7℃
  • 맑음흑산도20.9℃
  • 구름많음보은17.8℃
  • 맑음여수22.6℃
  • 흐림대관령15.1℃
  • 맑음창원21.4℃
  • 구름조금서청주17.4℃
  • 맑음영광군19.7℃
  • 구름조금서산19.8℃
  • 맑음김해시21.6℃
  • 맑음인천20.8℃
  • 맑음군산20.9℃
  • 맑음고흥18.6℃
  • 구름조금청주21.8℃
  • 구름많음원주19.7℃
  • 맑음북부산21.5℃
  • 맑음동두천19.1℃
  • 맑음장흥18.1℃
  • 맑음추풍령17.8℃
  • 맑음보령19.6℃
  • 구름조금영주17.0℃
  • 구름많음영덕19.4℃
  • 구름많음성산21.7℃
  • 흐림정선군17.4℃
  • 구름조금울산20.7℃
  • 구름조금고산21.8℃
  • 구름많음인제17.2℃
  • 구름조금세종19.1℃
  • 구름많음부안20.0℃
  • 구름조금충주18.2℃
  • 구름많음전주21.8℃
  • 구름많음울진20.8℃
  • 구름조금제천16.8℃
  • 구름많음구미20.9℃
  • 흐림북강릉19.6℃
  • 맑음남원18.9℃
  • 구름조금산청19.6℃
  • 맑음부산22.7℃
  • 맑음고창20.2℃
  • 맑음보성군18.7℃
  • 2025.09.30 (화)

MS, API 개발 설계 언어로 '캐들' 선택

안하영 / 기사승인 : 2022-12-23 13:39:00
  • -
  • +
  • 인쇄
마이크로소프트(Microsoft)가 대부분의 API 개발에 OpenAPI 정의로 컴파일하기 전에 프로그래밍 방식으로 API 구조를 정의하는 데 도움이 되는 캐들(Cadl) 언어를 활용하고 있다. [사진출처=마이크로소프트]
마이크로소프트(Microsoft)가 대부분의 API 개발에 OpenAPI 정의로 컴파일하기 전에 프로그래밍 방식으로 API 구조를 정의하는 데 도움이 되는 캐들(Cadl) 언어를 활용하고 있다. [사진출처=마이크로소프트]

마이크로소프트(Microsoft)가 대부분의 API 개발에 OpenAPI 정의로 컴파일하기 전, 프로그래밍 방식으로 API 구조를 정의하는 데 도움이 되는 캐들(Cadl) 언어를 활용하고 있다.

소프트웨어 전문매체 인포월드에 따르면, 마이크로소포트는 캐들로 Bicep이 인프라에 대해 수행하는 작업을 API에 수행해, API 정의를 반복적으로 제공하고 있다.

캐들은 .NET과 일부 유사한 자바스크립트와 유사한 언어다. 마이크로소프트는 C#에 익숙한 사람이라면 누구나 쉽게 사용할 수 있도록 ‘API용 TypeScript’라고 설명했다. 비주얼 스튜디오 및 비주얼 스튜디오 코드의 언어 서버에 캐들 확장을 추가해 기본 제공 구문 강조 표시, 코드 완성, linting에서 지원을 받을 수 있다.

또한 캐들은 디자인을 추상화해, 더 간결한 출력을 제공할 수 있어 비주얼 스튜디오와 같은 플랫폼의 OpenAPI 도구가 빠르고 효율적으로 구문을 분석할 수 있게 한다. 캐들을 사용하면 50줄의 코드로 500줄 OpenAPI 정의를 작성할 수 있다. 설계자와 개발자가 API를 구성하고 제한하는 논리적인 방법이다.

캐들을 언어로 만드는 것은 많은 의미가 있다. 아키텍처 제약 조건을 규칙으로 캡슐화하고 공통 구조를 라이브러리로 래핑할 수 있다. API 설명은 아키텍처 규칙의 범위를 벗어나는 경우 컴파일 되지 않으므로 캐들 환경에서 적용된다. API 설계자는 아키텍처 팀이 설정한 지침 내에서 작업해야 한다. 캐들 설계자는 이 프로세스를 ‘구성에 의해 수정’된 출력으로 만드는 것으로 설명한다.

캐들에서 API 정의를 작성하는 것은 간단하다. 일반적으로 캐들 코드의 기본 파일에서 REST 및 OpenAPI 바인딩을 해야 한다. 캐들에서 키워드는 ‘데코레이터’라고 하며 @로 시작해 파일을 사람이 읽을 수 있도록 한다. 정의는 서비스 정의로 시작해 서비스에 이름을 지정하고 버전 번호를 지정해야 한다. 다음에 엔드포인트에 대한 URI가 있는 서버 정의를 추가할 수 있다. 전 세계적으로 분산된 시스템에 유용한 이 기능은 API를 사용할 수 있는 지역과 같은 추가 매개변수를 추가할 수 있다. 이는 애저(Azure)를 염두에 두고 설계된 것이지만, 여러 엔드포인트가 있는 분산 시스템에 유용하다.

다음으로 API에서 사용하는 경로와 리소스를 정의한다. 경로는 서비스 URI에 상대적인 리소스 경로이며 API 작업을 래핑하는 네임스페이스에 연결된다. 작업은 예상되는 HTTP 동사를 사용하거나 목록과 같은 기능으로 정의된다. 이름이 사용되는 경우 컴파일러는 API를 생성할 때 적절한 동사를 추가한다. 이는 REST API 호출의 요청 본문을 정의할 수 있으므로 이를 사용해 복잡한 API에 JSON을 보내거나 비교적 기본적인 것에 대한 간단한 텍스트를 보낼 수 있다.

API가 더 복잡할 때는 자동 경로 지정 옵션은 매개변수를 사용해 경로를 생성할 수 있다. 사용자 이름이나 ID를 경로에서 예상하는 API에 전달하는 때를 예시로 언급할 수 있다. 경로에 매개변수를 전달하는 것으로 제한되지 않는다. URL 쿼리로 전달하는 옵션이 있다. 결과는 Express node.js 애플리케이션 프레임워크 작업을 연상시키는 REST API를 정의하는 비교적 간단한 방법이다. 주로 캐들이 서비스 호출을 위한 URL을 구성하고 API를 코드로 추상화하기 때문이다. Express와 같은 도구를 사용한 경험이 있으면 개발자가 새로운 언어를 이해하는 데 도움이 될 수 있다.

API 정의 작성은 캐들 기능 중 일부 기능에 해당한다. 더 중요한 것은 API를 제공하는 데 사용해야 하는 구조를 제공해 개발팀에 API 표준을 적용하는 것이다. 캐들 정의 표준을 구축하기 위한 핵심 요소는 라이브러리를 생성하는 것이다.

라이브러리로 캐들 정의의 표준을 확립한다면, C#과 매우 유사한 구문으로 공통 함수에 대한 재사용 가능한 템플릿을 관리할 수 있다. 또, 마이크로소프트는 이를 사용해 애저 API 기능을 구현하는 방법을 살펴볼 가치가 있다.

예를 들어, API의 기능을 자세히 설명하는 REST API 형식을 정의하는 일반 인터페이스를 만들 수 있다. 라이브러리가 있으면 API 인터페이스를 확장해 라이브러리 템플릿을 사용해 경로에 매핑하고 적절하게 태그를 지정할 수 있다. 다음으로 모델 정의를 사용해 예상 응답을 나열하는 API를 생성한다.

[저작권자ⓒ CWN(CHANGE WITH NEWS). 무단전재-재배포 금지]

안하영
안하영

기자의 인기기사

최신기사

뉴스댓글 >

- 띄어 쓰기를 포함하여 250자 이내로 써주세요.
- 건전한 토론문화를 위해, 타인에게 불쾌감을 주는 욕설/비방/허위/명예훼손/도배 등의 댓글은 표시가 제한됩니다.

댓글 0

Today

Hot Issue