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

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介:

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

相关实践学习
小试牛刀,一键部署电商商城
SAE 仅需一键,极速部署一个微服务电商商城,体验 Serverless 带给您的全托管体验,一起来部署吧!
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
1月前
|
负载均衡 网络协议 算法
一文读懂什么是Nginx?它能否实现IM的负载均衡?
Nginx(及其衍生产品)是目前被大量使用的服务端反向代理和负载均衡方案,从某种意义上来讲,Nginx几乎是低成本、高负载Web服务端代名词。 如此深入人心的Nginx,很多人也想当然的认为,在IM或消息推送等场景下是否也能使用Nginx来解决负载均衡问题? 另外,即时通讯网的论坛和QQ群里也经常有人问起,Nginx是否能支持TCP、UDP、WebSocket的负载
79 4
|
5月前
|
负载均衡 算法 搜索推荐
Nginx 常用的负载均衡算法
【10月更文挑战第17天】在实际应用中,我们需要根据具体的情况来选择合适的负载均衡算法。同时,还可以结合其他的优化措施,如服务器健康检查、动态调整权重等,来进一步提高负载均衡的效果和系统的稳定性。
203 59
|
2天前
|
负载均衡 算法 应用服务中间件
Nginx长连接负载均衡详细说明以及案例
本文详细介绍了Nginx长连接负载均衡的配置与原理。长连接(Keepalive)允许客户端和服务器保持连接,减少建立和关闭连接的开销。Nginx支持多种负载均衡算法,如轮询、IP哈希等。通过在Nginx配置文件中使用`upstream`模块和`keepalive`指令,可以实现长连接负载均衡,从而提高系统的性能和响应速度。示例配置展示了如何设置后端服务器组、长连接数及HTTP/1.1协议,确保连接复用,降低延迟。
|
2月前
|
前端开发 应用服务中间件 nginx
docker安装nginx,前端项目运行
通过上述步骤,你可以轻松地在Docker中部署Nginx并运行前端项目。这种方法不仅简化了部署流程,还确保了环境的一致性,提高了开发和运维的效率。确保按步骤操作,并根据项目的具体需求进行相应的配置调整。
197 25
|
3月前
|
弹性计算 负载均衡 网络协议
ECS中实现nginx4层7层负载均衡和ALB/NLB原SLB负载均衡
通过本文的介绍,希望您能深入理解并掌握如何在ECS中实现Nginx四层和七层负载均衡,以及如何使用ALB和NLB进行高效的负载均衡配置,以提高系统的性能和可靠性。
296 9
|
4月前
|
缓存 负载均衡 算法
如何配置Nginx反向代理以实现负载均衡?
如何配置Nginx反向代理以实现负载均衡?
|
3月前
|
负载均衡 算法 应用服务中间件
Nginx的负载均衡
Nginx 是一款高性能的Web服务器与反向代理服务器,支持负载均衡功能,能有效提升系统性能与可靠性。其负载均衡策略包括基于轮询和权重的分配方法,以及IP哈希、最小连接数等算法,可根据实际需求灵活选择。
229 5
|
3月前
|
负载均衡 前端开发 应用服务中间件
负载均衡指南:Nginx与HAProxy的配置与优化
负载均衡指南:Nginx与HAProxy的配置与优化
227 3
|
3月前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
149 3
|
4月前
|
应用服务中间件 网络安全 nginx
轻松上手Nginx Proxy Manager:安装、配置与实战
Nginx Proxy Manager (NPM) 是一款基于 Nginx 的反向代理管理工具,提供直观的 Web 界面,方便用户配置和管理反向代理、SSL 证书等。本文档介绍了 NPM 的安装步骤,包括 Docker 和 Docker Compose 的安装、Docker Compose 文件的创建与配置、启动服务、访问 Web 管理界面、基本使用方法以及如何申请和配置 SSL 证书,帮助用户快速上手 NPM。
1598 1