Group Name: Fill your team name.
Section: Fill your class section.
Team Mates: 1.MUHAMMAD FIRDAUS BIN DARMAWAN (2211901) 2.MUHAMMAD HAFIZUDIN BIN JAMHARI (2217261) 3.AIZUDDIN ISHQAL BIN ABDULLAH (2216207)
- You are allowed to have 3 group members. Exception is allowed IFF (if and only if) you are allowed to have 4 group members if you are a multinational or a multigender group.
- When you complete the project, make sure to submit the repository link of your cloned project. Make sure all the files are as what you aspect in your repository.
- Answer all questions in the README.md, in your own repository. Either use the online VSCode, terminal or github to edit. Answers are expected where you see Fill answer here.
- Learn how to use markdown. https://www.w3schools.io/file/markdown-introduction/
-
First thing you need in doing this project is to have a github account. Make sure to sign up at https://www.github.com
-
The second thing you need is to fork the OS project repository in your own github account.
- Go to https://github.com/joeynor/OSProject and click fork to copy the project into your own repository
- Make sure that the new fork is now in your own repository
Questions:
-
What is the link of the fork OSProject in your repository. (1 mark)
-
How many files and folders are in this repository. (1 mark) Fill answer here.
- The next thing that we will be doing is exploring codespaces. First of all, read about codespaces https://docs.github.com/en/codespaces/overview#what-is-a-codespace
- Then go to the link https://github.com/codespaces and we shall start a new codespace.
- Click on New codespace.
- Choose your own OSProject repository to start your codespace.
- Once you have created you codespace, you will see the following. You might already be familiar with this, since it will look similar to VSCode.
- You will see the README file file. One is a preview of how it looks like on the web, and the other is the editing view in markdown language.
- Edit the README file. Make sure you have your group details correct, ie, group name, section and team members along with their matric IDs.
- Once you have finish editing, click File->Save or ctrl-s to save it.
- After saving, you will notice an M or U next to your file. You will need to commit any changes, whenever you make changes so that it is uploaded to the github repository.
- Click on the source control, hint: its on the left side panel, and it will list down the files that have been modified or updated. Click on commit. It will then ask you "Would you like to stage all your changes and commit them directly?" Just say yes, and a new tab will appear. Type a message to log what you have done, and click on the check mark.
- After that, sync the changes to the main repository.
- Make sure to commit and sync your files to the main repository, or else, your work will be lost since it is not saved into the main repository when you submit your project.
Questions:
- What is default OS used to run the virtual environment for codespaces. (1 mark) Ubuntu Linux
- What are the two options of ram, disk and vcpu configuration you can have in running codespaces . (1 mark)
- 2 core vCPU, 8 GB RAM and 32 GB storage
- 4 core vCPU, 16 GB RAM and 32 GB storage
- Why must we commit and sync our current work on source control? (1 mark) Fill answer here. So that our progress will not be lost.
- Look at the TERMINAL tab. Explore and run commands according to the questions below.
- You can include your answers as images, or cut and paste the output here. If you are cutting and pasting your answers, wrap your answers in the codeblock clause in markdown. For example, if i run the command whoami the the output would look like the one below.
@joeynor ➜ /workspaces/OSProject (main) $ whoami
codespaceQuestions:
Look at the TERMINAL tab. Run the following commands and provide the output here.
- Run the command pwd . (1 mark)
@Juddinnn ➜ /workspaces/OSProject (main) $ whoami
/workspaces/OSProject- Run the command cat /etc/passwd . (1 mark)
root:x:0:0:root:/root:/bin/bash```
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
sys:x:3:3:sys:/dev:/usr/sbin/nologin
sync:x:4:65534:sync:/bin:/bin/sync
games:x:5:60:games:/usr/games:/usr/sbin/nologin
man:x:6:12:man:/var/cache/man:/usr/sbin/nologin
lp:x:7:7:lp:/var/spool/lpd:/usr/sbin/nologin
mail:x:8:8:mail:/var/mail:/usr/sbin/nologin
news:x:9:9:news:/var/spool/news:/usr/sbin/nologin
uucp:x:10:10:uucp:/var/spool/uucp:/usr/sbin/nologin
proxy:x:13:13:proxy:/bin:/usr/sbin/nologin
www-data:x:33:33:www-data:/var/www:/usr/sbin/nologin
backup:x:34:34:backup:/var/backups:/usr/sbin/nologin
list:x:38:38:Mailing List Manager:/var/list:/usr/sbin/nologin
irc:x:39:39:ircd:/var/run/ircd:/usr/sbin/nologin
gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/usr/sbin/nologin
nobody:x:65534:65534:nobody:/nonexistent:/usr/sbin/nologin
_apt:x:100:65534::/nonexistent:/usr/sbin/nologin
systemd-timesync:x:101:101:systemd Time Synchronization,,,:/run/systemd:/usr/sbin/nologin
systemd-network:x:102:103:systemd Network Management,,,:/run/systemd:/usr/sbin/nologin
systemd-resolve:x:103:104:systemd Resolver,,,:/run/systemd:/usr/sbin/nologin
messagebus:x:104:105::/nonexistent:/usr/sbin/nologin
codespace:x:1000:1000::/home/codespace:/bin/bash
sshd:x:105:65534::/run/sshd:/usr/sbin/nologin- Run the command df . (1 mark)
Filesystem 1K-blocks Used Available Use% Mounted on
overlay 32847680 10380932 20772652 34% /
tmpfs 65536 0 65536 0% /dev
shm 65536 8 65528 1% /dev/shm
/dev/root 30298176 24165828 6115964 80% /vscode
/dev/sda1 46127956 96 43752284 1% /tmp
/dev/loop3 32847680 10380932 20772652 34% /workspaces
4. Run the command **du** . ***(1 mark)***
1972 ./images
8 ./.git/logs/refs/heads
12 ./.git/logs/refs/remotes/origin
16 ./.git/logs/refs/remotes
28 ./.git/logs/refs
36 ./.git/logs
4 ./.git/lfs/tmp
8 ./.git/lfs
8 ./.git/info
68 ./.git/hooks
8 ./.git/objects/fd
8 ./.git/objects/79
8 ./.git/objects/a3
8 ./.git/objects/71
8 ./.git/objects/f6
8 ./.git/objects/fa
12 ./.git/objects/14
12 ./.git/objects/3d
12 ./.git/objects/29
12 ./.git/objects/6e
8 ./.git/objects/b9
8 ./.git/objects/4a
12 ./.git/objects/72
8 ./.git/objects/74
12 ./.git/objects/70
12 ./.git/objects/2e
12 ./.git/objects/17
8 ./.git/objects/d8
12 ./.git/objects/c0
4 ./.git/objects/info
12 ./.git/objects/e5
8 ./.git/objects/81
12 ./.git/objects/62
8 ./.git/objects/11
12 ./.git/objects/d2
8 ./.git/objects/e9
12 ./.git/objects/af
16 ./.git/objects/fb
8 ./.git/objects/f2
8 ./.git/objects/96
8 ./.git/objects/1b
8 ./.git/objects/0d
8 ./.git/objects/b6
8 ./.git/objects/3a
8 ./.git/objects/b2
12 ./.git/objects/ff
8 ./.git/objects/83
8 ./.git/objects/86
12 ./.git/objects/64
8 ./.git/objects/52
8 ./.git/objects/ab
8 ./.git/objects/93
8 ./.git/objects/a4
8 ./.git/objects/0b
12 ./.git/objects/73
12 ./.git/objects/90
8 ./.git/objects/c3
8 ./.git/objects/fe
8 ./.git/objects/4f
12 ./.git/objects/b5
8 ./.git/objects/58
8 ./.git/objects/cb
16 ./.git/objects/1c
12 ./.git/objects/44
8 ./.git/objects/fc
8 ./.git/objects/c6
8 ./.git/objects/7b
8 ./.git/objects/24
8 ./.git/objects/60
8 ./.git/objects/eb
8 ./.git/objects/91
8 ./.git/objects/49
8 ./.git/objects/3f
8 ./.git/objects/47
8 ./.git/objects/cd
12 ./.git/objects/bd
1828 ./.git/objects/pack
8 ./.git/objects/20
8 ./.git/objects/a6
8 ./.git/objects/e7
8 ./.git/objects/41
8 ./.git/objects/4b
8 ./.git/objects/04
2500 ./.git/objects
8 ./.git/refs/heads
4 ./.git/refs/tags
12 ./.git/refs/remotes/origin
16 ./.git/refs/remotes
32 ./.git/refs
4 ./.git/branches
2692 ./.git
4688 .- Run the command ls . (1 mark) Fill answer here.
@Juddinnn ➜ /workspaces/OSProject (main) $ ls
README.md images- Run the command ls -asl . (1 mark) Fill answer here.
@Juddinnn ➜ /workspaces/OSProject (main) $ ls -asl
total 40
4 drwxrwxrwx+ 4 codespace root 4096 Jun 27 07:15 .
4 drwxr-xrwx+ 5 codespace root 4096 Jun 27 07:16 ..
4 drwxrwxrwx+ 9 codespace root 4096 Jun 27 07:31 .git
24 -rw-rw-rw- 1 codespace root 21760 Jun 28 01:09 README.md
4 drwxrwxrwx+ 2 codespace root 4096 Jun 27 07:15 images- Run the command free -h . (1 mark) Fill answer here.
@Juddinnn ➜ /workspaces/OSProject (main) $ free -h
total used free shared buff/cache available
Mem: 7.7Gi 1.3Gi 239Mi 64Mi 6.2Gi 6.0Gi
Swap: 0B 0B 0B- Run the command cat /proc/cpuinfo . (1 mark) Fill answer here.
@Juddinnn ➜ /workspaces/OSProject (main) $ cat /proc/cpuinfo
processor : 0
vendor_id : AuthenticAMD
cpu family : 25
model : 1
model name : AMD EPYC 7763 64-Core Processor
stepping : 1
microcode : 0xffffffff
cpu MHz : 3074.428
cache size : 512 KB
physical id : 0
siblings : 2
core id : 0
cpu cores : 1
apicid : 0
initial apicid : 0
fpu : yes
fpu_exception : yes
cpuid level : 13
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall nx mmxext fxsr_opt pdpe1gb rdtscp lm constant_tsc rep_good nopl tsc_reliable nonstop_tsc cpuid extd_apicid aperfmperf pni pclmulqdq ssse3 fma cx16 pcid sse4_1 sse4_2 movbe popcnt aes xsave avx f16c rdrand hypervisor lahf_lm cmp_legacy svm cr8_legacy abm sse4a misalignsse 3dnowprefetch osvw topoext invpcid_single vmmcall fsgsbase bmi1 avx2 smep bmi2 erms invpcid rdseed adx smap clflushopt clwb sha_ni xsaveopt xsavec xgetbv1 xsaves clzero xsaveerptr rdpru arat npt nrip_save tsc_scale vmcb_clean flushbyasid decodeassists pausefilter pfthreshold v_vmsave_vmload umip vaes vpclmulqdq rdpid fsrm
bugs : sysret_ss_attrs null_seg spectre_v1 spectre_v2 spec_store_bypass srso
bogomips : 4890.85
TLB size : 2560 4K pages
clflush size : 64
cache_alignment : 64
address sizes : 48 bits physical, 48 bits virtual
power management:
processor : 1
vendor_id : AuthenticAMD
cpu family : 25
model : 1
model name : AMD EPYC 7763 64-Core Processor
stepping : 1
microcode : 0xffffffff
cpu MHz : 3243.374
cache size : 512 KB
physical id : 0
siblings : 2
core id : 0
cpu cores : 1
apicid : 1
initial apicid : 1
fpu : yes
fpu_exception : yes
cpuid level : 13
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall nx mmxext fxsr_opt pdpe1gb rdtscp lm constant_tsc rep_good nopl tsc_reliable nonstop_tsc cpuid extd_apicid aperfmperf pni pclmulqdq ssse3 fma cx16 pcid sse4_1 sse4_2 movbe popcnt aes xsave avx f16c rdrand hypervisor lahf_lm cmp_legacy svm cr8_legacy abm sse4a misalignsse 3dnowprefetch osvw topoext invpcid_single vmmcall fsgsbase bmi1 avx2 smep bmi2 erms invpcid rdseed adx smap clflushopt clwb sha_ni xsaveopt xsavec xgetbv1 xsaves clzero xsaveerptr rdpru arat npt nrip_save tsc_scale vmcb_clean flushbyasid decodeassists pausefilter pfthreshold v_vmsave_vmload umip vaes vpclmulqdq rdpid fsrm
bugs : sysret_ss_attrs null_seg spectre_v1 spectre_v2 spec_store_bypass srso
bogomips : 4890.85
TLB size : 2560 4K pages
clflush size : 64
cache_alignment : 64
address sizes : 48 bits physical, 48 bits virtual
power management:- Run the command top and type q to quit. (1 mark) Fill answer here.
top - 01:15:24 up 48 min, 0 users, load average: 0.21, 0.17, 0.15
Tasks: 17 total, 1 running, 16 sleeping, 0 stopped, 0 zombie
%Cpu(s): 4.2 us, 4.9 sy, 0.0 ni, 90.9 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
MiB Mem : 7929.6 total, 187.8 free, 1364.7 used, 6377.1 buff/cache
MiB Swap: 0.0 total, 0.0 free, 0.0 used. 6185.1 avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
555 codespa+ 20 0 1312500 86580 45184 S 0.7 1.1 0:04.24 node
575 codespa+ 20 0 21.5g 330236 49920 S 0.7 4.1 0:18.86 node
1 codespa+ 20 0 1136 640 640 S 0.0 0.0 0:00.03 docker-init
7 codespa+ 20 0 7236 1792 1792 S 0.0 0.0 0:00.02 sleep
22 root 20 0 12196 3480 2560 S 0.0 0.0 0:00.00 sshd
354 codespa+ 20 0 2616 1536 1536 S 0.0 0.0 0:00.01 sh
386 root 20 0 2616 1408 1408 S 0.0 0.0 0:00.00 sh
546 codespa+ 20 0 2624 1536 1536 S 0.0 0.0 0:00.01 sh
589 codespa+ 20 0 1240564 52988 41216 S 0.0 0.7 0:00.22 node
1007 codespa+ 20 0 1018004 68844 40576 S 0.0 0.8 0:02.16 node
1027 codespa+ 20 0 1107256 62104 42112 S 0.0 0.8 0:00.93 node - Run the command uname -a. (1 mark) Fill answer here.
@Juddinnn ➜ /workspaces/OSProject (main) $ uname -a
Linux codespaces-2c229e 6.5.0-1022-azure #23~22.04.1-Ubuntu SMP Thu May 9 17:59:24 UTC 2024 x86_64 x86_64 x86_64 GNU/Linux- What is the available free memory in the system. (1 mark) Fill answer here.
6185.1 avail Mem- What is the available disk space mounted on /workspace. (1 mark) Fill answer here.
20772652 (20GB)- Name the version and hardware architecture of the linux Virtual environment. (1 mark) Fill answer here.
Version: Ubuntu 22.04.1
Hardware Architecture: x86_64- What is the difference between ls vs ls -asl. (1 mark) Fill answer here.
ls : Lists the names of files and directories in the current directory.
ls -asl : Lists detailed information about files and directories in the current directory, including all files (even hidden ones), sizes, and permissions.- What is the TLB size of the Virtual CPU. (1 mark) Fill answer here.
TLB size : 2560 4K pages- What is the CPU speed of the Virtual CPU. (1 mark) Fill answer here.
cpu MHz : 3074.428- What is the top running process that consumes the most CPU cycles. (1 mark) Fill answer here.
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
555 codespa+ 20 0 1312500 86580 45184 S 0.7 1.1 0:04.24 node - At the terminal, run a linux instance. By typing the following command.
docker pull debian
docker run --detach -it debian
- This will run the debian container. To check if the debian container is running, type
@joeynor ➜ /workspaces/OSProject (main) $ docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
f65be1987f84 debian "bash" 4 minutes ago Up 4 minutes romantic_jackson- Keep note of the name used by your container, this is usually given random names unless you specify your own name. Now run a bash command on the container. Make sure you use the name of your container instead of the one shown here.
docker exec -i -t romantic_jackson /bin/bash- Create a file on the container. First you must make sure you are in the bash command prompt of the container. The container is new, and does not have any software other than the debian OS. To create a new file, you will need an editor installed. In the bash shell of the container, run the package manager apt-get to install nano text editor.
root@f65be1987f84:~# apt-get update
root@f65be1987f84:~# apt-get install nano
root@f65be1987f84:~# cd /root
root@f65be1987f84:~# nano helloworld.txt-
Edit your helloworld.txt, create your messsage and save by typing ctrl-X. Once saved, explore using the container to see where the file is located. Then exit the shell, by typing exit.
-
Stop the container and run docker ps -a, and restart the container again. Is your file in the container still available?
@joeynor ➜ /workspaces/OSProject (main) $ docker stop romantic_jackson
@joeynor ➜ /workspaces/OSProject (main) $ docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
f65be1987f84 debian "bash" 19 minutes ago Exited (137) 18 seconds ago romantic_jackson
@joeynor ➜ /workspaces/OSProject (main) $ docker restart romantic_jackson- Stop the container and delete the container. What happened to your helloworld.txt?
@joeynor ➜ /workspaces/OSProject (main) $ docker stop romantic_jackson
@joeynor ➜ /workspaces/OSProject (main) $ docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
f65be1987f84 debian "bash" 19 minutes ago Exited (137) 18 seconds ago romantic_jackson
@joeynor ➜ /workspaces/OSProject (main) $ docker rm romantic_jacksonQuestions:
- Are files in the container persistent. Why not?. (1 mark) Fill answer here. The files in the container are not persistent. The helloworld.txt removed when user give docker rm command. It deleted all data stored in container. This happens because container designed to be ephemeral and stateless. Containers use for very short time, disposable and do not retain dta after they are removed.
- Can we run two, or three instances of debian linux? . (1 mark) Fill answer here. Yes we can run multiples instances of debian linux.
- In the previous experiment, you might have notice that containers are not persistent. To make storage persistent, you will need to mount them. At the terminal, create a new directory called myroot, and run a instance of debian linux and mount myroot to the container. Find out the exact path of my root, and mount it as the root folder in the debian container.
- Create a file in /root on the container, the files should also appear in myroot of your host VM.
@joeynor ➜ /workspaces/OSProject (main) $ mkdir myroot
@joeynor ➜ /workspaces/OSProject (main) $ cd myroot/
@joeynor ➜ /workspaces/OSProject/myroot (main) $ pwd
/workspaces/OSProject/myroot
@joeynor ➜ /workspaces/OSProject/myroot (main) $ docker run --detach -it -v /workspaces/OSProject/myroot:/root debianQuestions:
- Check the permission of the files created in myroot, what user and group is the files created in docker container on the host virtual machine? . (2 mark) Fill answer here.
@Juddinnn ➜ /workspaces/OSProject/myroot/myroot (main) $ ls -l /workspaces/OSProject/myroot
total 8
-rw-rw-rw- 1 codespace codespace 13 Jun 28 01:44 helloworld.txt
drwxrwxrwx+ 2 codespace codespace 4096 Jun 28 01:45 myroot- Can you change the permission of the files to user codespace. You will need this to be able to commit and get points for this question. (2 mark)
//use sudo and chown
sudo chown -R codespace:codespace myroot
@Juddinnn ➜ /workspaces/OSProject (main) $ ls -l /workspaces/OSProject/myroot
total 8
-rw-rw-rw- 1 codespace codespace 13 Jun 28 01:44 helloworld.txt
drwxrwxrwx+ 3 codespace codespace 4096 Jun 28 01:50 myroot*** Yes i can change it.***
- Create a directory called webpage in your host machine
- Inside the directory, create a page index.html, with any content you would like
- Then, run the apache webserver and mount the webpage directory to it. Hint:
## the -p 8080:80 flag points the host port 8080 to the container port 80
docker run --detach -v /workspaces/OSProject/webpage:/usr/local/apache2/htdocs/ -p 8080:80 httpd- If it works, codespace will trigger a port assignment and provide a URL for you to access your webpage like the one below.
-
You can also see the Port in the PORTS tab, next to the terminal tab.
-
You can then access your website by adding an index.html towards the end of your url link, like the one below.
Questions:
- What is the permission of folder /usr/local/apache/htdocs and what user and group owns the folder? . (2 mark) Fill answer here.
@Juddinnn ➜ /workspaces/OSProject/webpage (main) $ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
826dd602866a httpd "httpd-foreground" 5 minutes ago Up 5 minutes 0.0.0.0:8080->80/tcp, :::8080->80/tcp elated_hertz
eabbe53cbc80 debian "bash" 16 minutes ago Up 16 minutes nifty_chaum
6a1f356b7c48 debian "bash" 19 minutes ago Up 17 minutes agitated_cori
052c9e6eebbd debian "bash" 26 minutes ago Up 26 minutes trusting_easley
@Juddinnn ➜ /workspaces/OSProject/webpage (main) $ docker exec -it elated_hertz /bin/bash
root@826dd602866a:/usr/local/apache2# - What port is the apache web server running. (1 mark) Apache web server running on port 80.
- What port is open for http protocol on the host machine? (1 mark) Port 8080 is open for HTTP protocol on the host machine.
- In docker, you can create your own private networks where you can run multiple services, in this part, we will create two networks, one called bluenet and the other is rednet
- Run the docker create network to create you networks like the ones below
## STEP 1:
## Create Networks ##
docker network create bluenet
docker network create rednet
## STEP 2: (automatically running)
## Create (1) Container in background called "c1" running busybox image ##
docker run -itd --net bluenet --name c1 busybox sh
docker run -itd --net rednet --name c2 busybox shQuestions:
-
Describe what is busybox and what is command switch --name is for? . (2 mark) . BusyBox is a software suite that provides several Unix utilities in a single executable file. --name switch is used to assign a specific name to a Docker container. Later can be use as reference of the container. Instead the name automatically generated, the container can be named using user-defined name
-
Explore the network using the command
docker network ls, show the output of your terminal. (1 mark)
@Juddinnn ➜ /workspaces/OSProject (main) $ docker network ls
NETWORK ID NAME DRIVER SCOPE
ab38e2674117 bluenet bridge local
11d77014f613 bridge bridge local
1536fc55c92a host host local
f9557666433f mysqlnet bridge local
efd8353d46d9 nodejsnet bridge local
19271bcc1a07 none null local
6bfb417b90c2 rednet bridge local- Using
docker inspect c1anddocker inspect c2inscpect the two network. What is the gateway of bluenet and rednet.? (1 mark) Fill answer here.
@Juddinnn ➜ /workspaces/OSProject (main) $ docker inspect c1 | grep Gateway
"Gateway": "",
"IPv6Gateway": "",
"Gateway": "172.18.0.1",
"IPv6Gateway": "",@Juddinnn ➜ /workspaces/OSProject (main) $ docker inspect c2 | grep Gateway
"Gateway": "",
"IPv6Gateway": "",
"Gateway": "172.21.0.1",
"IPv6Gateway": "",- What is the network address for the running container c1 and c2? (1 mark) Fill answer here.
@Juddinnn ➜ /workspaces/OSProject (main) $ docker inspect c1 | grep IPAddress
"SecondaryIPAddresses": null,
"IPAddress": "",
"IPAddress": "172.18.0.2",@Juddinnn ➜ /workspaces/OSProject (main) $ docker inspect c2 | grep IPAddress
"SecondaryIPAddresses": null,
"IPAddress": "",
"IPAddress": "172.21.0.2",- Using the command
docker exec c1 ping c2, which basically tries to do a ping from container c1 to c2. Are you able to ping? Show your output . (1 mark) Fill answer here.
@Juddinnn ➜ /workspaces/OSProject (main) $ docker exec c1 ping c2
ping: bad address 'c2'- Let's try this again by creating a network to bridge the two containers in the two subnetworks
docker network create bridgenet
docker network connect bridgenet c1
docker network connect bridgenet c2
docker exec c1 ping c2
Questions:
- Are you able to ping? Show your output . (1 mark) Fill answer here. Yes, im able to ping.
@Juddinnn ➜ /workspaces/OSProject (main) $ docker network create bridgenet
nect bridgenet c1
docker network connect bridgenet c2
docker exec c1 ping c25d14c110d82606b1688180ab229cb797590a8cbb545e46b002b70f42c426a6d3
@Juddinnn ➜ /workspaces/OSProject (main) $ docker network connect bridgenet c1
@Juddinnn ➜ /workspaces/OSProject (main) $ docker network connect bridgenet c2
@Juddinnn ➜ /workspaces/OSProject (main) $ docker exec c1 ping c2
@Juddinnn ➜ /workspaces/OSProject (main) $ docker exec c1 ping c2
PING c2 (172.22.0.3): 56 data bytes
64 bytes from 172.22.0.3: seq=0 ttl=64 time=0.156 ms
64 bytes from 172.22.0.3: seq=1 ttl=64 time=0.086 ms
64 bytes from 172.22.0.3: seq=2 ttl=64 time=0.085 ms
64 bytes from 172.22.0.3: seq=3 ttl=64 time=0.109 ms
64 bytes from 172.22.0.3: seq=4 ttl=64 time=0.087 ms
64 bytes from 172.22.0.3: seq=5 ttl=64 time=0.074 ms
64 bytes from 172.22.0.3: seq=6 ttl=64 time=0.104 ms
64 bytes from 172.22.0.3: seq=7 ttl=64 time=0.082 ms
64 bytes from 172.22.0.3: seq=8 ttl=64 time=0.101 ms
64 bytes from 172.22.0.3: seq=9 ttl=64 time=0.079 ms
64 bytes from 172.22.0.3: seq=10 ttl=64 time=0.078 ms
64 bytes from 172.22.0.3: seq=11 ttl=64 time=0.072 ms
64 bytes from 172.22.0.3: seq=12 ttl=64 time=0.103 ms
64 bytes from 172.22.0.3: seq=13 ttl=64 time=0.076 ms
64 bytes from 172.22.0.3: seq=14 ttl=64 time=0.102 ms
64 bytes from 172.22.0.3: seq=15 ttl=64 time=0.060 ms
64 bytes from 172.22.0.3: seq=16 ttl=64 time=0.065 ms
64 bytes from 172.22.0.3: seq=17 ttl=64 time=0.061 ms- What is different from the previous ping in the section above? (1 mark) Fill answer here. In previous attempt, the ping failed because c1 and c2 were not on the same network (bluenet and rednet) and unable to ping each other. By creating a connecting the two subnetwork the both container can ping each other.
This guide will help you set up a simple Node.js website that retrieves a random row from a MySQL database. Both the MySQL server and the Node.js server will run in separate Docker containers on two separate networks. Your job is to make it work by making the two containers in two separate network bridged together.
Create a Docker network to for the two containers. For mysql, call it mysqlnet for nodejs call it nodejsnet .
Run a MySQL container on the created network.
docker run --name mysql-container --network mysqlnet -e MYSQL_ROOT_PASSWORD=rootpassword -e MYSQL_DATABASE=mydatabase -e MYSQL_USER=myuser -e MYSQL_PASSWORD=mypassword -d mysql:latest-
Create a directory for your Node.js application and initialize it.
mkdir nodejs-app cd nodejs-app npm init -y npm install express mysql -
Create a file named
index.jswith the following content:const express = require('express'); const mysql = require('mysql'); const app = express(); const port = 3000; // Create a MySQL connection const connection = mysql.createConnection({ host: 'mysql-container', user: 'myuser', password: 'mypassword', database: 'mydatabase' }); // Connect to MySQL connection.connect((err) => { if (err) { console.error('Error connecting to MySQL:', err); return; } console.log('Connected to MySQL'); }); // Define a route to get a random row app.get('/random', (req, res) => { const query = 'SELECT * FROM mytable ORDER BY RAND() LIMIT 1'; connection.query(query, (err, results) => { if (err) { console.error('Error executing query:', err); res.status(500).send('Server Error'); return; } res.json(results[0]); }); }); // Start the server app.listen(port, () => { console.log(`Server running at http://localhost:${port}`); });
-
Create a Dockerfile for the Node.js application:
# Use the official Node.js image FROM node:14 # Create and change to the app directory WORKDIR /usr/src/app # Copy application dependency manifests to the container image COPY package*.json ./ # Install production dependencies RUN npm install # Copy local code to the container image COPY . . # Run the web service on container startup CMD [ "node", "index.js" ]
-
Build the Docker image for the Node.js application.
docker build -t nodejs-app . -
Run the Node.js container on the same network as the MySQL container.
docker run --name nodejs-container --network nodejsnet -p 3000:3000 -d nodejs-app
You can now test the setup by accessing the Node.js application in your browser or using a tool like curl:
curl http://localhost:3000/randomMake sure you have created the mytable table and populated it with some data in your MySQL database for the above steps to work correctly.
You can use the following SQL commands to create and populate the table (run these commands in the MySQL container):
CREATE TABLE mytable (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(255) NOT NULL,
value VARCHAR(255) NOT NULL
);
INSERT INTO mytable (name, value) VALUES ('example1', 'value1'), ('example2', 'value2'), ('example3', 'value3');You have now set up a Node.js application in a Docker container on nodejsnet netowrk and a MySQL database in another Docker container on mysqlnet network. Now bridge the two network together.
Questions:
- What is the output of step 5 above, explain the error? (1 mark) Fill answer here.
@Juddinnn ➜ /workspaces/OSProject (main) $ curl http://localhost:3000/random
curl: (7) Failed to connect to localhost port 3000: Connection refused- Show the instruction needed to make this work. (1 mark) Fill answer here.
- Make sure to commit all changes on your source control, and make sure your source control is sync to the repository.
- Check your repository link, to see if all the files and answers are included in the repository.
- Submit through italeem, by providing the link to your repository.
- Due by AS STATED IN ITALEEM SYSTEM





