I am running Jenkins in a docker container and Jenkins tries to run my maven build. As part of the build, the docker maven plugin instructs it to build a docker image.
That part of the POM is below.
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>0.3.8</version>
<configuration>
<imageName>example</imageName>
<baseImage>java:latest</baseImage>
<skipDockerBuild>false</skipDockerBuild>
<cmd>["java", "-jar", "myLogThread-jar-with-dependencies.jar"]</cmd>
<resources>
<resource>
<directory>target/</directory>
<include>config.properties</include>
</resource>
<resource>
<directory>${project.build.directory}</directory>
<include>myLogThread-jar-with-dependencies.jar</include>
</resource>
</resources>
</configuration>
</plugin>
The maven build runs until it attempts to build the image, at which point the following error message is spat out:
[INFO] Building image example
[INFO] I/O exception (java.io.IOException) caught when processing request to {}->unix://localhost:80: Permission denied
I can go into the correct directory and the Dockerfile is there.
I can also run sudo docker build .
and it will build the image with no issues.
Why is the maven build failing? What request is being made to localhost:80? How can I correct this so that maven can build my image?
Note: I have mounted the docker socket and binary in this container
As mentioned above by Rajith Delantha, this solved the problem for me:
Add:
DOCKER_OPTS=' -G jenkins'
directly in/etc/default/docker
.Then restart docker service by
sudo service docker restart
.This can be resolved by adding
DOCKER_HOST
environment variable in Jenkins.Setup your docker daemon like this:
Jenkins Jobs (Inject environment variables):
I met the issue at bamboo-agent, but I assume the same holds for jenkins.
Add the user running maven to the docker group. Then restart docker AND the service running maven. Group changes are not loaded while the services are running. So in my case:
I had the same problem, but in my local machine.
I've got it after reading this comment in Github thread: https://github.com/docker/compose/issues/1214#issuecomment-256774629
It says:
I had a similar issue when I didn't have the docker daemon running - restart the Docker toolbox and it looks much happier now
after making sure
docker ps
works from the same user that runsmvn
I still had the same problem. it looks like a bug due to special characters in the image name. I resolved it by removing the dash sign (-) (or any special characters) from the docker image name.try set the repository to deferent name and check.