Зашифрованный том и собственный ключ KMS с AWS CDK не работают

Я пытаюсь создать том EBS с AWS CDK, который зашифрован моим собственным ключом KMS на С#, с помощью этого фрагмента:

var kmsProps = new EncryptionKeyProps
{
    Description = "Encryption key for Storage",
    EnableKeyRotation = true,
    Enabled = true,
    Retain = true
};

var kms = new EncryptionKey(stack, "kms-storage", kmsProps);

var kmsAlias = kms.AddAlias("alias/" + stack.StackName + "/storage");

var storageVolume = new CfnVolume(stack, "server-storage-encrypted", new CfnVolumeProps
{
    AvailabilityZone = privateSubnet1.AvailabilityZone,
    KmsKeyId = kmsAlias.AliasName,
    Size = 30,
    Encrypted = true,
    Tags = new ICfnTag[]
    {
        new CfnTag {Key = "Name", Value = "Server Storage"}
    },
    VolumeType = "gp2"
}); 

Но команда развертывания завершается с ошибкой Volume vol-0e88979f5568c16fa is still creating

Любая идея, если я делаю что-то не так с политикой KMS и т. д.? Пытался найти, единственное, что я нашел, это то, что для автоматического масштабирования нужен доступ к ключу, ничего о EBS/EC2

Когда вы говорите «команда развертывания не удалась», что именно вы имеете в виду? Я сбит с толку, поскольку вы также связали облачное формирование AWS, но это не CFN. Ключ KMS (и его псевдоним) создается правильно? Вы пытались разделить код, так как в одном фрагменте создается ключ, а затем, как только вы это проверите, вы используете его ARN для создания тома в отдельном фрагменте?

Marakai 15.06.2019 04:32

PS: извиняюсь за путаницу в отношении: CFN или нет. Обычно я использую Python и boto3, поэтому не был сразу знаком с C# (или Java SDK). Тем не менее, мой совет остается в силе: разбейте все на части и протестируйте каждый ресурс отдельно.

Marakai 16.06.2019 05:24

Да, протестировал незашифрованный том, и он сработал, и он работает, если я разрешаю все всем в политике ключей. Не знаю, если это ошибка CFN или CDK, но я предполагаю, что это что-то изношенное в созданном CFN

Erik Karlsson 17.06.2019 11:08

Вы пытались создать if с помощью старого доброго шаблона YAML/JSON? Тогда, может быть, с Python? Чтобы заблокировать, является ли это проблемой C# SDK?

Marakai 17.06.2019 11:40
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
2
4
744
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я побежал к этому вопросу сегодня. Выяснилось, что использование псевдонима в KmsKeyId вызывало проблему. Стек был успешно создан после изменения псевдонима на фактический идентификатор ключа. Хотя в документации говорится, что можно использовать псевдоним, это не сработало для меня.

https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-ebs-volume.html

На самом деле псевдоним работает. Мой псевдоним был написан с ошибкой, но операция стека CF не сообщила об этом. Он просто долго зависал, пока не истечет время.

barryku 31.07.2021 05:31

Другие вопросы по теме