docker基础:服务部署到swarm集群(六)

        上一篇文章说道,我们如何搭建集群,这时有人就要问了,集群搭建起来,我们要做什么用呢。在这篇文章中,主要给大家讲解一下,我们搭建集群后做的一些操作。比如说集群中怎么创建服务?用那种方式创建服务?以及创建服务后一些相关的命令。下面开始进行服务的创建。

        1、服务是什么?

        服务就是docker中能够支持一些功能或者是任务的操作的容器,这些容器中的软件就可以看作是一个服务。

        2、创建服务的方式?

         创建一个服务有三种方式,我们以tomcat为例。

          1)第一种用docker create 为例: docker container create --name tomcat -p 8088:8080 tomcat:latest

                这种方式创建出来的容器:每次只能在一台机器上创建一个容器。这种适合单机但容器操作。

          2)第二种用docker-compose运行compose文件:docker-compose up

         compose文件:

                              version: '3'

                              services:

                                  web:

                                   build: .

                                   ports:

                                       - "5001:5000"

                                  volumes:

                                       - .:/code

                                  redis:

                                      image: "redis:alpine"

                    这种方式是可以在一个机器上创建多容器,不能通过集群管理机指定节点进行部署。这种适合单机多服务操作。

              3)第三种方式用stack运行compose文件,在集群中运行镜像:docker stack deploy docker-compose.yml

                    docker-compose.yml内容如下:

                        #version是指版本,现在用的是3

                        version: "3"

                        #services是指有哪些服务

                        services:

                            web:

                                # replace username/repo:tag with your name and image details

                                image: tomcat:latest

                         deploy:

                             placement:

                                constraints:

                                    - node.hostname == node166

                           #启动5个节点

                           replicas: 5

                         #运行该映像的五个实例作为调用的服务web,限制每个实例使用,最多使用10%的CPU(跨所有内核)和50MB RAM。

                         #resources:

                              #limits:

                                  #cpus: "0.1"

                                  #memory: 50M

                      #运行失败从新启动

                      restart_policy:

                           condition: on-failure

                     #映射端口

                     ports:

                        - "8088:8080"

                     #指示web容器通过称为负载平衡网络共享端口80webnet

                        networks:

                             - webnet

                     #webnet使用默认设置(这是一个负载平衡的重叠网络)来定义网络。

                        networks:

                           webnet:

                 这种方式可以在一个集群内运行多个服务到指定的节点。这些节点之间可以进行正常通讯。这种的适合做集群的操作。 

                本次使用第三种方式进行服务的部署。

        3、服务的部署

             1.首先要搭建好集群。这个就不再说了。

             *在centos中创建一个文件夹:mkdir /root/swarmtest

             *创建一个compose文件:vi docker-compose.yml

             *在文件中填写下面的内容:

                   version: "3"

                   services:

                       web:

                            image: tomcat:latest

                            deploy:

                                 placement:

                                      constraints:

                                      - node.hostname == node166

                                 replicas: 5

                                 restart_policy:

                                       condition: on-failure

                                 ports:

                                     - "8088:8080"

                                 networks:

                                       - webnet

                           networks:

                                webnet:

           *保存后,执行docker stack deploy -c docker-compose.yml  tomcattest

执行的顺序是,先下载镜像,然后根据下载的镜像进行容器的创建,创建容器的时候,会根据指定的属性,安装到指定节点,设置属性信息。


启动服务之后查看的状态


节点运行状态

这样就在node166这台节点机器上运行了5个相同的服务。

只要是这个集群的ip都可以访问:192.168.1.166:8088,可以成功的访问到容器中

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,340评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,762评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,329评论 0 329
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,678评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,583评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,995评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,493评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,145评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,293评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,250评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,267评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,973评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,556评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,648评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,873评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,257评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,809评论 2 339

推荐阅读更多精彩内容