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

搭建tomcat_Docker搭建Tomcat+Mysql

准备虚拟机虚拟机安装Docker在纯净的Centos镜像上搭建Centos镜像准备虚拟机上拉取Centos镜像:dockerpullcentos创建一个容器运行Cen

准备

  1. 虚拟机
  2. 虚拟机安装Docker
a241d2d11d87c784bbb2125344b1ea81.png

在纯净的Centos镜像上搭建

Centos镜像准备

  • 虚拟机上拉取 Centos 镜像: docker pull centos
  • 创建一个容器运行Centos镜像:docker run -it -d --name mycentos centos /bin/bash

注:这里遇到了一个错误【WARNING: IPv4 forwarding is disabled. Networking will not work.

更改虚拟机文件:vim /usr/lib/sysctl.d/00-system.conf添加如下内容net.ipv4.ip_forward=1重启网络:systemctl restart network

注:这里又衍生一个问题,docker中systemctl无法正常使用。在官网找到如下解决办法

链接:https://forums.docker.com/t/systemctl-status-is-not-working-in-my-docker-container/9075/4

run 镜像的时候用如下语句docker run --privileged -v /sys/fs/cgroup:/sys/fs/cgroup -it -d --name usr_sbin_init_centos centos /usr/sbin/init#注意几点 #1. 必须有--privileged#2. 必须有-v /sys/fs/cgroup:/sys/fs/cgroup#3. 将bin/bash替换成 /usr/sbin/init

最后终于能够正常运行起来一个Centos镜像了。

安装JAVA 环境准备JDK tar包上传到 虚拟机中

  • 使用docker cp 将tar包放入docker容器中

docker cp jdk-11.0.2_linux-x64_bin.tar.gz 41dbc0fbdf3c:/#与linux cp指定用法相同,需要加上container的标识:id或者name

  • 解压tar包

tar -xf jdk-11.0.2_linux-x64_bin.tar.gz -C /usr/local/java/jdk

  • 编辑profile文件 export java环境变量

# /etc/profileexport JAVA_HOME=/usr/local/java/jdk/jdk1.8.0_91export PATH=$JAVA_HOME/bin:$PATHexport CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

  • 运行 source /etc/profile,使环境变量生效
  • 检测是否成功

java --version #结果java 11.0.2 2019-01-15 LTSJava(TM) SE Runtime Environment 18.9 (build 11.0.2+9-LTS)Java HotSpot(TM) 64-Bit Server VM 18.9 (build 11.0.2+9-LTS, mixed mode)

安装Tomcat

a8b68bac691ca6f7a772883da6df4b2c.png
  • 准备好tomcat tar 包上传到虚拟机,并cp到docker容器中
  • 解压到

tar -xf apache-tomcat-8.5.38.tar.gz -C /usr/local/tomcat

  • 设置开机启动,通过使用rc.local文件实现

#rc.local 增加如下代码export JAVA_HOME=/usr/local/java/jdk/jdk-11.0.2/usr/local/tomcat/apache-tomcat-8.5.38/bin/startup.sh

  • 开启tomcat

#到/usr/local/tomcat/apache-tomcat-8.5.38/bin/目录下 运行./startup.sh

  • 检测

curl localhost:8080#返回html源码内容

安装mysql

3b6850a6271db7340b509cbbdbf6c561.png
  • 获取 mysql 的yum源

wget -i -c http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm

  • 安装上面的yum 源

yum -y install mysql57-community-release-el7-10.noarch.rpm

  • yum 安装 mysql

yum -y install mysql-community-server

  • 更改mysql 配置:/etc/my/cnf

validate_password=OFF # 关闭密码验证character-set-server=utf8 collation-server=utf8_general_cilog-error=/var/log/mysqld.log pid-file=/var/run/mysqld/mysqld.pid[client]default-character-set=utf8

  • 获取mysql 初始密码

grep "password" /var/log/mysqld.log#结果:[Note] A temporary password is generated for root@localhost: k:nT

  • 进入到mysql,进行操作

