热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

web重启tomcat_使用docker构建jdk镜像和web服务镜像

一、构建jdk镜像FROMcentosWORKDIRhomelilyADDjdk-8u91-linux-x64.tar.gzhomelilyRUNmvjdk1.8.0_91jdk8

一、构建jdk镜像

FROM centos

WORKDIR /home/lily

ADD jdk-8u91-linux-x64.tar.gz /home/lily

RUN mv jdk1.8.0_91 jdk8

ENV JAVA_HOME=/home/lily/jdk8

ENV PATH=$JAVA_HOME/bin:$PATH

二、构建web服务镜像

(一)、基于jdk的镜像构建tomcat镜像

FROM web/jdk8

ADD apache-tomcat-8.0.20.tar.gz /home/lily

RUN mv apache-tomcat-8.0.20 tomcat8

WORKDIR /home/lily/tomcat8/bin

EXPOSE 8080

(二)、基于镜像运行容器

1、映射成宿主机的默认端口

docker run -it -P web/tomcat /bin/bash

[root@localhost web2]# docker ps

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

1e6a9261bf95 web/tomcat "/bin/bash" 6 minutes ago Up 6 minutes 0.0.0.0:32768->8080/tcp youthful_shockley

外界访问web服务:http://192.168.85.10:32768/

2、上述启动个容器只要已退出,那么服务就停止了,所以让容器在后台运行。但是想要访问web服务tomcat,那么容器里面的

tomcat必须有个前台进程

docker run -d -p 8888:8080 web/tomcat /home/lily/tomcat8/bin/catalina.sh run

解释:

(1)-d代表容器放在后台运行

(2)-p 8888:8080代表把宿主机的8888端口映射为容器的8080

(3)web/tomcat是我们新构建的镜像

(4)/home/lily/tomcat8/bin/catalina.sh run是我们运行的命令

3、启动构建平台资源共享的服务

docker run -d -p 8888:8080 -v /home/demo:/home/lily/tomcat8/webapps/demo web/tomcat /home/lily/tomcat8/bin/catalina.sh run

-v /home/demo:/home/lily/tomcat8/webapps代表属主机的目录/home/demo和容器/home/lily/tomcat8/webapps共享资源

[root@localhost demo]# docker ps

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

e4cd4754a89e web/tomcat "/home/lily/tomcat..." About a minute ago Up About a minute 0.0.0.0:8888->8080/tcp heuristic_panini

连接进去容器:docker exec -it heuristic_panini /bin/bash

注意:如果发现执行下面命令创建volume在容器中没有写权限的时候

docker run -it -v /usr/local/webapp:/webapp centos /bin/bash

进入容器

cd webapp

touch a.txt

touch: cannot touch 'a': Permission denied

解决方法:

1:setenforce 0(立刻生效,不需要重启操作系统)

2:修改/etc/selinux/config文件中的SELINUX=disabled ,然后重启生效

3985e30650cd1f85cad814f7796c0539.png


推荐阅读
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 标题: ... [详细]
  • 在CentOS/RHEL 7/6,Fedora 27/26/25上安装JAVA 9的步骤和方法
    本文介绍了在CentOS/RHEL 7/6,Fedora 27/26/25上安装JAVA 9的详细步骤和方法。首先需要下载最新的Java SE Development Kit 9发行版,然后按照给出的Shell命令行方式进行安装。详细的步骤和方法请参考正文内容。 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • 集合的遍历方式及其局限性
    本文介绍了Java中集合的遍历方式,重点介绍了for-each语句的用法和优势。同时指出了for-each语句无法引用数组或集合的索引的局限性。通过示例代码展示了for-each语句的使用方法,并提供了改写为for语句版本的方法。 ... [详细]
  • Servlet多用户登录时HttpSession会话信息覆盖问题的解决方案
    本文讨论了在Servlet多用户登录时可能出现的HttpSession会话信息覆盖问题,并提供了解决方案。通过分析JSESSIONID的作用机制和编码方式,我们可以得出每个HttpSession对象都是通过客户端发送的唯一JSESSIONID来识别的,因此无需担心会话信息被覆盖的问题。需要注意的是,本文讨论的是多个客户端级别上的多用户登录,而非同一个浏览器级别上的多用户登录。 ... [详细]
  • ShiftLeft:将静态防护与运行时防护结合的持续性安全防护解决方案
    ShiftLeft公司是一家致力于将应用的静态防护和运行时防护与应用开发自动化工作流相结合以提升软件开发生命周期中的安全性的公司。传统的安全防护方式存在误报率高、人工成本高、耗时长等问题,而ShiftLeft提供的持续性安全防护解决方案能够解决这些问题。通过将下一代静态代码分析与应用开发自动化工作流中涉及的安全工具相结合,ShiftLeft帮助企业实现DevSecOps的安全部分,提供高效、准确的安全能力。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
author-avatar
手机用户2502878113
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有