generated from jhudsl/OTTR_Template
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path09-troubleshooting.qmd
97 lines (66 loc) · 2.89 KB
/
09-troubleshooting.qmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
# Troubleshooting Tips
```{r, out.width = "100%", echo = FALSE}
ottrpal::include_slide("https://docs.google.com/presentation/d/1T5Lfei2UVou9b0qaUCrWXmkcIwAao-UcN4pHMPEE4CY/edit#slide=id.g2effc5b673e_0_862")
```
```{r panel-setup, include = FALSE}
xaringanExtra::use_panelset()
xaringanExtra::style_panelset_tabs(font_family = "inherit")
```
### Tips for troubleshooting
First remind yourself of the lessons we discussed in the activities in Chapter 3:
```{r, out.width = "100%", echo = FALSE}
ottrpal::include_slide("https://docs.google.com/presentation/d/1T5Lfei2UVou9b0qaUCrWXmkcIwAao-UcN4pHMPEE4CY/edit#slide=id.g30a4ed49e59_0_1326")
```
Then ask yourself the following questions:
- Is there a file that I'm assuming the image/container has that it does not?
- Is there a software package I'm assuming the image/container has that it does not?
- Is there a typo?
- Am I missing a dependency? Make sure the dependency's RUN steps come before the software package that needs it.
- Did the base image I'm pulling from change or a file I'm `COPY`ing change? Do I need to use --no-cache to force a rebuild of everything so the changes are seen?
Now you have the basics of using containers but this is really just the beginning!
As you continue to work with containers you will encounter errors and need to troubleshoot.
This table has a quick rundown on some of the most common errors:
```{r, out.width = "100%", echo = FALSE}
ottrpal::include_slide("https://docs.google.com/presentation/d/1T5Lfei2UVou9b0qaUCrWXmkcIwAao-UcN4pHMPEE4CY/edit#slide=id.g2effc5b673e_0_574")
```
## Activity Instructions {.panelset}
### Docker
There are three Dockerfiles in this folder. Each has something slightly wrong with it.
Use the following `docker build` commands and work to pinpoint the error and fix it using the tips we discussed in this chapter.
#### Bad Dockerfile 1:
```
docker build -f Bad_Dockerfile_1 .
```
#### Bad Dockerfile 2:
```
docker build -f Bad_Dockerfile_2 .
```
#### Bad Dockerfile 3:
```
docker build -f Bad_Dockerfile_3 .
```
### Podman
There are three Dockerfiles in this folder. Each has something slightly wrong with it.
Use the following `podman build` commands and work to pinpoint the error and fix it using the tips we discussed in this chapter.
#### Bad Dockerfile 1:
```
podman build -f Bad_Dockerfile_1 .
```
#### Bad Dockerfile 2:
```
podman build -f Bad_Dockerfile_2 .
```
#### Bad Dockerfile 3:
```
podman build -f Bad_Dockerfile_3 .
```
## SPOILERS: Hints for each of the dockerfiles
<details><summary> Bad_Dockerfile_1 hint </summary>
Carefully look at the name of base image that is being pulled from.
</details>
<details><summary> Bad_Dockerfile_2 hint </summary>
Are the commands that are referenced all things that are installed on the base image?
</details>
<details><summary> Bad_Dockerfile_3 hint </summary>
Is the file that is being `COPY` over specified correctly?
</details>