#packer (2020-06)
Discuss Packer for building AMIs and Docker Images
Archive: https://archive.sweetops.com/packer/
2020-06-04
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
Hey I am trying to pass 2 env vars from a ci pipeline to my shell provisioner somehow this does not seems to work. RESOURCES_AWS_ACCESS_KEY_ID
and RESOURCES_AWS_SECRET_ACCESS_KEY
my packer json is in the thread
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
{
"variables": {
"resources_aws_id": "{{env `RESOURCES_AWS_ACCESS_KEY_ID`}}",
"resources_aws_key": "{{env `RESOURCES_AWS_SECRET_ACCESS_KEY`}}"
},
"provisioners": [
{
"type": "shell",
"inline": [
"mkdir -p /tmp/httpd/ /tmp/crontab/ /tmp/sAI/"
]
},
{
"type": "file",
"source": "./httpd",
"destination": "/tmp/"
},
{
"type": "file",
"source": "./sAI",
"destination": "/tmp/"
},
{
"type": "file",
"source": "./crontab",
"destination": "/tmp/"
},
{
"type": "shell",
"scripts": [
"./httpd/install.sh",
"./sAI/install.sh",
"./crontab/install.sh"
],
"environment_vars": [
"RELEASE_PROJECT={{user `RELEASE_PROJECT`}}",
"RELEASE_STAGE={{user `RELEASE_STAGE`}}",
"RELEASE_VERSION={{user `RELEASE_VERSION`}}",
"AWS_ACCESS_KEY_ID={{user `AWS_ACCESS_KEY_ID`}}",
"AWS_SECRET_ACCESS_KEY={{user `AWS_SECRET_ACCESS_KEY`}}",
"RESOURCES_AWS_ACCESS_KEY_ID={{user `resources_aws_id`}}",
"RESOURCES_AWS_SECRET_ACCESS_KEY={{user `resources_aws_key`}}"
]
}
]
}
data:image/s3,"s3://crabby-images/05674/0567407520a5644811bc615e323224ad04488e82" alt="ikar avatar"
"AWS_ACCESS_KEY_ID={{user `AWS_ACCESS_KEY_ID`}}"
should be:
"AWS_ACCESS_KEY_ID={{user `resources_aws_id`}}"
data:image/s3,"s3://crabby-images/05674/0567407520a5644811bc615e323224ad04488e82" alt="ikar avatar"
also RELEASE_* seem not to be defined?
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
oh these I pass in via cli
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
packer build \
-var "SOURCE_AMI=$SOURCE_AMI" \
-var "RELEASE_PROJECT=$PROJECT_NAME" \
-var "RELEASE_STAGE=$TARGET" \
-var "RELEASE_VERSION=$TAG" \
-var "RELEASE_NAME=$PROJECT_NAME-$TARGET-$TAG" \
-var "AWS_ACCESS_KEY_ID=$AWS_ACCESS_KEY_ID" \
-var "AWS_SECRET_ACCESS_KEY=$AWS_SECRET_ACCESS_KEY" \
-var "CI_JOB_TOKEN=$CI_JOB_TOKEN" \
"packer.json"
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
but I want the RESOURCES_* to be passed in via env vars instead of defining them via cli arguments
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
since those are project specific
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
I found the issue it is not related to packer but how I merge with a different packer file later
data:image/s3,"s3://crabby-images/05674/0567407520a5644811bc615e323224ad04488e82" alt="ikar avatar"
dunno, sorry. Was my first shot in the dark
2020-06-14
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Anyone use hcl for packer?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
One thing I’m interested in is modules so i can create a good template of build commands that other repos can source.. i don’t see any examples of this
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We recently looked into it for a project we are working on.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Decided against it due to https://github.com/hashicorp/packer/issues/9176
HCL2 support is a beta work in progress and features are added one by one. As a result it can be hard for end users to know where we are at. While the full list HCL2 issues can be found using the H…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Many things are not yet implemented.
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
This is helpful !! Thanks @Erik Osterman (Cloud Posse) @RB!! I was looking to use HCL for packer stuff, thanks for heads up !!
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Ah i see. Ill watch that issue and wait for it to be fully implemented
2020-06-15
2020-06-18
data:image/s3,"s3://crabby-images/ebdc9/ebdc90eae2e10c45a8833de12112e9b14fa0e915" alt="Sai Krishna avatar"
Hi Everyone - How do I set image name in packer docker image builder script?
2020-06-19
2020-06-30
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
is there a packer linter ?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
or perhaps a json linter with configurable rules for packer
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
conftest?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Write tests against structured configuration data using the Open Policy Agent Rego query language - open-policy-agent/conftest
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it supports like 20 languages and formats
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
including json/yaml/hcl/etc
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
ah interesting. i guess i need to explore this more. once hcl2 is completely embraced by packer, we could modularize our packer configs hopefully, and to be extra we could test with conftest too
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
awesome, thanks erik. i wonder if someone has already posted on testing their json code with this tool.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
ah heres a jsonnet example in conftest itself
https://github.com/open-policy-agent/conftest/blob/master/examples/jsonnet/arith.jsonnet
Write tests against structured configuration data using the Open Policy Agent Rego query language - open-policy-agent/conftest
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ya was just about to share
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Write tests against structured configuration data using the Open Policy Agent Rego query language - open-policy-agent/conftest
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
funny coincidence, @joshmyers just asked about https://sweetops.slack.com/archives/CB6GHNLG0/p1593520077380600
Anyone using Open Policy Agent/Conftest with Terraform?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Ya, doing that now, integrating OPA with Atlantis
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Very cool! I hope we get to work on a project that requires that this year.
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Still figuring out if I want conftest or direct OPA
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Looking reasonable so far though
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Interested to know folks approaches to this and integration into Atlantis, storing the rego policies besides your modules etc?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
That seems like it would work but you may require the same checks across different repos so perhaps youd want to either put the shared checka in its own repo and somehow clone it as a custom workflow
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Aye, or separate to actually enforce policies, so folks can just change them on a branch to suit their needs