ML
    • Recent
    • Categories
    • Tags
    • Popular
    • Users
    • Groups
    • Register
    • Login

    Check my 2 min audio theory on Containers

    Scheduled Pinned Locked Moved IT Discussion
    containerscontainerdockervirtualization
    111 Posts 6 Posters 14.7k Views
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • matteo nunziatiM
      matteo nunziati @stacksofplates
      last edited by

      @stacksofplates said in Check my 2 min audio theory on Containers:

      @scottalanmiller said in Check my 2 min audio theory on Containers:

      Containers use shared kernels by definition, that's what makes it a container.

      This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

      Well go requires the kernel too. But yes for the most is the "from scratch" part which allows more abstraction

      stacksofplatesS 1 Reply Last reply Reply Quote 1
      • travisdh1T
        travisdh1 @stacksofplates
        last edited by travisdh1

        @stacksofplates said in Check my 2 min audio theory on Containers:

        @scottalanmiller said in Check my 2 min audio theory on Containers:

        Containers use shared kernels by definition, that's what makes it a container.

        This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

        To simplify what you are saying. Write software that doesn't really on the kennel and Docker just works I actually agree with you on this.

        My actual experience is that developers don't know when their code actually uses things from the kennel, thus 90+% of all Docker images I try to run are just broken.

        stacksofplatesS scottalanmillerS 4 Replies Last reply Reply Quote 2
        • stacksofplatesS
          stacksofplates @matteo nunziati
          last edited by

          @matteo-nunziati said in Check my 2 min audio theory on Containers:

          @stacksofplates said in Check my 2 min audio theory on Containers:

          @scottalanmiller said in Check my 2 min audio theory on Containers:

          Containers use shared kernels by definition, that's what makes it a container.

          This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

          Well go requires the kernel too. But yes for the most is the "from scratch" part which allows more abstraction

          Well I mean you have to have a kernel for anything to run. My point was it is technically possible to run a Go app in Docker natively on Windows with no Linux anywhere.

          scottalanmillerS 1 Reply Last reply Reply Quote 0
          • stacksofplatesS
            stacksofplates @travisdh1
            last edited by

            @travisdh1 said in Check my 2 min audio theory on Containers:

            @stacksofplates said in Check my 2 min audio theory on Containers:

            @scottalanmiller said in Check my 2 min audio theory on Containers:

            Containers use shared kernels by definition, that's what makes it a container.

            This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

            To simplify what you are saying. Write software that doesn't really on the kennel and Docker just works I actually agree with you on this.

            My actual experience is that developers don't know when their code actually uses things from the kennel, thus 90+% of all Docker images I try to run are just broken.

            Right. A lot of the containers use FROM everypackageinadistro because they don't know what their dependencies actually are.

            1 Reply Last reply Reply Quote 1
            • stacksofplatesS
              stacksofplates @travisdh1
              last edited by

              @travisdh1 said in Check my 2 min audio theory on Containers:

              @stacksofplates said in Check my 2 min audio theory on Containers:

              @scottalanmiller said in Check my 2 min audio theory on Containers:

              Containers use shared kernels by definition, that's what makes it a container.

              This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

              To simplify what you are saying. Write software that doesn't really on the kennel and Docker just works I actually agree with you on this.

              My actual experience is that developers don't know when their code actually uses things from the kennel, thus 90+% of all Docker images I try to run are just broken.

              And another plus with this is you can use Docker/K8s or something else like Nomad. You have multiple tools at your disposal this way.

              1 Reply Last reply Reply Quote 0
              • F
                flaxking @matteo nunziati
                last edited by

                @matteo-nunziati said in Check my 2 min audio theory on Containers:

                Doker images on kubernates are awesome but if you have to manage your data center doing ansible + docker over just ansible is not gaining a lot imho.

                Well, if IT is trying to use Docker without container orchestration then there's not much benefit to be gained there at all

                scottalanmillerS 1 Reply Last reply Reply Quote 0
                • scottalanmillerS
                  scottalanmiller @flaxking
                  last edited by

                  @flaxking said in Check my 2 min audio theory on Containers:

                  @matteo-nunziati said in Check my 2 min audio theory on Containers:

                  Doker images on kubernates are awesome but if you have to manage your data center doing ansible + docker over just ansible is not gaining a lot imho.

                  Well, if IT is trying to use Docker without container orchestration then there's not much benefit to be gained there at all

                  Docker became the golden child of IT buzz before orchestration was available. If orchestration is needed to validate it, it seems like a solution looking for a problem.

                  1 Reply Last reply Reply Quote 2
                  • scottalanmillerS
                    scottalanmiller @Emad R
                    last edited by

                    @emad-r said in Check my 2 min audio theory on Containers:

                    @scottalanmiller said in Check my 2 min audio theory on Containers:

                    @matteo-nunziati said in Check my 2 min audio theory on Containers:

                    @scottalanmiller said in Check my 2 min audio theory on Containers:

                    @matteo-nunziati said in Check my 2 min audio theory on Containers:

                    @emad-r actually The main benefit of containers is to disconnect sysadmin and devel work.

                    Not really. Containers are virtualization like any other, they've been around for decades and the idea that they were anything for developers is an extremely recent use case of only a very specific subset of containers. Most containers, and most of the history of containers, don't do anything like that, no more than any other kind of virtualization.

                    Yes but I think here we are talking docker. Docker is like python virtual envs for anything and not just for python. This is their main meaning to me.

                    Sure, if we are talking Docker and not talking Containerization, then Docker just seems like a sloppy, error prone way to do that.

                    My biggest issue with Docker is that it seems to make things worse rather than better. More complexity, more things to break, more dependencies. It introduces the very problems it claims to solve, problems that we weren't experiencing previously.

                    It does that, it does create more complexity at first.

                    Installing an app for us is much easier, like PHP-FPM + apache, it is only 10 commands or something, however if you did in docker/container in VPS you get the extra benefit of having clean environment in the host OS always + the container can be moved around easily to another VPS + it is much easier for non smart people to get your app and its updates + Docker provides free accout to publish one app.

                    That's a theory, but in the real world I've seen the opposite. Docker requires too much knowledge and skill on both ends and isn't as portable as people say. Docker requires both the admins and the developers to do more work and if either gets it wrong, Docker is harder to deal with. And since you rarely control both sides, it's a pretty big problem.

                    Docker doesn't really give the benefits you list. It can do that, but so can more traditional containers, without all of the Docker problems.

                    So given that moving workloads, and containerizing aren't benefits to Docker (it does them, but it's not unique), what problem do you feel Docker is actually solving over older, simpler solutions?

                    If there is one thing Docker doesn't do, it's make things easier for non-smart people. It requires all people to be smarter. This is exactly the opposite of the value it is providing.

                    Emad RE 1 Reply Last reply Reply Quote 2
                    • scottalanmillerS
                      scottalanmiller @matteo nunziati
                      last edited by

                      @matteo-nunziati said in Check my 2 min audio theory on Containers:

                      The only linux technology which involves containers and acts as a proper virtualization layer afaik is lxd. I don't know if there is anything similar, aka, another frontend to lxc, the actual userspace driver for kernel isolation technologies.
                      Of course there is the long standing openvz, but I'm considering some in-tree technology which doens't require a custom kernel.

                      No reason for competitors to arise. LXC and OpenVZ cover the spectrum and are free and part of the OS. Not the kind of thing you'd expect a competitor to arise to compete with. Just like there is no competitor for LVM. It's so good, and free, and built in, that replacing it would be completely silly.

                      1 Reply Last reply Reply Quote 0
                      • scottalanmillerS
                        scottalanmiller @matteo nunziati
                        last edited by

                        @matteo-nunziati said in Check my 2 min audio theory on Containers:

                        @scottalanmiller said in Check my 2 min audio theory on Containers:

                        @matteo-nunziati said in Check my 2 min audio theory on Containers:

                        @scottalanmiller said in Check my 2 min audio theory on Containers:

                        @matteo-nunziati said in Check my 2 min audio theory on Containers:

                        @emad-r actually The main benefit of containers is to disconnect sysadmin and devel work.

                        Not really. Containers are virtualization like any other, they've been around for decades and the idea that they were anything for developers is an extremely recent use case of only a very specific subset of containers. Most containers, and most of the history of containers, don't do anything like that, no more than any other kind of virtualization.

                        Yes but I think here we are talking docker. Docker is like python virtual envs for anything and not just for python. This is their main meaning to me.

                        Sure, if we are talking Docker and not talking Containerization, then Docker just seems like a sloppy, error prone way to do that.

                        My biggest issue with Docker is that it seems to make things worse rather than better. More complexity, more things to break, more dependencies. It introduces the very problems it claims to solve, problems that we weren't experiencing previously.

                        100% agree. It makes sense only in a developers world no sysadmin usefulness here.

                        Yes, that's a good way, I think, to look at it. Docker seems to be designed to entice lazy, sloppy developers to not have to do their jobs well and just throw code "over the wall" to system admins that they don't want to talk to.

                        Docker didn't start off as an IT solution, but as a problem that IT has to contend with if we deal with bad developers. It was sold to developers as some silver bullet and tried to trick them into thinking that with Docker, they could skip operational knowledge. Something I see lots of dev shops attempting to do.

                        1 Reply Last reply Reply Quote 1
                        • scottalanmillerS
                          scottalanmiller @matteo nunziati
                          last edited by

                          @matteo-nunziati said in Check my 2 min audio theory on Containers:

                          @emad-r said in Check my 2 min audio theory on Containers:

                          @scottalanmiller said in Check my 2 min audio theory on Containers:

                          @matteo-nunziati said in Check my 2 min audio theory on Containers:

                          @scottalanmiller said in Check my 2 min audio theory on Containers:

                          @matteo-nunziati said in Check my 2 min audio theory on Containers:

                          @emad-r actually The main benefit of containers is to disconnect sysadmin and devel work.

                          Not really. Containers are virtualization like any other, they've been around for decades and the idea that they were anything for developers is an extremely recent use case of only a very specific subset of containers. Most containers, and most of the history of containers, don't do anything like that, no more than any other kind of virtualization.

                          Yes but I think here we are talking docker. Docker is like python virtual envs for anything and not just for python. This is their main meaning to me.

                          Sure, if we are talking Docker and not talking Containerization, then Docker just seems like a sloppy, error prone way to do that.

                          My biggest issue with Docker is that it seems to make things worse rather than better. More complexity, more things to break, more dependencies. It introduces the very problems it claims to solve, problems that we weren't experiencing previously.

                          It does that, it does create more complexity at first.

                          Installing an app for us is much easier, like PHP-FPM + apache, it is only 10 commands or something, however if you did in docker/container in VPS you get the extra benefit of having clean environment in the host OS always + the container can be moved around easily to another VPS + it is much easier for non smart people to get your app and its updates + Docker provides free accout to publish one app.

                          Also the performance aspect is very good, but the storing this is bad abit.

                          The key idea here it is not currently hyper visor replacement, it is complementary tool that is good when you have service/server that does not need to store data.

                          While I find useful to have a package+config easily moveable I would syggest to manage staless services with ansible/salt and their playbooks if you want automation at sysadmin level.

                          Exactly. Rapid spin up, isolation, portability... I have all of that with existing tools. Docker just breaks that, rather than fixes it.

                          1 Reply Last reply Reply Quote 1
                          • scottalanmillerS
                            scottalanmiller @flaxking
                            last edited by

                            @flaxking said in Check my 2 min audio theory on Containers:

                            @matteo-nunziati said in Check my 2 min audio theory on Containers:

                            @emad-r said in Check my 2 min audio theory on Containers:

                            @scottalanmiller said in Check my 2 min audio theory on Containers:

                            @matteo-nunziati said in Check my 2 min audio theory on Containers:

                            @scottalanmiller said in Check my 2 min audio theory on Containers:

                            @matteo-nunziati said in Check my 2 min audio theory on Containers:

                            @emad-r actually The main benefit of containers is to disconnect sysadmin and devel work.

                            Not really. Containers are virtualization like any other, they've been around for decades and the idea that they were anything for developers is an extremely recent use case of only a very specific subset of containers. Most containers, and most of the history of containers, don't do anything like that, no more than any other kind of virtualization.

                            Yes but I think here we are talking docker. Docker is like python virtual envs for anything and not just for python. This is their main meaning to me.

                            Sure, if we are talking Docker and not talking Containerization, then Docker just seems like a sloppy, error prone way to do that.

                            My biggest issue with Docker is that it seems to make things worse rather than better. More complexity, more things to break, more dependencies. It introduces the very problems it claims to solve, problems that we weren't experiencing previously.

                            It does that, it does create more complexity at first.

                            Installing an app for us is much easier, like PHP-FPM + apache, it is only 10 commands or something, however if you did in docker/container in VPS you get the extra benefit of having clean environment in the host OS always + the container can be moved around easily to another VPS + it is much easier for non smart people to get your app and its updates + Docker provides free accout to publish one app.

                            Also the performance aspect is very good, but the storing this is bad abit.

                            The key idea here it is not currently hyper visor replacement, it is complementary tool that is good when you have service/server that does not need to store data.

                            While I find useful to have a package+config easily moveable I would syggest to manage staless services with ansible/salt and their playbooks if you want automation at sysadmin level.

                            The only pro of docker as a sysadmin tool is you have a good ecosystem with a lot of automation already done. With ansible/salt I don't know if you can pick from repos or you need to write everything from scratch.

                            The semi-equivalent of the docker pattern with ansible/salt is if you killed the server each time it you were going to do a configuration change or update, and redeployed it with your configuration. Then your CM has to bootstrap it before it is ready. Or you let your CM configure it, then image it and deploy the image... but you're just reinventing the wheel here, because that's what you do with Docker and you get smaller sized images.

                            So if the server doesn't make sense to use Docker for, maybe it's because it won't fit neatly into an immutable pattern?

                            Though your configuration as code being dockerfiles is not as nice.

                            Right. And you can do that. If that's something you want, Docker isn't necessary. Easy to do that without Docker. It's just that without Docker, no one wants that. It seems like Docker is designed to promote ideas that no one wants without the buzz of Docker itself. If you actually describe what Docker does, it doesn't sound very good.

                            Not that immutable deployments aren't beneficial, that can be great. But I don't need to be locked into that.

                            1 Reply Last reply Reply Quote 0
                            • scottalanmillerS
                              scottalanmiller @stacksofplates
                              last edited by scottalanmiller

                              @stacksofplates said in Check my 2 min audio theory on Containers:

                              @scottalanmiller said in Check my 2 min audio theory on Containers:

                              Containers use shared kernels by definition, that's what makes it a container.

                              This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

                              By definition, though, that makes it not a container in those cases, but a Type 2 hypervisor. And what a bad idea that is. Now we are just automated VirtualBox.

                              Containers require a shared kernel to be a container. It's the shared kernel that gives the behaviour and performance that makes it interesting. Without that, it's just misleading and crappy.

                              Is that really what Docker is doing, switching to a Type 2 model now instead of being a container?

                              stacksofplatesS 1 Reply Last reply Reply Quote 0
                              • scottalanmillerS
                                scottalanmiller @travisdh1
                                last edited by

                                @travisdh1 said in Check my 2 min audio theory on Containers:

                                @stacksofplates said in Check my 2 min audio theory on Containers:

                                @scottalanmiller said in Check my 2 min audio theory on Containers:

                                Containers use shared kernels by definition, that's what makes it a container.

                                This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

                                To simplify what you are saying. Write software that doesn't really on the kennel and Docker just works I actually agree with you on this.

                                But we can do that without Docker.

                                1 Reply Last reply Reply Quote 0
                                • scottalanmillerS
                                  scottalanmiller @travisdh1
                                  last edited by

                                  @travisdh1 said in Check my 2 min audio theory on Containers:

                                  My actual experience is that developers don't know when their code actually uses things from the kennel, thus 90+% of all Docker images I try to run are just broken.

                                  Same here. Docker is the most extreme dependency hell I've witnessed yet. Just like with Windows, DLLs can be managed well if both the devs and the admins are in sync and know what they are doing. But Docker exacerbates this by encouraging the "throw it over the wall" effect and tries to trick both sides into thinking that they don't need to do the diligence necessary in the past - while actually seemingly to require it even more.

                                  1 Reply Last reply Reply Quote 0
                                  • scottalanmillerS
                                    scottalanmiller @stacksofplates
                                    last edited by

                                    @stacksofplates said in Check my 2 min audio theory on Containers:

                                    @matteo-nunziati said in Check my 2 min audio theory on Containers:

                                    @stacksofplates said in Check my 2 min audio theory on Containers:

                                    @scottalanmiller said in Check my 2 min audio theory on Containers:

                                    Containers use shared kernels by definition, that's what makes it a container.

                                    This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

                                    Well go requires the kernel too. But yes for the most is the "from scratch" part which allows more abstraction

                                    Well I mean you have to have a kernel for anything to run. My point was it is technically possible to run a Go app in Docker natively on Windows with no Linux anywhere.

                                    Well sure, but you have a Windows kernel. Why would a Linux kernel be expected to be required to run a Go app? The Windows kernel has a Linux compatibility layer to mimic Linux calls. So we'd expect it to be able to run anything that can run on Linux.

                                    I assume you are using Go as an example because normally you need to compile Go to the platform and if you compile against Linux, then Windows would not be able to run it? But is Docker handling the translation here, or is Windows? What if you ran it on BSD? Or a different architecture, like ARM?

                                    stacksofplatesS 1 Reply Last reply Reply Quote 1
                                    • stacksofplatesS
                                      stacksofplates @scottalanmiller
                                      last edited by

                                      @scottalanmiller said in Check my 2 min audio theory on Containers:

                                      @stacksofplates said in Check my 2 min audio theory on Containers:

                                      @scottalanmiller said in Check my 2 min audio theory on Containers:

                                      Containers use shared kernels by definition, that's what makes it a container.

                                      This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

                                      By definition, though, that makes it not a container in those cases, but a Type 2 hypervisor. And what a bad idea that is. Now we are just automated VirtualBox.

                                      Containers require a shared kernel to be a container. It's the shared kernel that gives the behaviour and performance that makes it interesting. Without that, it's just misleading and crappy.

                                      It is in no way a type 2 hypervisor at this point. OpenShift (Docker) running on physical systems that spin up VMs on hardware. No type 2 anywhere.

                                      scottalanmillerS 1 Reply Last reply Reply Quote 0
                                      • stacksofplatesS
                                        stacksofplates @scottalanmiller
                                        last edited by

                                        @scottalanmiller said in Check my 2 min audio theory on Containers:

                                        @stacksofplates said in Check my 2 min audio theory on Containers:

                                        @matteo-nunziati said in Check my 2 min audio theory on Containers:

                                        @stacksofplates said in Check my 2 min audio theory on Containers:

                                        @scottalanmiller said in Check my 2 min audio theory on Containers:

                                        Containers use shared kernels by definition, that's what makes it a container.

                                        This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

                                        Well go requires the kernel too. But yes for the most is the "from scratch" part which allows more abstraction

                                        Well I mean you have to have a kernel for anything to run. My point was it is technically possible to run a Go app in Docker natively on Windows with no Linux anywhere.

                                        Well sure, but you have a Windows kernel. Why would a Linux kernel be expected to be required to run a Go app? The Windows kernel has a Linux compatibility layer to mimic Linux calls. So we'd expect it to be able to run anything that can run on Linux.

                                        I assume you are using Go as an example because normally you need to compile Go to the platform and if you compile against Linux, then Windows would not be able to run it? But is Docker handling the translation here, or is Windows? What if you ran it on BSD? Or a different architecture, like ARM?

                                        Go statically links the compiled code. Same source code is compiled for Linux or Windows or Mac or BSD. You're making my point with the first statement. There are no kernel dependencies, external libraries, etc with a Go app in the container. The same source could be run across most operating systems (excluding AIX and some other UNIX).

                                        scottalanmillerS 1 Reply Last reply Reply Quote 0
                                        • scottalanmillerS
                                          scottalanmiller @stacksofplates
                                          last edited by scottalanmiller

                                          @stacksofplates said in Check my 2 min audio theory on Containers:

                                          @scottalanmiller said in Check my 2 min audio theory on Containers:

                                          @stacksofplates said in Check my 2 min audio theory on Containers:

                                          @scottalanmiller said in Check my 2 min audio theory on Containers:

                                          Containers use shared kernels by definition, that's what makes it a container.

                                          This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

                                          By definition, though, that makes it not a container in those cases, but a Type 2 hypervisor. And what a bad idea that is. Now we are just automated VirtualBox.

                                          Containers require a shared kernel to be a container. It's the shared kernel that gives the behaviour and performance that makes it interesting. Without that, it's just misleading and crappy.

                                          It is in no way a type 2 hypervisor at this point. OpenShift (Docker) running on physical systems that spin up VMs on hardware. No type 2 anywhere.

                                          A full VM would require a Type 2. The description you gave was of a Type 2, not a Container. If it loads a full VM (including a kernel), it's a Type 2.

                                          It has to be one or the other.

                                          If it doesn't, then it's the shared kernel I mentioned.

                                          stacksofplatesS 1 Reply Last reply Reply Quote 0
                                          • scottalanmillerS
                                            scottalanmiller @stacksofplates
                                            last edited by

                                            @stacksofplates said in Check my 2 min audio theory on Containers:

                                            @scottalanmiller said in Check my 2 min audio theory on Containers:

                                            @stacksofplates said in Check my 2 min audio theory on Containers:

                                            @matteo-nunziati said in Check my 2 min audio theory on Containers:

                                            @stacksofplates said in Check my 2 min audio theory on Containers:

                                            @scottalanmiller said in Check my 2 min audio theory on Containers:

                                            Containers use shared kernels by definition, that's what makes it a container.

                                            This isn't really how Docker works. Docker manages namespaces. If you use "FROM Alpine" then it will share the kernel, but if you write an app in Go and use "FROM scratch" it has zero reliance on a specific kernel. You can also run full VMs in a Docker container which is how Red Hat uses OpenShift to deploy OpenStack VMs.

                                            Well go requires the kernel too. But yes for the most is the "from scratch" part which allows more abstraction

                                            Well I mean you have to have a kernel for anything to run. My point was it is technically possible to run a Go app in Docker natively on Windows with no Linux anywhere.

                                            Well sure, but you have a Windows kernel. Why would a Linux kernel be expected to be required to run a Go app? The Windows kernel has a Linux compatibility layer to mimic Linux calls. So we'd expect it to be able to run anything that can run on Linux.

                                            I assume you are using Go as an example because normally you need to compile Go to the platform and if you compile against Linux, then Windows would not be able to run it? But is Docker handling the translation here, or is Windows? What if you ran it on BSD? Or a different architecture, like ARM?

                                            Go statically links the compiled code. Same source code is compiled for Linux or Windows or Mac or BSD. You're making my point with the first statement. There are no kernel dependencies, external libraries, etc with a Go app in the container. The same source could be run across most operating systems (excluding AIX and some other UNIX).

                                            But your point was that Docker was including a kernel to run a full VM. My point was that it doesn't have to, it uses a shared kernel. So this makes my point, that Go doesn't require a full VM, therefore can use whatever kernel is already there. So it is a shared kernel.

                                            stacksofplatesS 1 Reply Last reply Reply Quote 0
                                            • 1
                                            • 2
                                            • 3
                                            • 4
                                            • 5
                                            • 6
                                            • 4 / 6
                                            • First post
                                              Last post