BazelCon 2022는 11월 16~17일에 뉴욕과 온라인에서 개최됩니다.
지금 등록하기

실행 그룹

컬렉션을 사용해 정리하기 내 환경설정을 기준으로 콘텐츠를 저장하고 분류하세요.

실행 그룹을 사용하면 단일 타겟 내에서 여러 실행 플랫폼을 사용할 수 있습니다. 각 실행 그룹에는 고유한 도구 모음 종속 항목이 있으며 자체 도구 모음 확인을 실행합니다.

배경

실행 그룹을 사용하면 규칙 작성자가 각각 서로 다른 실행 플랫폼을 포함하는 작업 집합을 정의할 수 있습니다. 여러 실행 플랫폼을 사용하면 작업을 다르게 실행할 수 있습니다. 예를 들어 원격(Linux) 작업자에서 iOS 앱을 컴파일한 다음 로컬 Mac 작업자에서 연결/코드 서명을 합니다.

작업 그룹을 정의할 수 있게 되면 작업 지정을 위한 프록시로 작업 연상제의 사용을 줄이는 데에도 도움이 됩니다. 중성어는 고유하지 않을 수 있으며 단일 동작만 참조할 수 있습니다. 이 방법은 까다로운 작업에 과도하게 할당하지 않고 특정 메모리에 추가 리소스를 할당하고 C++ 빌드에 연결하는 것과 같은 집중적인 작업을 처리하는 데 특히 유용합니다.

실행 그룹 정의

규칙 정의 중에 규칙 작성자는 실행 그룹 집합을 선언할 수 있습니다. 각 실행 그룹에서 규칙 작성자는 실행 그룹의 실행 플랫폼을 선택하는 데 필요한 모든 항목, 즉 exec_compatible_with을 통해 제약조건과 toolchain를 통해 도구 모음 유형을 지정할 수 있습니다.

# foo.bzl
my_rule = rule(
    _impl,
    exec_groups = {
        “link”: exec_group(
            exec_compatible_with = [ "@platforms//os:linux" ]
            toolchains = ["//foo:toolchain_type"],
        ),
        “test”: exec_group(
            toolchains = ["//foo_tools:toolchain_type"],
        ),
    },
    attrs = {
        "_compiler": attr.label(cfg = config.exec("link"))
    },
)

위의 코드 스니펫에서는 도구 종속 항목이 cfg 속성 매개변수와 config 모듈을 사용하여 실행 그룹의 전환을 지정할 수도 있다는 사실을 알 수 있습니다. 모듈은 종속 항목이 빌드되어야 하는 실행 그룹의 이름인 단일 문자열 매개변수를 사용하는 exec 함수를 노출합니다.

네이티브 규칙과 마찬가지로 test 실행 그룹은 Starlark 테스트 규칙에 기본적으로 표시됩니다.

실행 그룹 상속

새 실행 그룹은 자체 제약조건 및 도구 모음을 정의하는 것 외에도 copy_from_rule = True 매개변수를 전달하여 규칙의 기본 실행 그룹에서 상속하려고 한다고 선언할 수 있습니다. copy_from_rule를 true로 설정하고 exec_compatible_with 또는 toolchains를 전달하는 것은 오류입니다.

기본 실행 그룹에서 상속되는 실행 그룹은 제약 조건, 도구 모음, 실행 속성을 기본값에서 복사합니다. 여기에는 규칙 자체에 의해 지정되는 대상뿐 아니라 대상 수준에서 설정된 제약조건 및 실행 속성도 포함됩니다. 즉, 다음과 같은 사항을 고려하세요.

# foo.bzl
my_rule = rule(
    _impl,
    exec_groups = {
        “copied”: exec_group(
            copy_from_rule = True,
            # This will inherit exec_compatible_with and toolchains.
            # Setting them here directly would be an error, however.
        ),
    },
    toolchains = ["//foo_tools:toolchain_type"],
    exec_compatible_with = ["@platforms//os:linux"],
)

# BUILD

my_rule(
    name = "demo",
    exec_compatible_with = [":local_constraint"],
)

구성된 대상 democopied 실행 그룹에 다음을 모두 포함: - //fool_tools:toolchain_type - @platforms//os:linux - :local_constraint

실행 그룹 액세스

