编写Dockerfile制作tomcat镜像,生成镜像名为tomcat:v1,并推送到私有仓库。

1.具体要求如下:

  • 基于rockylinux:8基础镜像;
  • 指定作者为openlab;
  • 安装tomcat服务,暴露8080端口;
  • 设置服务自启动。

总结步骤:基于rockylinux:8,安装Java环境,安装Tomcat,配置,暴露端口,设置启动命令,然后构建镜像,打标签,推送到私有仓库。

宿主机:

创建tomcat目录并进入: mkdir tomcat ; cd tomcat

2.下载所需文件(jdk和tomcat)

apache-tomcat-9.0.102.tar.gz 和 jdk-8u261-linux-x64.rpm

3、编写Dockerfile

FROM rockylinux:8
MAINTAINER openlab <openlab@123.com>

复制代码
FROM rockylinux:8
MAINTAINER openlab <openlab@123.com>
COPY  jdk-8u261-linux-x64.rpm /opt/jdk-8u261-linux-x64.rpm
ADD apache-tomcat-9.0.102.tar.gz /usr/local
RUN yum install -y /opt/jdk-8u261-linux-x64.rpm && ln -s /usr/local/apache-tomcat-9.0.102 /usr/local/tomcat
EXPOSE 8080
CMD ["/usr/local/tomcat/bin/catalina.sh","run"]

4、制作镜像

docker build -t tomcat:v1 .

5、测试镜像

docker run -d --name a1 -p 8080:8080 tomcat:v1

执行后,通过docker ps -a 查看 发现容器未启动

排查方法:
查看日志 docker logs c1
...
library initialization failed - unable to allocate file descriptor table - out of memory
内存溢出,错误原因通常是由于系统资源不足,特别是文件描述符(file descriptor, FD)的数量不足

解决方法:
方法1: 在执行 docker run 命令时添加参数 --ulimit nofile=65535:65535 --ulimit nproc=65535:65535
docker run -d -p 8080:8080 --ulimit nofile=65535:65535 --ulimit nproc=65535:65535 tomcat:v1

方法2: 修改docker服务脚本
vim /usr/lib/systemd/system/docker.service

在`ExecStart`参数值后面追加 `--default-ulimit nofile=65535:65535`,这样就能为创建的容器设置一个较高的文件描述符限制了。

编辑完成后,重新加载systemd的配置,并重启Docker服务:
输入以下命令:
systemctl daemon-reload
systemctl restart docker

然后再进行测试

6.标记镜像为私有仓库格式

docker tag tomcat:v1 192.168.234.15:5050/openlab/tomcat:v1

7.登录到私有仓库并推送镜像

docker login 192.168.234.15:5050

docker push 192.168.234.15:5050/tomcat:v1

推送成功!!!

相关推荐
Waay1 小时前
Linux Shell 知识点考评(一):grep 文本搜索(附答案)
linux·运维·服务器
碧海银沙音频科技研究院2 小时前
基于VMware虚拟机ubuntu开发博通BK7258方法
linux·运维·ubuntu
weixin_514253184 小时前
511-qwen3.5-patch
服务器
谁似人间西林客6 小时前
工厂大脑如何让汽车制造告别“救火式”运维?
运维·汽车·制造
飞飞传输7 小时前
数字化科研提速关键 构建安全可控一体化跨网数据传输体系
大数据·运维·安全
wanhengidc7 小时前
服务器中带宽的重要性
运维·服务器·网络·安全·web安全
189228048617 小时前
H27QCG8T2ELR-BCF海力士H27QCG8UDBIR-BCB
大数据·服务器·人工智能·科技·缓存
云游牧者8 小时前
K8S故障排查三板斧-CSDN博客
运维·docker·云原生·kubernetes·k8s·容器化·故障排查
程序员老邢8 小时前
【技术底稿 32】Nginx 经典大坑复盘:本机公网域名自环代理,导致接口返回首页 / 404 实战排障
java·运维·nginx·前后端分离·技术底稿·后端部署
сокол8 小时前
【网安-Web渗透测试-内网渗透】局域网ARP攻击与DNS劫持
服务器·网络·网络安全