我创建了一个dockerfile和docker-compose,如下所示,它可以在我的容器中创建tomcat的图像并编辑tomcat用户,以便我能够访问管理器gui。
下面的四个文件都与我运行 docker-compose up 命令的文件夹位于同一文件夹中。
docker-compose.yml
version: '2'
services:
tomcat:
build: .
container_name: development
ports:
- 8001:8080
environment:
- spring.profiles.active=development
Dockerfile
FROM tomcat
COPY tomcat-users.xml /usr/local/tomcat/conf/
COPY context.xml /usr/local/tomcat/webapps/manager/META-INF/
CMD ["catalina.sh","run"]
雄猫用户.xml
<?xml version='1.0' encoding='cp1252'?>
<tomcat-users xmlns="http://tomcat.apache.org/xml"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://tomcat.apache.org/xml tomcat-users.xsd"
version="1.0">
<user username="manager" password="pass" roles="manager-gui,manager-script"/>
<user username="admin" password="pass" roles="tomcat"/>
</tomcat-users>
上下文.xml
<?xml version="1.0" encoding="UTF-8"?>
<Context antiResourceLocking="false" privileged="true" >
<!--<Valve className="org.apache.catalina.valves.RemoteAddrValve"
allow="127.d+.d+.d+|::1|0:0:0:0:0:0:0:1" />-->
</Context>
当我运行命令docker-compose up时,它会完美地生成带有tomcat映像的容器,但是现有的tomcat用户.xml和上下文.xml并没有被覆盖。知道我做错了什么来覆盖这两个文件吗?
我想通了。问题是我用来执行构建任务的用户没有足够的权限在这些文件夹中写入内容。 我所做的是将一个 USER 根任务添加到 Dockerfile 中,以便它以 root 身份执行所有命令。
我的 Dockerfile 现在看起来像这样:
FROM tomcat
USER root
COPY tomcat-users.xml /usr/local/tomcat/conf/
COPY context.xml /usr/local/tomcat/webapps/manager/META-INF/
CMD ["catalina.sh","run"]