규칙 구현에서는 실행 그룹의 실행 플랫폼에서 작업이 실행되도록 선언할 수 있습니다. 이렇게 하려면 작업 생성 메서드의 exec_group 매개변수, 특히 ctx.actions.runctx.actions.run_shell를 사용하면 됩니다.

# foo.bzl
def _impl(ctx):
  ctx.actions.run(
     inputs = [ctx.attr._some_tool, ctx.srcs[0]]
     exec_group = "compile",
     # ...
  )

규칙 작성자는 대상의 확인된 도구 모음에 액세스하는 방법과 비슷하게 실행 그룹의 확인된 도구 모음에 액세스할 수도 있습니다.

# foo.bzl
def _impl(ctx):
  foo_info = ctx.exec_groups["link"].toolchains["//foo:toolchain_type"].fooinfo
  ctx.actions.run(
     inputs = [foo_info, ctx.srcs[0]]
     exec_group = "link",
     # ...
  )

실행 그룹을 사용하여 실행 속성 설정

실행 그룹은 모든 규칙에 존재하는 exec_properties 속성과 통합되며, 타겟 작성자가 실행 기계로 전달되는 속성의 문자열 사전을 지정할 수 있습니다. 예를 들어, 타겟과 관련하여 일부 속성(예: 메모리)을 설정하고 특정 작업에 더 높은 메모리 할당을 부여하려면 다음과 같이 실행 그룹 확대 키를 사용하여 exec_properties 항목을 작성합니다.

# BUILD
my_rule(
    name = 'my_target',
    exec_properties = {
        'mem': '12g',
        'link.mem': '16g'
    }
    …
)

exec_group = "link"를 사용하는 모든 작업에는 실행 속성 사전이 {"mem": "16g"}로 표시됩니다. 여기에서 볼 수 있듯이, 실행 그룹 수준 설정이 타겟 수준 설정보다 우선 적용됩니다.

네이티브 규칙의 실행 그룹

네이티브 규칙으로 정의된 작업에는 다음 실행 그룹을 사용할 수 있습니다.

  • test: 테스트 실행자 작업을 테스트합니다.
  • cpp_link: C++ 연결 작업.

실행 속성을 설정하기 위해 실행 그룹 만들기

때로 exec 그룹을 사용하여 특정 작업에 다른 exec 속성을 부여하되 실제로 규칙과 다른 도구 모음 또는 제약 조건을 원하지 않는 경우가 있습니다. 이러한 경우에는 copy_from_rule 매개변수를 사용하여 실행 그룹을 만들 수 있습니다.

# foo.bzl

# Creating an exec group with `copy_from_rule=True` is the same as explicitly
# setting the exec group's toolchains and constraints to the same values as the
# rule's respective parameters.
my_rule = rule(
    _impl,
    exec_compatible_with = ["@platforms//os:linux"],
    toolchains = ["//foo:toolchain_type"],
    exec_groups = {
        # The following two groups have the same toolchains and constraints:
        “foo”: exec_group(copy_from_rule = True),
        "bar": exec_group(
            exec_compatible_with = ["@platforms//os:linux"],
            toolchains = ["//foo:toolchain_type"],
        ),
    },
)

#

실행 그룹 및 플랫폼 실행 속성

플랫폼 타겟에서 임의의 실행 그룹에 대해 exec_properties을 정의할 수 있습니다 (알 수 없는 실행 그룹의 속성이 거부되는 타겟에 exec_properties 직접 설정됨). 그러면 기본 실행 그룹과 기타 관련 실행 그룹에 영향을 주는 실행 플랫폼의 exec_properties를 상속합니다.

예를 들어 C++ 테스트를 실행하려면 일부 리소스를 사용할 수 있어야 하며, 컴파일 및 연결에 필요하지는 않습니다. 다음과 같이 모델링할 수 있습니다.

constraint_setting(name = "resource")
constraint_value(name = "has_resource", constraint_setting = ":resource")

platform(
    name = "platform_with_resource",
    constraint_values = [":has_resource"],
    exec_properties = {
        "test.resource": "...",
    },
)

cc_test(
    name = "my_test",
    srcs = ["my_test.cc"],
    exec_compatible_with = [":has_resource"],
)

타겟에 직접 정의된 exec_properties가 실행 플랫폼에서 상속된 값보다 우선 적용됩니다.