# 进入mysql -u root -p #更改密码ALTER USER 'root'@'localhost' IDENTIFIED BY '111111';# 更改 使mysql可以远端访问update user set host = '%' where user = 'root';

  • 测试,可以使用物理机,使用navicat 对docker中的mysql进行访问

打包容器

  • 放到docker hub上

# 将容器提交成 镜像docker commit -a 'kane' -m 'test' container_id images_name:images_tag# 推到dockerhubdocker push kane0725/tomcat

  • 到处本地tar包

# 导出打成本地 tar 包docker export -o test.tar a404c6c174a2# 将 tar 包导入成镜像docker import test.tar test_images

使用Dockerfile

注:只搭建一个tomcat的镜像

准备工作

  1. 创建一个专门的文件夹,放入jdk 与tomcat的 tar包
  2. 在这个目录下创建Dockerfile文件
  3. centos 基础镜像

文件内容

FROM centosMAINTAINER tomcat mysqlADD jdk-11.0.2 /usr/local/javaENV JAVA_HOME /usr/local/java/ADD apache-tomcat-8.5.38 /usr/local/tomcat8EXPOSE 8080

使用docker build输出结果

[root@localhost dockerfile]# docker build -t tomcats:centos .Sending build context to Docker daemon 505.8 MBStep 1/7 : FROM centos ---> 1e1148e4cc2cStep 2/7 : MAINTAINER tomcat mysql ---> Using cache ---> 889454b28f55Step 3/7 : ADD jdk-11.0.2 /usr/local/java ---> Using cache ---> 8cad86ae7723Step 4/7 : ENV JAVA_HOME /usr/local/java/ ---> Running in 15d89d66adb4 ---> 767983acfacaRemoving intermediate container 15d89d66adb4Step 5/7 : ADD apache-tomcat-8.5.38 /usr/local/tomcat8 ---> 4219d7d611ecRemoving intermediate container 3c2438ecf955Step 6/7 : EXPOSE 8080 ---> Running in 56c4e0c3b326 ---> 7c5bd484168aRemoving intermediate container 56c4e0c3b326Step 7/7 : RUN /usr/local/tomcat8/bin/startup.sh ---> Running in 7a73d0317db3Tomcat started. ---> b53a6d54bf64Removing intermediate container 7a73d0317db3Successfully built b53a6d54bf64

docker build的问题

一定要带上命令后面的 . 否则会报错的"docker build" requires exactly 1 argument(s).

运行一个容器

# 进入容器docker run -it --name tomcats --restart always -p 1234:8080 tomcats /bin/bash#运行tomcat startup.sh/usr/local/tomcat8/bin/startup.sh#结果Using CATALINA_BASE: /usr/local/tomcat8Using CATALINA_HOME: /usr/local/tomcat8Using CATALINA_TMPDIR: /usr/local/tomcat8/tempUsing JRE_HOME: /usr/local/java/Using CLASSPATH: /usr/local/tomcat8/bin/bootstrap.jar:/usr/local/tomcat8/bin/tomcat-juli.jarTomcat started.

使用docker compose

安装 docker compose

官方:https://docs.docker.com/compose/install/

我选择的方式是pip安装

# 安装pip install docker-compose# 检测docker-compose --version# -----------------------docker-compose version 1.23.2, build 1110ad0

编写docker-compose.yml

# 这个yml文件 搭建一个mysql 一个 tomcat的容器version: "3" services: mysql: container_name: mysql image: mysql:5.7 restart: always volumes: - ./mysql/data/:/var/lib/mysql/ - ./mysql/conf/:/etc/mysql/mysql.conf.d/ ports: - "6033:3306" environment: - MYSQL_ROOT_PASSWORD=******** tomcat: container_name: tomcat restart: always image: tomcat ports: - 8080:8080 - 8009:8009 links: - mysql:m1 #连接数据库镜像

注:

  • volumn里必须是路径,不能指定文件
  • tomcat指定外部conf的时候一直创建不成功,不知道为什么,提示

