(八)Docker Swarm 搭建 Nginx 服务

1. Nginx镜像

docker-nginx的root路径是:/usr/share/nginx/html

[root@Thor _data]# docker run -dit --name nginx -P -v my_volume:/usr/share/nginx/html nginx:latest

[root@Thor _data]# ls
50x.html  aliyun.jpg  index.html
[root@Thor _data]# docker volume inspect my_volume
[
    {
        "Driver": "local",
        "Labels": {},
        "Mountpoint": "/var/lib/docker/volumes/my_volume/_data",
        "Name": "my_volume",
        "Options": {},
        "Scope": "local"
    }
]
[root@Thor _data]# docker container ls
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES
462b38e12ef2        nginx:latest        "nginx -g 'daemon ..."   22 minutes ago      Up 22 minutes       0.0.0.0:32770->80/tcp    nginx
[root@Thor _data]# 

http://10.86.10.214:32770/aliyun.jpg

2. Docker Swarm 搭建 Nginx 集群

[root@Thor volumes]# docker volume ls
DRIVER              VOLUME NAME
local               my_volume
[root@Thor volumes]# 
[root@Thor volumes]# 
[root@Thor volumes]# clear
[root@Thor volumes]# 
[root@Thor volumes]# docker network ls
NETWORK ID          NAME                DRIVER              SCOPE
996812025ea1        bridge              bridge              local
3996a5cca929        docker_gwbridge     bridge              local
7f779eaf12fc        host                host                local
00ea96ba8181        my-net              bridge              local
bab9f30b8cbc        none                null                local
[root@Thor volumes]# 
[root@Thor volumes]# docker swarm init
Swarm initialized: current node (nawy26ys5d8t35poovzca09gf) is now a manager.

To add a worker to this swarm, run the following command:

    docker swarm join \
    --token SWMTKN-1-08lysjmybp1f2gi2z3myfy4rqjm5n0jy9h4ah3ap1uv7x16c9z-5plyyozoy6ty6p3vfmc9838y8 \
    10.86.10.214:2377

To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.

[root@Thor volumes]# docker network ls
NETWORK ID          NAME                DRIVER              SCOPE
996812025ea1        bridge              bridge              local
3996a5cca929        docker_gwbridge     bridge              local
7f779eaf12fc        host                host                local
i9hsx10utcfw        ingress             overlay             swarm
00ea96ba8181        my-net              bridge              local
bab9f30b8cbc        none                null                local
[root@Thor volumes]# docker node ls
ID                           HOSTNAME  STATUS  AVAILABILITY  MANAGER STATUS
nawy26ys5d8t35poovzca09gf *  Thor      Ready   Active        Leader
[root@Thor volumes]# docker service ls
ID  NAME  MODE  REPLICAS  IMAGE
[root@Thor volumes]# docker service create --replicas 3 -p 1992:80 --mount type=volume,source=my_volume,destination=/usr/share/nginx/html --name nginx nginx:latest
vb34nrb7rc86rag1hkw20dcia
[root@Thor volumes]# docker service ls
ID            NAME   MODE        REPLICAS  IMAGE
vb34nrb7rc86  nginx  replicated  1/3       nginx:latest
[root@Thor volumes]# docker service ls
ID            NAME   MODE        REPLICAS  IMAGE
vb34nrb7rc86  nginx  replicated  3/3       nginx:latest
[root@Thor volumes]# 
[root@Thor volumes]# docker service ls
ID            NAME   MODE        REPLICAS  IMAGE
vb34nrb7rc86  nginx  replicated  3/3       nginx:latest
[root@Thor volumes]# 
[root@Thor volumes]# docker container ls
CONTAINER ID        IMAGE                                                                           COMMAND                  CREATED             STATUS              PORTS                    NAMES
3f4fc77d40f5        nginx@sha256:1b109555ad28bb5ec429422ee136c5f5ab5ee6faaeb518836a5c9a3b6436a1bd   "nginx -g 'daemon ..."   48 seconds ago      Up 47 seconds       80/tcp                   nginx.3.25xb0q9ai3a0n1egw3bbu2ofk
e5275a076b6e        nginx@sha256:1b109555ad28bb5ec429422ee136c5f5ab5ee6faaeb518836a5c9a3b6436a1bd   "nginx -g 'daemon ..."   48 seconds ago      Up 48 seconds       80/tcp                   nginx.1.xg5lm0izzbnpp54j7grqliv8h
7573ec039bbd        nginx@sha256:1b109555ad28bb5ec429422ee136c5f5ab5ee6faaeb518836a5c9a3b6436a1bd   "nginx -g 'daemon ..."   49 seconds ago      Up 48 seconds       80/tcp                   nginx.2.t55k1n9yxqdw3xdony4ypt5bs
bb8e12657b50        google/cadvisor                                                                 "/usr/bin/cadvisor..."   3 weeks ago         Up 3 weeks          0.0.0.0:8080->8080/tcp   cadvisor
[root@Thor volumes]# 
[root@Thor volumes]# docker service ls
ID            NAME   MODE        REPLICAS  IMAGE
vb34nrb7rc86  nginx  replicated  3/3       nginx:latest
[root@Thor volumes]# docker service --help

