>백엔드 개발 >Golang >Raku 인터페이스를 사용한 Go 파이프라인

Raku 인터페이스를 사용한 Go 파이프라인

Linda Hamilton
Linda Hamilton원래의
2024-11-07 13:52:03303검색

Go pipelines with Raku interfaces

그래서, 당신이 golang 개발자이고 순수 Go에서 CICD 작업을 작성하고 싶다고 가정해 보겠습니다.

cat task.go

package main

import "fmt"

func main() {
    fmt.Println("Hello, pipeline")
}

Go는 멋지지만 높은 수준의 시나리오에서 사용하기 어렵게 만드는 한 가지가 있습니다. 바로 그 장황함입니다. 작업을 진행하고 기본 시나리오로 다시 반환하기 위해 매개변수를 전달하려면 약간의 노력과 많은 상용구 코드가 필요합니다. 주요 코드를 간결하고 읽기 쉽게 유지하는 것이 좋습니다.

반면에 Rakulang은 극도의 유연성과 표현력으로 인해 데이터를 넣고 빼는 데 있어 완벽한 언어입니다.

이 게시물에서는 Sparrow 프레임워크의 도움을 받아 CICD 파이프라인에 golang 작업을 삽입하는 방법을 보여 드리겠습니다.


먼저 golang 작업 코드를 수정해 보겠습니다. 새 버전은 다음과 같습니다.

cat task.go

package main

import (
  "fmt"
  "github.com/melezhik/sparrowgo"
)

func main() {

  type Params struct {
    Message string
  }

  type Result struct {
    Message string
  }

  var params Params

  // sparrowgo takes care about passing 
  // input parameters from Raku to Go
  sparrowgo.Config(&params)

  // read params from pipeline
  fmt.Printf("Task params: %s\n", params.Message)

  // return results back to pipeline 
  sparrowgo.UpdateState(&Results{Message : "Hello from Go"})

}

여기서 우리가 수행한 모든 작업은 Rakulang과 데이터를 전달하고 반환하는 이점을 통해 golang 작업을 Sparrow 작업으로 "변환"하는 Sparrowgo 패키지를 활용한 것입니다.


마지막으로 우리의 파이프라인은 다음과 같습니다. 이제 Raku 부분입니다.

#!raku

my $s = task-run ".", %(
  :message<Hello from Raku>
);

say "Result: ", $s<Message>;

수준 높은 디자인.

이제 개념 증명 코드가 준비되면 파이프라인 시스템이 어떤 모습일지에 대한 높은 수준의 그림을 얻을 수 있습니다.

      [ Raku scenario to pass and handle data in and out ]
        \                    \                     \          
      task.go -> result -> task.go -> result -> task.go -> ...

따라서 우리는 두 가지 장점을 모두 갖고 있습니다. 적은 코드로 시나리오를 작성하는 Raku와 성능 및 엄격한 유형 검사가 필요한 모든 작업을 수행하는 Golang입니다.

위 내용은 Raku 인터페이스를 사용한 Go 파이프라인의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.