Docker学习之搭建JavaWeb环境进阶篇

简介: 上一篇文章中,简单了学习了一下在Docker环境中搭建JavaWeb环境,其实这时候已经是一个全新的镜像了,就是我们的Ghost系统一样,装配了各式各样的软件一样,以后使用的时候直接安装镜像即可。这时候我们需要做的就是把配置完成JavaWeb环境Docker打包一下,封装成一个更新的镜像环境。

上一篇文章中,简单了学习了一下在Docker环境中搭建JavaWeb环境,其实这时候已经是一个全新的镜像了,就是我们的Ghost系统一样,装配了各式各样的软件一样,以后使用的时候直接安装镜像即可。这时候我们需要做的就是把配置完成JavaWeb环境Docker打包一下,封装成一个更新的镜像环境。

打包镜像

首先我们进入之前启动的容器:

[root@iZ2ze74fkxrls31tr2ia2fZ ~]# docker attach centos
[root@b5a21b26c111 ROOT]

b5a21b26c111是产生的容器ID,然后我们执行以下命令:

docker commit  b5a21b26c111  centos-java

配置完成以后执行命令docker images,就可以看到REPOSITORY名为centos-java的镜像了。

上传镜像

阿里云官方网站链接(进入后自行创建用户):https://dev.aliyun.com/search.html

然后依次创建命名空间-镜像仓库。

登录阿里云docker registry:

docker login --username=admin@52itstyle.com registry.cn-hangzhou.aliyuncs.com

将镜像推送到registry:

docker tag <IMAGE ID> registry.cn-hangzhou.aliyuncs.com/itstyle/images:centos-java

docker push   registry.cn-hangzhou.aliyuncs.com/itstyle/images:centos-java

Push成功以后如下显示:
001

运行容器

查看镜像:

docker images

创建并启动容器:

docker run -i -t -v /root/software/:/mnt/software/ <IMAGE ID> /bin/bash

如果想启动的时候设置内存:

docker run -i -t -m 100m --memory-swap=100m  -v /root/software/:/mnt/software/ <IMAGE ID> /bin/bash

创建时指定容器名字:

docker run -i -t --name test -m 100m --memory-swap=100m  -v /root/software/:/mnt/software/ <IMAGE ID> /bin/bash

Docker 1.10提供了对容器资源限制的动态修改能力。例如,我们可以通过下面命令把容器内存限制调整到1GB

docker update -m 1024m test
docker restart test

查看运行容器:

docker ps

重命名容器:

docker rename <原容器NAMES> <新容器NAMES>

配置完成以后,我们启动容器中的Tomcat。

负载均衡

openresty配置:

server {
        listen       80;
        server_name  docker.52itstyle.com;

        charset utf-8;

        location / {
            default_type text/html;
            proxy_pass http://docker;
        }

    }
    upstream docker {
        server  172.18.0.2:8080  weight=1  max_fails=2 fail_timeout=30s;
        server  172.18.0.3:8080  weight=1  max_fails=2 fail_timeout=30s;
    }

最终访问地址(见标题变化):http://docker.52itstyle.com/

资源配置小知识

内存限制

Docker 提供的内存限制功能有以下几点:

  • 容器能使用的内存和交换分区大小。
  • 容器的核心内存大小。
  • 容器虚拟内存的交换行为。
  • 容器内存的软性限制。
  • 是否杀死占用过多内存的容器。
  • 容器被杀死的优先级

内存限制相关的参数:
执行docker run命令时能使用的和内存限制相关的所有选项如下。

  • -m,--memory 内存限制,格式是数字加单位,单位可以为 b,k,m,g。最小为 4M
  • --memory-swap 内存+交换分区大小总限制。格式同上。必须必-m设置的大
  • --memory-reservation 内存的软性限制。格式同上
  • --oom-kill-disable 是否阻止 OOM killer 杀死容器,默认没设置
  • --oom-score-adj 容器被 OOM killer 杀死的优先级,范围是[-1000, 1000],默认为 0
  • --memory-swappiness 用于设置容器的虚拟内存控制行为。值为 0~100 之间的整数
  • --kernel-memory 核心内存限制。格式同上,最小为 4M

作者: 小柒

出处: https://blog.52itstyle.com

分享是快乐的,也见证了个人成长历程,文章大多都是工作经验总结以及平时学习积累,基于自身认知不足之处在所难免,也请大家指正,共同进步。

目录
相关文章
|
1月前
|
应用服务中间件 Linux nginx
在虚拟机Docker环境下部署Nginx的步骤。
以上就是在Docker环境下部署Nginx的步骤。需要注意,Docker和Nginix都有很多高级用法和细节需要掌握,以上只是一个基础入门级别的教程。如果你想要更深入地学习和使用它们,请参考官方文档或者其他专业书籍。
111 5
|
1月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
339 5
|
3月前
|
缓存 Ubuntu Docker
Ubuntu环境下删除Docker镜像与容器、配置静态IP地址教程。
如果遇见问题或者想回滚改动, 可以重启系统.
281 16
|
5月前
|
消息中间件 监控 Docker
Docker环境下快速部署RabbitMQ教程。
就这样,你成功地用魔法召唤出了RabbitMQ,还把它和你的应用程序连接了起来。现在,消息会像小溪流水一样,在你的系统中自由流淌。别忘了,兔子们不喜欢孤独,他们需要你细心的关怀,不时地监控它们,确保他们的世界运转得井井有条。
343 18
|
4月前
|
弹性计算 关系型数据库 Nacos
低配阿里云 ECS 如何 docker 环境部署 NACOS : 单机版模式
NACOS 单机版 Docker 安装指南。使用指定端口和 custom.env 配置文件启动 Nacos 服务,适用于 2.X 版本,包含 gRPC 支持及 MySQL 数据源配置。 -e MODE=standalone \
408 5
|
5月前
|
消息中间件 监控 Docker
Docker环境下快速部署RabbitMQ教程。
至此,这次神秘而简明的部署之旅告一段落。祝你在利用RabbitMQ打造消息队列时,一切顺风顺水!
235 8
|
4月前
|
存储 缓存 Serverless
【Azure Container App】如何在Consumption类型的容器应用环境中缓存Docker镜像
在 Azure 容器应用的 Consumption 模式下,容器每次启动均需重新拉取镜像,导致冷启动延迟。本文分析该机制,并提出优化方案:使用 ACR 区域复制加速镜像拉取、优化镜像体积、设置最小副本数减少冷启动频率,或切换至 Dedicated 模式实现镜像缓存,以提升容器启动效率和应用响应速度。
129 0