this post was submitted on 10 Jun 2023
22 points (95.8% liked)

Linux

46775 readers
1922 users here now

From Wikipedia, the free encyclopedia

Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).

Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.

Rules

Related Communities

Community icon by Alpár-Etele Méder, licensed under CC BY 3.0

founded 5 years ago
MODERATORS
 

I've read that standard containers are optimized for developer productivity and not security, which makes sense.

But then what would be ideal to use for security? Suppose I want to isolate environments from each other for security purposes, to run questionable programs or reduce attack surface. What are some secure solutions?

Something without the performance hit of VMs

you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 13 points 1 year ago (17 children)

It is the application Docker that is not secure. Containers are. In fact Docker runs a daemon as root to wich you communicate from a client. This is what makes it less secure; running under root power. It also has a few shortcomings of privileged containers. This can be easily solved by using podman and SELinux. If you can manage to run Docker rootless, then you are magnitudes higher in security.

[–] [email protected] 6 points 1 year ago (11 children)

Do you think Podman is ready to take over Docker? My understanding is that Podman is Docker without the root requirement.

[–] [email protected] 1 points 1 year ago* (last edited 1 year ago) (2 children)

Related to this: can podman completely replace Docker? I.e., can it pull containers and build containers in addition to running them?

[–] [email protected] 2 points 1 year ago

I believe it can but don't take my word for it

[–] [email protected] 1 points 1 year ago (3 children)

It can pull and build containers fine but last time I tried there were some differences. Mounts were not usable because user uid/gid behave quite differently. Tools like portainer dont work on podman containers. I havent tried out any networking or advanced stuff yet.

But i found that the considerations to write docker files are quite different for podman.

[–] [email protected] 3 points 1 year ago

Differences you find could be related to containers being run rootless, or the host system having SELinux enforcesd. Both problems could be intended behavior and can be soled simply by using by adding correct labels to mount points like :z or :Z. This SELinux feature also affects Docker when setup.

Portaiers tries to connect to a docker sock path that is not the same with Podman. While podman is rootless and does not need a daemon, socks and stuff, it has support for them nevertheless. So you can simply adjust Portainer config to work with podman. I havnt tried it yet but I managed to do similar things for other software.

[–] [email protected] 1 points 1 year ago

Gotcha. I use docker containers on computing clusters at the University, but because of security, I have to convert them to singularity containers. That is okay, but I was hoping that by running podman I could prevent this extra step.

[–] [email protected] 0 points 1 year ago (2 children)

Podman supports dockerfile, right?

[–] [email protected] 1 points 1 year ago

Unlike docker, podman doesn't try to do everything on it's own. There's a separate tool known as buildah which builds containers from dockerfiles just fine.

Ps. More generally, they're called containerfiles.

load more comments (8 replies)
load more comments (13 replies)