Docker is a tool for lightweight OS-level virtualization. Docker images are created by performing a build, controlled by a source-level artifact called a Dockerfile. We studied Dockerfiles on GitHub, and-to our great surprisefound that over a quarter of the examined Dockerfiles failed to build (and thus to produce images). To address this problem, we propose Sh i p w r i g h t , a human-in-the-loop system for finding repairs to broken Dockerfiles. Sh i p w r i g h t uses a modified version of the BERT language model to embed build logs and to cluster broken Dockerfiles. Using these clusters and a searchbased procedure, we were able to design 13 rules for making automated repairs to Dockerfiles. With the aid of Sh i p w r i g h t , we submitted 45 pull requests (with a 42.2% acceptance rate) to GitHub projects with broken Dockerfiles. Furthermore, in a "time-travel" analysis of broken Dockerfiles that were later fixed, we found that S h i p w r i g h t proposed repairs that were equivalent to human-authored patches in 22.77% of the cases we studied. Finally, we compared our work with recent, state-of-theart, static Dockerfile analyses, and found that, while static tools detected possible build-failure-inducing issues in 20.6-33.8% of the files we examined, Sh i p w r i g h t was able to detect possible issues in 73.25% of the files and, additionally, provide automated repairs for 18.9% of the files.