Docker的安装和镜像管理并利用Docker容器实现nginx的负载均衡、动静分离

简介:

Docker的安装

一、Docker的概念

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。

46be2302e6664297a39258873ac65c0c.png

二、安装Docker

1.检查内核版本

# uname -r      查看当前linux得版本信息

Docker要求CentOS7最低内核版本为3.1版本

2. 关闭防火墙和selinux

# systemctl stop firewalld

# setenforce 0

3.使用yum安装docker

# yum install -y docker

# systemctl start docker         开启docker服务

_______________________________________________________________________________

# ps aux | grep docker           查看docker服务

# docker search nginx            查看nginx镜像

(# docker pull centos:7  )     下载官方的 CentOS 镜像到本地

# docker pull docker.io/nginx     下载nginx镜像

# docker pull docker.io/tomcat    下载tomcat镜像

由于Docker官方服务器在海外,因此不推荐使用,这里建议使用网易蜂巢镜像中心

https://c.163.com/hub#/m/home/

4.同步时间

# date 022019512017

5.安装docker -devel

# yum -y install docker-devel

6.下载镜像

# docker pull hub.c.163.com/library/tomcat:latest

# docker pull hub.c.163.com/library/nginx:latest

# docker pull hub.c.163.com/public/centos:7.0

bead46b7f5f79053f24e05b37c39f8b7.png

# docker images                                 查看下载好的镜像

6fcb63e2da6ffae47b7efaafef2e5ae4.png

这时创建容器会报错,因此需要修改/usr/lib/sysctl.d/00-system.conf

添加如下代码:net.ipv4.ip_forward=1
重启network服务

# systemctl restart network

 

在docker配置负载均衡

 

创建nginx容器

# docker tag db079554b4d2 nginx:111    修改镜像名字

# docker run -ti -d -p 80:80 hub.c.163.com/library/nginx /bin/bash       创建nginx容器

# docker ps (-a)                                     查看docker运行中(所有)容器    

f679671c65d67c8349e2aa69c98b5a07.png

# docker exec -ti a62119e032b3 /bin/bash      进入后台容器并提供bash

# /usr/sbin/nginx       启动nginx服务

# apt-get update        升级vim

# apt-get install vim        安装vim

 

在宿主机的根目录创建两个tomcat的发布目录# mkdir www1 www2

558d32e4679dc3877a122ff7c8303ae4.png

创建tomcat容器1&2(利用Xshell复制ssh渠道功能再开两个窗口)

# docker run -ti -d -P -h tomcat1 -v /www1:/usr/local/tomcat/webapps/ROOThub.c.163.com/library/tomcat /bin/bash

# docker ps –a

18093308a75e6f38beba387ab074a92e.png

# docker exec -ti  f6725eb67195 /bin/bash

# bin/startup.sh

# docker run -ti -d -h tomcat2 -P -v /www2:/usr/local/tomcat/webapps/ROOT hub.c.163.com/library/tomcat /bin/bash

5757ef165b3a0844c0a402f89613ca2c.png

# docker ps -a

# docker exec -ti 5157b553106d /bin/bash

# bin/startup.sh

使用# docker ps -a在宿主机查看映射的端口

ee3d7aa7efbb0e0fa583b9ca17a753da.png

为tomcat1&2映射的目录写下测试页面,我在这里使用tomcat1和tomcat2作为页面内容区分

# cd /www1

# vim index.jsp

# cd /www2

# vim index.jsp

9e203ebbcdbdaffdda18e0ddee412b13.png

在nginx容器中进行负载均衡配置

# vim /etc/nginx/nginx.conf

upstream zeyu {

    server 192.168.81.60:32771;

    server 192.168.81.60:32772;

}

a743635f29781aecb74ac5465b1598ae.png

# vim /etc/nginx/conf.d/default.conf

   # location / {

   #     root   /usr/share/nginx/html;

   #     index  index.html index.htm;

   # }

    location ~ {

        proxy_pass http://zeyu;

        }

90cbf6120f6faf4e8f1d4e81f3f3a505.png

# pkill nginx

# /usr/sbin/nginx

验证

a4643ed71031e67b620304aa69ff4a17.png


Docker的动静分离

在Docker的nginx容器中修改

# vim /etc/nginx/conf.d/default.conf

    location / {

        root   /usr/share/nginx/html;

        index  index.html index.htm;

    }

    location ~*\.jsp$ {

        proxy_pass http://zeyu;

        proxy_redirect off;

        }

dfb0273466f5fc9ee69e416c2277174a.png

# pkill nginx

# /usr/sbin/nginx

浏览器访问验证

访问IP/index.html为nginx欢迎页面

48dc9b692d9a6b02437ad68aeda7ac88.png

访问IP/index.jsp为tomcat测试页面1&2

f6757cae555f0d0c3868d1d689de8e34.png



本文转自 Mr_sheng 51CTO博客,原文链接:http://blog.51cto.com/sf1314/1980353

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
相关文章
|
3月前
|
JavaScript Docker 容器
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
381 100
|
3月前
|
缓存 安全 Linux
优化Docker镜像大小的多阶段构建实践
优化Docker镜像大小的多阶段构建实践
314 99
|
3月前
|
缓存 Docker 容器
优化Docker镜像大小的五个实用技巧
优化Docker镜像大小的五个实用技巧
332 98
|
2月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
504 5
|
3月前
|
Java Docker 容器
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
206 8
|
7月前
|
负载均衡 前端开发 应用服务中间件
Tomcat的负载均衡和动静分离(与nginx联动)
总的来说,负载均衡和动静分离是提高Web应用性能的两个重要手段。通过合理的配置和使用,我们可以让Web应用更好地服务于用户。
242 21
|
缓存 负载均衡 算法
解读 Nginx:构建高效反向代理和负载均衡的秘密
解读 Nginx:构建高效反向代理和负载均衡的秘密
298 2
|
负载均衡 前端开发 应用服务中间件
负载均衡指南:Nginx与HAProxy的配置与优化
负载均衡指南:Nginx与HAProxy的配置与优化
737 3
|
负载均衡 算法 应用服务中间件
nginx自定义负载均衡及根据cpu运行自定义负载均衡
nginx自定义负载均衡及根据cpu运行自定义负载均衡
372 1
|
运维 负载均衡 算法
SLB与NGINX的异同是什么
SLB与NGINX的异同是什么
1874 2