Compute Engine용 커넥터
컬렉션을 사용해 정리하기
내 환경설정을 기준으로 콘텐츠를 저장하고 분류하세요.
워크플로 내에서 Compute Engine에 액세스하는 데 사용되는 기본 제공 함수를 정의하는 Workflows 커넥터입니다.
더 살펴보기
이 코드 샘플이 포함된 자세한 문서는 다음을 참조하세요.
코드 샘플
달리 명시되지 않는 한 이 페이지의 콘텐츠에는 Creative Commons Attribution 4.0 라이선스에 따라 라이선스가 부여되며, 코드 샘플에는 Apache 2.0 라이선스에 따라 라이선스가 부여됩니다. 자세한 내용은 Google Developers 사이트 정책을 참조하세요. 자바는 Oracle 및/또는 Oracle 계열사의 등록 상표입니다.
[[["이해하기 쉬움","easyToUnderstand","thumb-up"],["문제가 해결됨","solvedMyProblem","thumb-up"],["기타","otherUp","thumb-up"]],[["이해하기 어려움","hardToUnderstand","thumb-down"],["잘못된 정보 또는 샘플 코드","incorrectInformationOrSampleCode","thumb-down"],["필요한 정보/샘플이 없음","missingTheInformationSamplesINeed","thumb-down"],["번역 문제","translationIssue","thumb-down"],["기타","otherDown","thumb-down"]],[],[],[],null,["# Connector for Compute Engine\n\nWorkflows connector that defines the built-in function used to access Compute Engine within a workflow.\n\nExplore further\n---------------\n\n\nFor detailed documentation that includes this code sample, see the following:\n\n- [Compute Engine API Connector Overview](/workflows/docs/reference/googleapis/compute/Overview)\n\nCode sample\n-----------\n\n### YAML\n\n # This workflow demonstrates how to use the Compute Engine connector:\n # Create and start a Compute Engine VM instance, then stop and delete the VM\n # Each step waits until the long-running operation of stopping or starting the VM completes\n # After each step, the machine status is verified\n # Expected output: \"SUCCESS\"\n main:\n params: []\n steps:\n - init:\n assign:\n - project: ${sys.get_env(\"GOOGLE_CLOUD_PROJECT_ID\")}\n - zone: \"us-central1-a\"\n - instance: \"INSTANCE_NAME\" # replace INSTANCE_NAME placeholder\n - machineType: \"e2-micro\"\n - insert_machine:\n call: googleapis.compute.v1.instances.insert\n args:\n project: ${project}\n zone: ${zone}\n body:\n name: ${instance}\n machineType: ${\"zones/\" + zone + \"/machineTypes/\" + machineType}\n disks:\n - initializeParams:\n sourceImage: \"projects/debian-cloud/global/images/debian-10-buster-v20201112\"\n boot: true\n autoDelete: true\n networkInterfaces:\n - network: \"global/networks/default\"\n - start_machine:\n call: googleapis.compute.v1.instances.start\n args:\n instance: ${instance}\n project: ${project}\n zone: ${zone}\n - assert_running:\n call: assert_machine_status\n args:\n expected_status: \"RUNNING\"\n project: ${project}\n zone: ${zone}\n instance: ${instance}\n - stop_machine:\n call: googleapis.compute.v1.instances.stop\n args:\n instance: ${instance}\n project: ${project}\n zone: ${zone}\n - assert_terminated:\n call: assert_machine_status\n args:\n expected_status: \"TERMINATED\"\n project: ${project}\n zone: ${zone}\n instance: ${instance}\n - delete_machine:\n call: googleapis.compute.v1.instances.delete\n args:\n instance: ${instance}\n project: ${project}\n zone: ${zone}\n - the_end:\n return: \"SUCCESS\"\n\n assert_machine_status:\n params: [expected_status, project, zone, instance]\n steps:\n - get_instance:\n call: googleapis.compute.v1.instances.get\n args:\n instance: ${instance}\n project: ${project}\n zone: ${zone}\n result: instance\n - compare:\n switch:\n - condition: ${instance.status == expected_status}\n next: end\n - fail:\n raise: ${\"Expected VM status is \" + expected_status + \". Received \" + instance.status + \" instead.\"}\n\nWhat's next\n-----------\n\n\nTo search and filter code samples for other Google Cloud products, see the\n[Google Cloud sample browser](/docs/samples?product=workflows)."]]