tomcat | Feb 20, 2019 2:23:29 AM org.apache.catalina.startup.Catalina loadtomcat | WARNING: Unable to load server configuration from [/usr/local/tomcat/conf/server.xml]tomcat | Feb 20, 2019 2:23:29 AM org.apache.catalina.startup.Catalina starttomcat | SEVERE: Cannot start server. Server instance is not configured.tomcat exited with code 1

  • 运行命令

注:必须在yml文件的目录下下执行

docker-compose up -d# 结果----------查看docker container-------[root@localhost docker-compose]# docker ps -aCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES1a8a0165a3a8 tomcat "catalina.sh run" 7 seconds ago Up 6 seconds 0.0.0.0:8009->8009/tcp, 0.0.0.0:8080->8080/tcp tomcatddf081e87d67 mysql:5.7 "docker-entrypoint..." 7 seconds ago Up 7 seconds 33060/tcp, 0.0.0.0:6033->3306/tcp mysql



推荐阅读
  • Tomcat安装与配置教程及常见问题解决方法
    本文介绍了Tomcat的安装与配置教程,包括jdk版本的选择、域名解析、war文件的部署和访问、常见问题的解决方法等。其中涉及到的问题包括403问题、数据库连接问题、1130错误、2003错误、Java Runtime版本不兼容问题以及502错误等。最后还提到了项目的前后端连接代码的配置。通过本文的指导,读者可以顺利完成Tomcat的安装与配置,并解决常见的问题。 ... [详细]
  • 面试经验分享:华为面试四轮电话面试、一轮笔试、一轮主管视频面试、一轮hr视频面试
    最近有朋友去华为面试,面试经历包括四轮电话面试、一轮笔试、一轮主管视频面试、一轮hr视频面试。80%的人都在第一轮电话面试中失败,因为缺乏基础知识。面试问题涉及 ... [详细]
  • (九)Docker常用安装
    一、总体步骤1、搜索镜像2、拉取镜像3、查看镜像4、启动镜像5、停止镜像6、移除镜像二、安装tomcat1、dockerhub上面查找tomcat镜像 dockersearchto ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • Servlet多用户登录时HttpSession会话信息覆盖问题的解决方案
    本文讨论了在Servlet多用户登录时可能出现的HttpSession会话信息覆盖问题,并提供了解决方案。通过分析JSESSIONID的作用机制和编码方式,我们可以得出每个HttpSession对象都是通过客户端发送的唯一JSESSIONID来识别的,因此无需担心会话信息被覆盖的问题。需要注意的是,本文讨论的是多个客户端级别上的多用户登录,而非同一个浏览器级别上的多用户登录。 ... [详细]
  • 本文介绍了5个基本Linux命令行工具的现代化替代品,包括du、top和ncdu。这些替代品在功能上进行了改进,提高了可用性,并且适用于现代化系统。其中,ncdu是du的替代品,它提供了与du类似的结果,但在一个基于curses的交互式界面中,重点关注占用磁盘空间较多的目录。 ... [详细]
  • Annotation的大材小用
    为什么80%的码农都做不了架构师?最近在开发一些通用的excel数据导入的功能,由于涉及到导入的模块很多,所以开发了一个比较通用的e ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • Webmin远程命令执行漏洞复现及防护方法
    本文介绍了Webmin远程命令执行漏洞CVE-2019-15107的漏洞详情和复现方法,同时提供了防护方法。漏洞存在于Webmin的找回密码页面中,攻击者无需权限即可注入命令并执行任意系统命令。文章还提供了相关参考链接和搭建靶场的步骤。此外,还指出了参考链接中的数据包不准确的问题,并解释了漏洞触发的条件。最后,给出了防护方法以避免受到该漏洞的攻击。 ... [详细]
  • Jboss的EJB部署描述符standardjaws.xml配置步骤详解
    本文详细介绍了Jboss的EJB部署描述符standardjaws.xml的配置步骤,包括映射CMP实体EJB、数据源连接池的获取以及数据库配置等内容。 ... [详细]
  • 本文介绍了在Android Studio中使用命令行build gradle的方法,并解决了一些常见问题,包括手动配置gradle环境变量和解决External Native Build Issues的方法。同时提供了相关参考文章链接。 ... [详细]
author-avatar
李小欠儿724_579
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有