Usage:  docker service COMMAND

Manage services

Options:
      --help   Print usage

Commands:
  create      Create a new service
  inspect     Display detailed information on one or more services
  ls          List services
  ps          List the tasks of a service
  rm          Remove one or more services
  scale       Scale one or multiple replicated services
  update      Update a service

Run 'docker service COMMAND --help' for more information on a command.
[root@Thor volumes]# docker service ps
"docker service ps" requires exactly 1 argument(s).
See 'docker service ps --help'.

Usage:  docker service ps [OPTIONS] SERVICE

List the tasks of a service
[root@Thor volumes]# docker service ps nginx
ID            NAME     IMAGE         NODE  DESIRED STATE  CURRENT STATE               ERROR  PORTS
xg5lm0izzbnp  nginx.1  nginx:latest  Thor  Running        Running about a minute ago         
t55k1n9yxqdw  nginx.2  nginx:latest  Thor  Running        Running about a minute ago         
25xb0q9ai3a0  nginx.3  nginx:latest  Thor  Running        Running about a minute ago         
[root@Thor volumes]# docker service inspect nginx
[
    {
        "ID": "vb34nrb7rc86rag1hkw20dcia",
        "Version": {
            "Index": 12
        },
        "CreatedAt": "2018-09-01T06:50:00.889456834Z",
        "UpdatedAt": "2018-09-01T06:50:00.890534652Z",
        "Spec": {
            "Name": "nginx",
            "TaskTemplate": {
                "ContainerSpec": {
                    "Image": "nginx:latest@sha256:1b109555ad28bb5ec429422ee136c5f5ab5ee6faaeb518836a5c9a3b6436a1bd",
                    "Mounts": [
                        {
                            "Type": "volume",
                            "Source": "my_volume",
                            "Target": "/usr/share/nginx/html"
                        }
                    ],
                    "DNSConfig": {}
                },
                "Resources": {
                    "Limits": {},
                    "Reservations": {}
                },
                "RestartPolicy": {
                    "Condition": "any",
                    "MaxAttempts": 0
                },
                "Placement": {},
                "ForceUpdate": 0
            },
            "Mode": {
                "Replicated": {
                    "Replicas": 3
                }
            },
            "UpdateConfig": {
                "Parallelism": 1,
                "FailureAction": "pause",
                "MaxFailureRatio": 0
            },
            "EndpointSpec": {
                "Mode": "vip",
                "Ports": [
                    {
                        "Protocol": "tcp",
                        "TargetPort": 80,
                        "PublishedPort": 1992,
                        "PublishMode": "ingress"
                    }
                ]
            }
        },
        "Endpoint": {
            "Spec": {
                "Mode": "vip",
                "Ports": [
                    {
                        "Protocol": "tcp",
                        "TargetPort": 80,
                        "PublishedPort": 1992,
                        "PublishMode": "ingress"
                    }
                ]
            },
            "Ports": [
                {
                    "Protocol": "tcp",
                    "TargetPort": 80,
                    "PublishedPort": 1992,
                    "PublishMode": "ingress"
                }
            ],
            "VirtualIPs": [
                {
                    "NetworkID": "i9hsx10utcfw3q6dxgx4stp7t",
                    "Addr": "10.255.0.4/16"
                }
            ]
        },
        "UpdateStatus": {
            "StartedAt": "0001-01-01T00:00:00Z",
            "CompletedAt": "0001-01-01T00:00:00Z"
        }
    }
]
[root@Thor volumes]# 

转载于:https://www.cnblogs.com/walkinginthesun/p/9570862.html

