diff --git a/content/img/14/cover.png b/content/img/14/cover.png new file mode 100644 index 0000000..08caaf8 Binary files /dev/null and b/content/img/14/cover.png differ diff --git a/content/img/14/docker-vs-vm.png b/content/img/14/docker-vs-vm.png new file mode 100644 index 0000000..6f6e4c1 Binary files /dev/null and b/content/img/14/docker-vs-vm.png differ diff --git a/content/img/14/mind-blowing.png b/content/img/14/mind-blowing.png new file mode 100644 index 0000000..10d164c Binary files /dev/null and b/content/img/14/mind-blowing.png differ diff --git a/content/posts/13-time-machine-ep3.md b/content/posts/13-time-machine-ep3.md index 79a2c32..42723c9 100644 --- a/content/posts/13-time-machine-ep3.md +++ b/content/posts/13-time-machine-ep3.md @@ -1,9 +1,9 @@ --- -title: "How to deploy your website but it's 2010 - [Time Machine-E3]" +title: "How to deploy your website, but it's 2010 - Time Machine Ep3" date: 2023-11-14T21:48:59+01:00 summary: "In this article, we will deploy our website as if it were 2010. We will use virtual machines, web servers and some old tools to hammer things out" -tags: [Time machine] -categories: [Just chatting] +tags: [Time machine, Virtual Machine] +categories: [Time Machine, Virtual Machine] weight: "990" showToc: true draft: true diff --git a/content/posts/14-time-machine-ep4.md b/content/posts/14-time-machine-ep4.md index be56db1..f61c6de 100644 --- a/content/posts/14-time-machine-ep4.md +++ b/content/posts/14-time-machine-ep4.md @@ -1,22 +1,280 @@ --- -title: "How to deploy your website but it's 2015 - Time Machine Ep4" +title: "How to deploy your website but it's 2015 - Time Machine Ep3" date: 2023-11-14T22:06:47+01:00 summary: "In this article, we will deploy our website as if it were 2015. We will use container, web servers and some old tools to hammer things out" tags: [Time machine] -categories: [Just chatting] +categories: [Container] weight: "889" showToc: true -draft: true +draft: false cover: - image: "../img/13/cover.jpeg" + image: "../img/14/cover.png" --- ## Day 1 Playing with Docker -## Day 2 Containerizing Our Website +It's 2015, and you're listening to [Take Me to Church](https://www.youtube.com/watch?v=MYSVMgRr6pw) by Hozier. + +Many technologies are gaining ground. Virtual machines have become a standard and are everywhere. There are many hypervisors to choose from, and nerds are starting to have their first homelabs at reasonable prices. + +Amidst this sea of possibilities and new technologies, you also have the opportunity to play with Virtual Private Servers (VPS) somewhere. It's awesome – these are virtual machines hosted on some cloud provider. You no longer have to worry about creating the virtual machine on your hardware or installing the operating system. Now you can choose a VPS of the size you need, and with a couple of clicks, everything is up and running, ready to have fun. + +In these years, the first tools for Infrastructure as Code (IaC) are also emerging. Everything seems automatable and writable in a handful of minutes. + +But the technology that fascinates you the most is the one with the blue whale: Docker. + +Your friends are hesitant to learn it, but to you, it seems incredibly cool for the goals that Docker sets + +data:image/s3,"s3://crabby-images/a5540/a55408c8cdaea17f4d10c8881d1f00789795c2b0" alt="docker-vs-vm" + +What's the difference between a container and a virtual machine? + +Containers are lighter than virtual machines because they share the host operating system's kernel. In contrast, virtual machines carry their own kernel. This difference in overhead allows containers to start in seconds, whereas virtual machines may take several minutes to complete the startup phase. + +But what on earth are these containers? + +Containers are abstractions that enable us to isolate and make our applications portable. + +At the core of virtualization technologies are two features of the Linux kernel: + +Control Groups: to limit the resources a single process can consume. Through this feature, we can restrict the RAM, CPU, or disk write that a process uses. +Network Namespace: through namespaces, it's possible to isolate a process within an operating system, limiting its visibility. There are different types of namespaces: User, PID, Network, Mount, IPC, UTS. +Too much theory, do you want to get your hands dirty? + +You install Docker on your Linux machine and start playing. + +Run your first Nginx container: + +```docker run -d -p 80:80 --name first-nginx nginx``` + + +And with this command, a whole new world opens up for you. Notice that upon the first execution, the Docker daemon pulls the Nginx image from Docker Hub, and within a few seconds, your container is ready. You've mapped the container's port 80 to the host's port 80. + +Does it mean I have a web server listening on port 80 of my host? + +You decide to perform a curl + +```curl locahost``` + +And you receive as a response that of your newly created web server + +```html + + +
+If you see this page, the nginx web server is successfully installed and +working. Further configuration is required.
+ +For online documentation and support please refer to
+nginx.org.
+Commercial support is available at
+nginx.com.
Thank you for using nginx.
+ + +``` + +Indeed, it's that easy. What used to involve creating a virtual machine, installing Nginx, and downloading all the necessary packages can now be accomplished so easily. The use of containers, facilitated by tools like Docker, has significantly simplified and streamlined the process, making it more accessible and efficient. + +data:image/s3,"s3://crabby-images/37b93/37b9304eb07744b6f621f3da1190227d54bdcba7" alt="mind-blowing" + +You discover that you could achieve the same result using Docker Compose, a tool that, using the YAML format, allows you to configure your containers. + +The previously executed command could be converted into something like + +```yaml +version: '3' + +services: + first-nginx: + image: nginx + ports: + - "80:80" + container_name: first-nginx + restart: always +``` + +Absolutely! Your friends definitely need to give it a try! Docker and Docker Compose can revolutionize the way applications are developed, deployed, and managed. It's a game-changer in terms of simplicity and efficiency in the world of containerization + +## Day 2 Containerizing your Website + + +You're a hands-on person, and when you want to learn a new technology, you create a little project to understand how it works. + +You ponder and rethink: what's a use case where you can employ a technology like Docker? + +Finally, the lightbulb moment: hosting your website! Currently, it's on a virtual machine, served to the world through Nginx. The goal is to take that architecture and convert it into something that allows you to use Docker. + +The architecture serving your website and those of your friends currently looks like this: + +[TO DO: insert architecture] + +Your website is on a virtual machine. + +The Dockerfile for your application: + +```Dockerfile +FROM klakegg/hugo:0.107.0-ubuntu as build-step +WORKDIR /app +COPY . . +RUN hugo + +FROM nginx:alpine-slim +COPY --from=build-step /app/public /usr/share/nginx/html +EXPOSE 80 +``` + +This Dockerfile will be placed in the [Git repository](https://github.com/ettoreciarcia/personal-website-hugo) where your website's code is located. + +And then proceed to build your Docker image with the command: + +```docker build -t personal-website:1.0 .``` + +We're good to go, the build is ready. You can view your new image by running the command: + +```docker image ls``` + +Let's try it right away! + +## Day 3 Push your image to a registry + +For now, your image is local. For convenience, you decide to push it to the Docker Hub registry. + +Use the following command to log in to your Docker Hub account from the command line. Replace