Я использую конвейеры Bitbucket для запуска сценария развертывания на приоритетных компьютерах на вычислительном движке. Я использую Google SDK и учетную запись службы с ролью владельца, но все еще не могу SSH к машине.
Вот так выглядит мой bitbucket-pipelines.yml:
- echo $GCLOUD_API_KEYFILE | base64 --decode --ignore-garbage > ./gcloud-api-key.json
- gcloud auth activate-service-account --key-file gcloud-api-key.json
- gcloud config set project $GCLOUD_PROJECT
- gcloud compute --project $GCLOUD_PROJECT ssh --zone "us-east1-c" $INSTANCE_NAME --command "./deploy"
Я вижу, что могу успешно пройти проверку подлинности:
Activated service account credentials for: [...]
но я все еще не могу выполнить ssh к экземпляру
gcloud compute --project "..." ssh --zone "us-east1-c" "..." --command "..."
WARNING: The public SSH key file for gcloud does not exist.
WARNING: The private SSH key file for gcloud does not exist.
WARNING: You do not have an SSH key for gcloud.
WARNING: SSH keygen will be executed to generate a key.
Generating public/private rsa key pair.
Your identification has been saved in /root/.ssh/google_compute_engine.
Your public key has been saved in /root/.ssh/google_compute_engine.pub.
The key fingerprint is: ...
...
Updating project ssh metadata...
................Updated [https://www.googleapis.com/compute/v1/projects/...].
done.
Waiting for SSH key to propagate.
Warning: Permanently added '...' (RSA) to the list of known hosts.
Permission denied (publickey).
Я что-то упустил? Насколько я понимаю, когда я проходил проверку подлинности, поскольку учетная запись службы с разрешениями выполняет команду ssh, gcloud ssh предположим, что она работает