### 回答1: Docker Swarm 是 Docker 官方提供的容器编排工具,可以用于管理多个 Docker 容器的集群。Nginx 是一款高性能的 Web 服务器和反向代理服务器,可以用于部署 Web 应用和负载均衡等场景。在 Docker Swarm 中,可以通过部署多个 Nginx 容器来实现 Nginx 集群的部署。 具体步骤如下: 1. 准备 Docker Swarm 环境,包括 Docker Engine 和 Docker Swarm。 2. 创建一个 Docker Swarm 集群,可以使用 docker swarm init 命令初始化一个 Swarm 集群。 3. 创建一个 Nginx 镜像,可以使用 Dockerfile 文件构建一个 Nginx 镜像,或者使用已有的 Nginx 镜像。 4. 创建一个 Docker Stack,可以使用 docker stack deploy 命令创建一个 Stack,其中包含多个 Nginx 服务。 5. 配置 Nginx 服务,可以使用 Docker Compose 文件配置 Nginx 服务,包括端口映射、负载均衡等。 6. 启动 Nginx 服务,可以使用 docker stack deploy 命令启动 Nginx 服务。 7. 验证 Nginx 集群是否正常工作,可以使用 curl 命令访问 Nginx 服务,或者使用浏览器访问 Nginx 服务。 以上就是使用 Docker Swarm 部署 Nginx 集群的基本步骤。 ### 回答2: Docker Swarm是Docker官方推出的一个容器编排工具,可以用于管理多个Docker节点组成的集群,实现容器的自动部署、扩展、升级等功能。Nginx是一款高性能的Web服务器软件,可以用于反向代理、负载均衡、静态文件缓存等应用场景,常用于构建Web服务集群。下面将介绍如何使用Docker Swarm部署Nginx集群。 1. 环境准备 首先需要在多台计算机上安装DockerDocker Swarm,可以参考官方文档进行安装。安装完成后,需要将多台计算机加入到一个Docker Swarm集群中,可以使用Docker Swarm的初始化命令和加入命令完成。在集群中选择一台作为Swarm Manager,其他节点作为Swarm Worker。 2. 创建Docker镜像 在部署Nginx集群之前,需要先创建NginxDocker镜像。可以使用Dockerfile构建镜像,或者使用Docker Hub上已有的Nginx镜像。在这里使用已有的Nginx镜像,并根据自己的要求修改Nginx配置文件。 3. 创建Docker服务 创建NginxDocker服务,需要指定镜像名称、服务名称、副本数量、端口映射、挂载目录等参数。在创建服务时可以指定网络,此处需要创建一个Overlay网络,用于集群内部容器间通信。创建完成后,Docker Swarm会自动将服务的副本运行在集群内部的Worker节点上。 4. 部署Nginx集群 在集群内部创建多个Nginx服务,然后利用Docker Swarm的负载均衡功能将请求分发到不同的Nginx容器上。可以使用nginx.conf文件配置负载均衡策略,例如轮询、IP哈希等。在访问Nginx服务时,只需要访问Swarm Manager节点的VIP地址即可,Swarm会自动将请求分发到不同的Nginx容器上。 总结 Docker Swarm是一个强大的容器编排工具,可以用于管理复杂的容器集群。通过使用Docker Swarm,可以轻松地部署Nginx集群,提高Web服务的可用性和性能,实现高可用、高扩展性的服务架构。 ### 回答3: Docker是现今最为流行的容器化平台,其可以帮助我们将应用程序和其依赖项一起打包在一个可移植容器中。而Docker Swarm是Docker的官方集群管理工具,它允许我们快速轻松地构建、管理和扩展Docker容器集群。下面将介绍如何在Docker Swarm上部署nginx集群。 步骤一:创建Docker Swarm集群 首先,需要在集群中创建几个节点。在某台用作管理节点的机器上运行以下命令,在该机器上创建一个Swarm: ``` docker swarm init ``` 运行上述命令后,系统会返回一个命令,该命令需要您在其他节点上运行以加入集群。 步骤二:建立nginx镜像 接下来,需要创建一个基于NginxDocker镜像,并将其上传到Docker Hub。 ``` FROM nginx COPY nginx.conf /etc/nginx/nginx.conf CMD ["nginx", "-g", "daemon off;"] ``` 步骤三:使用docker stack 部署nginx集群 现在,启动一个名为“web”的服务,该服务由两个副本组成,并使用刚刚创建的Nginx镜像。 ``` docker service create -p 8080:80 --name web --replicas 2 nginx ``` 上述命令将在Docker Swarm集群中启动名为“web”的服务。使用标志“-p”将本地端口8080映射到容器的80端口。使用标志“--replicas”指定了启动两个副本。此命令将指定Nginx映像部署到Swarm中。 步骤四:查看nginx集群运行状态 在集群运行过程中,可以使用以下命令查看服务和副本的状态: ``` docker service ls ``` 此外,执行以下命令可以查看服务的状态和详细信息: ``` docker service ps web ``` 此命令将返回当前正在运行的服务副本的详细信息。通过查看这些信息,可以查看每个副本的IP地址和状态。 步骤五:测试nginx集群的负载均衡 现在,该nginx集群已成功部署。您可以使用“curl”命令或浏览器将请求发送到集群的任何成员。每次请求将自动转发到由Swarm管理的每个副本中的一个。 在浏览器中输入http://localhost:8080,您将看到nginx的欢迎页面,并可以看到每个请求都将定向到不同的副本。 总结 在Docker Swarm上部署nginx集群,可以快速轻松地运行一个高可靠性、高可用性的Web应用程序。使用Docker Swarm,我们可以轻松地扩展集群,通过使用负载均衡技术将请求自动转发到不同的副本。同时,Docker Swarm还提供了集群管理的所有功能,包括自动部署、升级和维护等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值