#docker (2018-11)
All things docker
Archive: https://archive.sweetops.com/docker/
2018-11-14
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Hi People,
does anyone know a good and proper way to remove layers with secrets from a docker image ?
e.g. the only way that this can be done currently is to use multi stage builds or to unset the ENV/ARGS and there’s this blog post here that mentions experimental secrets but not for strings https://medium.com/@tonistiigi/build-secrets-and-ssh-forwarding-in-docker-18-09-ae8161d066
TL;DR docker history <docker_images>
exposes layers with secrets from build time.
data:image/s3,"s3://crabby-images/77664/776647da668c3ae897d3bd7459a1889af537de79" alt="attachment image"
One of the complexities when using Dockerfiles has always been accessing private resources. If you need to access some private repository…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Nikola Velkovski did you look at https://github.com/goldmann/docker-squash
Docker image squashing tool. Contribute to goldmann/docker-squash development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
here a a post how to do it https://blog.tomecek.net/post/docker-build-with-secrets/
Technical blog. Read about Linux, Python, Containers, Red Hat, Fedora, tools.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Nope, thanks will have a look.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
I also found this https://docs.docker.com/develop/develop-images/build_enhancements/#new-docker-build-command-line-build-output which is more or less what the blog post is saying
Docker Build is one of the most used features of the Docker Engine - users ranging from developers, build teams, and release teams all use Docker Build. Docker Build enhancements…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I like this new output
Docker Build is one of the most used features of the Docker Engine - users ranging from developers, build teams, and release teams all use Docker Build. Docker Build enhancements…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i believe it’s also possible to squash an image without any thirdparty tools
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
docker build --squash
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Ah yes we discuissed it with @maarten but when using --squash
there will be no caching.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Ah, that’s true… let’s step back: why do you need the secrets in the image to begin with?
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
in this particular case it’s for ruby gems, i need to bundle them from a private repo so I need the api key from it
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
there are cases for npm etc…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Can you use build args? Those are not persisted in the layers unless the a build step writes it to disk.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Something like
FROM node:X
ARG NPM_TOKEN
RUN echo "//registry.npmjs.org/:_authToken=$NPM_TOKEN" > ~/.npmrc && \
npm install && \
rm ~/.npmrc
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
@Erik Osterman (Cloud Posse) I am using args but it turns out those layers also persist
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yes, the layers persist, but that’s why you need to rm
in the same layer
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
see the example above
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
need to chain with &&
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Argh that’s why… ok great good to know!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Description Build an image from a Dockerfile Usage docker image build [OPTIONS] PATH | URL | - Options Name, shorthand Default Description –add-host Add a custom host-to-IP mapping (host:ip) –build-arg… |
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
You can also have an internal proxy that you use in your build process
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that proxy then has the authentication token for github
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we wrote one for the docker registry to do this
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so we could pull images without authentication in a trusted environment
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
same concept would apply to github
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
here’s the simple service
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(you’d adapt something like this to proxy github requests instead)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
DUPE: ~@Nikola Velkovski~heck this out~<https://medium.com/@tonistiigi/build-secrets-and-ssh-forwarding-in-docker-18-09-ae8161d066~
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
~Posted just a few days ago… highly relevant~
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Ah yeah, I already read it and posted it yesterday
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hahah
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
sorry, missed that! you did post it
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Anyway thanks for the help, I was also under the impression that passing secrets as args is ok
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
luckily I haven’t pushed any public images
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so regarding that experimental feature, that would be the cleanest, no?
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
yes
2018-11-25
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
A tool for exploring each layer in a docker image. Contribute to wagoodman/dive development by creating an account on GitHub.
2018-11-28
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
Has anyone used docker as a test environment for starting/stopping services using their init manager? I can’t figure out why none of the “your-favorite-OS-in-docker” images… support their standard init process / service manager.
None of the vendor images (amazon 1 or 2, ubuntu) include their init system: (upstart, systemd, sysvinit) [ to their credit, CentOS does includes instructions on how to create your own “Dockerfile for systemd base image” on their dockerhub readme: https://hub.docker.com/_/centos/ ]
my concern is, that without such hoop jumping, native, installed packages that try to install/enable their /etc/init
or systemd unit files or /etc/init.d
files are going to behave differently than real systems running on the exact same OS.
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
not to mention the OSX support for running systemd is missing (it requires --cap-add=SYS_ADMIN
, apparently only on OSX, to allow systemd to mount tmpfs)
cf. https://github.com/moby/moby/issues/30723
Hi, I did a bit of research around this and, event though it looks like there is a way to work around this problem, this is not applicable to Docker users running it on macOS. OS version: macOS Sie…
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
Actually it looks like I can (on OSX) at least get it to start without --cap-add
and without --security-opt=seccomp:unconfined
by using --tmpfs /tmp --tmpfs /run
in the docker run
command
What is the scoop on running systemd in a container? A couple of years ago I wrote an article on Running systemd with a docker-formatted Container. Sadly, two years later if you google docker systemd this is still the article people see — it’s time for an update. This is a follow-up for my last article. Everything you …
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
is the requirement to use systemd inside of docker or to use systemd to start containers (e.g. like in CoreOS)?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
actually, i’m not quite clear on the problem statement.
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
goal I’m trying to work with is that packer treats a docker builder the same as an EC2 builder… assuming they both start with the same OS image…. that systems work as similarly as possible.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
aha, i see
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@catdevman does this sound familiar?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@catdevman was telling me yesterday that they use packer to build both their AMIs and docker images and using Amazon Linux as base for both.
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
thats where I’d like to be
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
Thanks Erik. That sounds close. @catdevman when you have a moment, I’m interested to hear your strategy for using packer to create both docker images and AMIs
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
fwiw, when we’ve needed init in containers we’ve used s6 or dumb-init
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
s6 - skarnet’s small supervision suite
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
The folks at Yelp are
2018-11-29
data:image/s3,"s3://crabby-images/d1076/d10762179376d281b36fb60529373b701212144f" alt="catdevman avatar"
yeah @tamsky I can share some of that information… the biggest part is that your starting point has to be the same so for us we went with amazon linux and ubuntu. Only problem with this strategy is docker and assuming everything is root and doesn’t have sudo which means become for ansible needs to be variable and needs to know what type of build you are doing.
data:image/s3,"s3://crabby-images/d1076/d10762179376d281b36fb60529373b701212144f" alt="catdevman avatar"
@tamsky I have made separate packer files for ami and docker but the ansible playbooks are the same just different variables passed in. if you want to know more we can do pm
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
Thanks @catdevman,
that lines up 100% with my starting points (amazonlinux:2
, ubuntu:18.04
)
and matches where I’m at with packer+ansible.
I’d be interested to share my docker bits and ansible “hacks” that I’m using to remove the differences between container and AMI.
maybe we should have a #ansible channel? @Erik Osterman (Cloud Posse)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@tamsky sure thing!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
2018-11-30
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Hello people! Any recommendations for a a docker centric CI that just builds and uploads images, and utilizes caching
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
because I am losing my s*** with travis ci
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
travis cannot into Docker
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we use https://codefresh.io/
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
ahha I knew it !
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
all pipeline steps are containers
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
soo I was checking out the pricing, and 3 concurent builds which is the pro subscription won’t do
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
any idea how will it cost to have let’s say 20 concurent builds ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you need to discuss that with @Erik Osterman (Cloud Posse), he can provide more info and connect you with the Codefresh guys
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
(Y)
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Thanks
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
one example how we use our Docker images in Codefresh pipelines https://github.com/cloudposse/github-status-updater#integrating-with-codefresh-cicd-pipelines
Command line utility for updating GitHub commit statuses and enabling required status checks for pull requests - cloudposse/github-status-updater
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
thanks @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
set the channel topic:
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
I just found this today: https://github.com/just-containers/s6-overlay interesting approach vs trying to support multiple flavors of init(1) within docker: sysv, upstart, systemd
s6 overlay for containers (includes execline, s6-linux-utils & a custom init) - just-containers/s6-overlay
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
That’s cool!