(¦b®aÆ[¬Ý = 0%¡A¦b®ÕÆ[¬Ý = 100%)
100% ¦b®ÕÆ[¬Ý¤é´Á¤Î®É¶¡¡G
¦Û¥Ñ¿ï¾Ü¡AÂI¿ï¥H¤U¦a°ÏÆ[¬Ý¿ì¤½®É¶¡¤Î¦ì¸m
½Ò®É¡G 18 ¤p®É
¨É¥Î®É´Á¡G 6 ¬P´Á¡C¶i«×¥Ñ±z±±¨î¡A¥i§Ö¥iºC¡C
½Ò°ó¿ý¼v¾É®v¡GNorman
¦b®Õ§K¶O¸ÕÚ»¡Gº 1 ¤p®É¡A½ÐP¹q¥H¤W¦aÂI»P¥»¤¤¤ß¾û¹w¬ù¡C
¥»½Òµ{´£¨Ñ¦b®Õ§K¶O«Ú»¤Î¾É®v¸ÑµªªA°È¡C
(¦b®aÆ[¬Ý = 100%¡A¦b®ÕÆ[¬Ý = 0%)
100% ¦b®aÆ[¬Ý¤é´Á¤Î®É¶¡¡G
¨C¤Ñ 24 ¤p®É¥þ¤ÑÔ¤£¦¸¼Æ¦aÆ[¬Ý
¾Ç¶O¡G$2,680 ³ø¦W phone
¹q¸Ü¡G2332-6544
½Ò®É¡G 18 ¤p®É
¨É¥Î®É´Á¡G 6 ¬P´Á¡C¶i«×¥Ñ±z±±¨î¡A¥i§Ö¥iºC¡C
½Ò°ó¿ý¼v¾É®v¡GNorman
¦b®Õ§K¶O¸ÕÚ»¡Gº 1 ¤p®É¡A½ÐP¹q¥H¤W¦aÂI»P¥»¤¤¤ß¾û¹w¬ù¡C
¥»½Òµ{´£¨Ñ¾É®v¸ÑµªªA°È¡C
·í§Aªì¨B¾Ç²ß¤F Docker ªº¥\¯à«á¡A³q¹L¶i¤@¨B¤F¸Ñ Docker I«áªº§Þ³N¡A¥i¥H¥O§A§ó©ö´x´¤Ãö©ó Docker ªºÀ³¥Î§Þ¥©¡C¥»½Òµ{°£¤F±´°Q¤@¨Ç Docker I«á§Þ³N¤§¥~¡A¤]·|¤¶²ÐºÞ²z¦h¹L¤@Ó¹B¦æ Docker ªº¥D¾÷®É¡A¥i¥HÀ³¥Îªº§Þ³N¡C ¥»½Òµ{·|¯A¤Îªº§Þ³N¥]¬A¡G
- Ãö©óÀɮרt²Î¤è±¡ADocker ¦p¦ó¥Î ¡§layers¡¨ ¥h«Ø¥ß container ¤Î image ªºÀɮרt²Î¡C³o¼ËªºÀɮרt²Î¦³¬Æ»ò¦n³B¡A¥H¦ÜÀ³¥Î®É¦pªG¹B¥Î³o¨Ç¦n³B¡C
- Ãö©ó±¾¸üÀɮפ象ABind Mount ¤Î Volume ªº¤À§O¡C¦ó®ÉÀ³¹B¥Î¥¦Ì¤Î¦p¦ó¿ï¾Ü¨º¤@Ó¥hÀ³¥Î¡C¥t¥~¤]·|²³æ¤¶²Ð¦p Docker ¶}±Ò¤F¹B¥Î SELinux ®É¡A¹ï±¾¸üÀɮצ³¬Æ»ò¼vÅT¡C
- Ãö©ó°O¿ý (logging) ¤è±¡ADocker ¦p¦ó¨ú±o¨C¤@Ó Container ªº°O¿ý¸ê®Æ¡C°O¿ýÀɦs©ñ¦b¨ºùØ¡A¦³¬Æ»ò®æ¦¡¥i¿ï¾Ü¥H¤Î¦p¦óÁקK²Ö¿n¤Ó¦h°O¿ý¦Ó¦û¥Î¤Ó¦hÀx¦sªÅ¶¡¡C
- Ãö©óºôµ¸¤è±¡ADocker ¦p¦ó¬° Container «Ø¥ß¤º³¡µêÀÀºôµ¸¡C¦p¦ó«È¨î§A»Ýnªººôµ¸Àô¹Ò (¦p«ü©w IP address, DNS settings ¡K. µ¥µ¥) ¥h´£¨Ñµ¹ Containers ¨Ï¥Î¡C¥t¥~¤]·|²³æ¤¶²Ð·í Docker ¥D¾÷¤º«Ø¨¾¤õÀð®É¡A¦³¨º¨ÇµêÀÀºôµ¸·|¨ü¼vÅT¤Î¦p¦ó¸Ñ¨M¡C
- Ãö©ó¸ê·½ºÞ²z¤è±¡ADocker ¦p¦óºÞ²z¨C¤@Ó Container ªº¥i¥Î¸ê·½ (¦p CPU, °O¾ÐÅé ¡K µ¥µ¥)¡C¦p¦ó¥i¥H³]©w³o¨Ç¨î¡C
- Ãö©ó«Ø¥ß Container ¤è±¡A·í¦b¤¬Ápºô¤W§ä¤£¨ì§A»Ýn¦b Container ¹B¦æªºµ{§Ç (Process) Ãè¹³ÀÉ (image) ®É¡A¦p¦ó¦Û¤v«È¨î¤@ÓÃè¹³ÀÉ¡C½Òµ{¤¤ªº¨Ò¤l·|¥Ü½d¥Ñ³Ìªì¤H¤â«Ø¥ß Container ¥Î§@´ú¸Õ¡Aª½¦Ü´ú¸Õ¦¨¥\«á¡A¨Ï¥Î Docker Compose ¥h¦Û°Ê¤Æ«Ø¥ß Container ¥H¤Î¦³»Ýn®É§@¥X§ó§ïªº¾ãÓ¹Lµ{¡C¥t¥~¡A¦p¦]¯S§O»Ýn¦Ón¦b¤@Ó Container ¤¤°õ¦æ¦h©ó¤@Óµ{§Ç®É¡A³oÓ Container ¥i¥H¦p¦ó«Ø¥ß¡C¥H¤Î¡A¦p¦ó¥i¥H¥O¨ä¤¤¤@Ó¦]·N¥~°h¥X¤Fªºµ{§Ç¥i¥H¦Û°Ê«±Ò¡C
- Ãö©ó«Ø¥ß¦hÓ°õ¦æ¬Û¦Pµ{§Çªº Containers ¤è±¡A¦p¦ó¥i¥H²³æ¦a«ü¥O Docker ¥h¼W¥[©Î´î¤Ö³o¨Ç Container ªº¼Æ¶q¡C½Òµ{¤¤·|¥Hºô¶¦øªA¾¹ªº Container §@¨Ò¤l¡A¦P®É¤]·|¥Ü½d¦p¦ó«Ø¥ß¤@Ó²³æªººô¶t¸ü¥¿Å¾¹ (Load Balancer) ªº container ¥h¦Û°Ê¤À°tºô¶n¨D (web request) ¦Ü¥¿¦b¹B¦æ¤¤ªº Containers¡CµL½×¼W¥[©Î´î¤Öºô¶¦øªA¾¹¡Acontainer ¤]¤£¥Î«·s³]©w¹B¦æ¤¤ªºt¸ü¥¿Å¾¹¡C
- Ãö©óºÞ²z¦h©ó¤@³¡¹B¦æ Docker ªº¥D¾÷¤è±¡A¦p¦ó¥i¥H¦b¤@³¡ Docker ¥D¾÷³q¹L°õ¦æ ¡§docker¡¨ «ü¥O¡A¥hºÞ²z¦Û¤v©Î¥ô¦ó¤@³¡§A«ü©wªº Docker ¥D¾÷¡C³Ì«á¡A¥»½Òµ{¤]·|²³æ¤¶²Ð Docker Swarm (¸s) ªº¥\¯à¡A³oÓ¥\¯à¯S§O¤§³B¬O¥i¥H¥Î³æ¤@Ó«ü¥O¥h¥O¦h³¡ Docker ¥D¾÷¦P®É«Ø¥ß©ÎºÞ²z°õ¦æ¬Û¦Pµ{§Çªº Containers¡C
¦]¬°¥»½Òµ{¯A¤Î¨¾¤õÀð©M SELinux¡A¦]¦¹·|¨Ï¥Î¹w³]¤w±Ò°Ê¨¾¤õÀð©M SELinuxªº CentOS ¤W¹B¦æªº Docker§@¬°¥Ü½d¨Ò¤l¡C
½Òµ{¦WºÙ¡G |
¶i¶¥ Linux Docker ³nÅé®e¾¹ (Container) ½Òµ{ - ²ºÙ¡GAdvanced Linux Docker Training Course |
½Òµ{®É¼Æ¡G | 18 ¤p®É (¦@ 6 °ó) |
¾A¦X¤H¤h¡G | ¦³¾Ç²ß©Î¨Ï¥Î¹L Docker Container ¦Ó¥B¦³¿³½ì¹ï¦¹§Þ³N¤ÎÀ³¥Î§@¶i¤@¨B»{ÃѪº¤H¤h |
±Â½Ò»y¨¥¡G | ¥H¼sªF¸Ü¬°¥D¡A»²¥H^»y |
½Òµ{µ§°O¡G | ¥»¤¤¤ß¾É®v¿Ë¦Û½s¼g^¤å¬°¥Dµ§°O¡A¦Ó³¡¥÷^¤å¦rªþ¦³¤¤¤å¹ï·Ó¡C |
½Òµ{¦WºÙ¡G¶i¶¥ Linux Docker ³nÅé®e¾¹ (Container) ½Òµ{ - ²ºÙ¡GAdvanced Linux Docker Training Course |
1. Image and Container Layers
1.1 Overview
1.2 Layers in a Container
1.2.1 Basic Mechanism for the R/W Layer
1.2.2 Examining the Layers in a Container
1.2.3 Exercise for Examining the Working of Container¡¦s Layers
1.2.4 Notes about Accessing R/W Layer in a Container
1.3 Layers in an Image
1.3.1 Basic Mechanism
1.3.2 Exercise for Examining Images Layers
1.3.3 Image Layers when Building with Dockerfile
1.3.4 Exercise for Examining Build Cache
1.3.5 Exercise for Clearing / Disabling Build Cache
1.3.6 Exercise for Multi-Stage Builds
2. Ways for Providing Storage Space to a Container
2.1 Overview
2.2 Pros and Cons for Using Layers
2.3 Using Volumes
2.3.1 Mechanism of Volumes
2.3.2 Exercise for Using Volumes
2.3.3 Pros and Cons for Using Volumes
2.4 Using Bind Mount
2.4.1 Mechanism of Bind Mount
2.4.2 Exercise for Using Bind Mounts
2.4.3 Pros and Cons for Using Bind Mount
2.5 Using tmpfs
3. Logging, Resource Control and Linux Permission
3.1 Logging
3.1.1 Overview
3.1.2 Container Logs
3.1.3 json-file Logging Driver
3.1.4 local Logging Driver
3.1.5 journald Logging Driver
3.1.6 Setting up Default Logging Driver
3.1.7 Exercise for Container Logs
3.2 Resource Control
3.2.1 Overview
3.2.2 Mechanism for Resource Control
3.2.3 Options for CPU Resource Control
3.2.4 Options for Memory Resource Control
3.2.5 Exercise for Resource Control
3.3 About Permission and Linux Namespaces
3.3.1 Overview
3.3.2 How Docker uses Various Types of Linux Namespace
3.3.3 Exercise for Permission and Linux Namespaces
3.3.4 Brief Notes about SELinux
4. Networking
4.1 Overview
4.2 Container Networking and Network Drivers
4.3 bridge Network Driver
4.3.1 Basic Characteristics and Mechanisms
4.3.2 The default bridge Network ¡§bridge¡¨
4.3.3 Creating Custom bridge Network
4.3.4 Publish Ports
4.3.5 Exposed Port
4.3.6 Container Settings for Name Resolution
4.4 host Network Driver
4.5 null Network Driver
4.5.1 Basic Characteristics
4.6 Exercise for Container Networking
4.7 Brief Notes about Firewall Rules Generated by Docker
5. Creating a Custom Image for Your Application
5.1 Create an Image for a Single Application
5.1.1 Use an Intermediate Containers to Create an Image for Your Application
5.1.2 Use Dockerfile to Create Image for Your Application
5.2 Create an Image for Running Two Different Applications
5.2.1 Overview
5.2.2 Problems for Running two Applications in a Container
5.2.3 About Supervisor
5.2.4 Exercise for Using Supervisor
6. Docker Compose
6.1 Overview
6.2 Docker Compose Configuration File
6.2.1 YAML
6.2.2 Top Level Element version
6.2.3 Top Level Element services
6.2.4 Top Level Element volumes
6.2.5 Top Level Element networks
6.3 Docker Compose Command
6.3.1 Commonly Used Child Commands for Starting / Stopping Containers.
6.3.2 Child Commands for Preparing Containers
6.3.3 Child Commands for Maintaining a Project
6.3.4 Child Commands for Maintaining a Specific Service
6.3.5 Child Commands for Maintaining a Specific Container
6.3.6 Child Commands for General Information
6.4 Exercise for Basic Usage of Docker Compose
6.5 Scaling
6.5.1 Overview
6.5.2 Exercise for Scaling
7. Docker Context and Docker API
7.1 Overview
7.2 Accessing a Remote Docker Daemon
7.2.1 Overview
7.2.2 Through the Unix Socket of the Remote Docker Daemon
7.2.3 Configure the Remote Docker Daemon to Listen to a TCP port
7.3 Docker Context
7.3.1 Overview
7.3.2 Exercise for Setting Up / Using a Docker Context
7.4 Docker API
7.4.1 Overview
7.4.2 Exercise for Simple Illustration of Using Docker API
8. Using Docker Swarm Mode
8.1 Overview
8.2 Exercise for Simple Illustration of Using Swarm
8.3 Brief Notes About Deploying a Stack
8.4 Brief Notes about How Routing Mesh Works
8.4.1 Mechanism of Load Balancing for External Networks
8.4.2 Mechanism of Load Balancing within a Custom Overlay Network
Appendix 1 : Basic Installation and Setup
- Installing VMware Workstation Player
- Installing CentOS (Using CentOS Stream 9 as example)
- Installing / Setup SSH Tools
- Putty
- Nano
- WinSCP
- Installing Docker
- Create another VM by Cloning (Optional)
- About Assigning a Static IP Addresss (Optional)
- Cleaning Up after Finishing Exercises in Each Chapter (Optional)
Appendix 2 : Brief Notes about Image ID, Diff ID, Chain ID and Cache ID
Appendix 3 : docker-squash
- Installing python-squash
- Preparing an Image for Squashing
- Squashing the Image