温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何使用Docker-Compose一键部署java微服务

发布时间:2021-09-18 13:51:09 来源:亿速云 阅读:672 作者:柒染 栏目:编程语言

这篇文章将为大家详细讲解有关如何使用Docker-Compose一键部署java微服务,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

Docker Compose 来轻松高效的管理容器,定义运行多个容器

官方介绍

定义、运行多个容器。 YAML file 配置文件。 single command。 命令有哪些? Compose is a tool for defining and running multi-container Docker applications. With Compose, you use a YAML file to configure your application’s services. Then, with a single command, you create and start all the services from your configuration. To learn more about all the features of Compose, see the list of features. 所有的环境都可以使用 Compose。 Compose works in all environments: production, staging, development, testing, as well as CI workflows. You can learn more about each case in Common Use Cases. 三步骤: Using Compose is basically a three-step process:

  1. Define your app’s environment with a Dockerfile so it can be reproduced anywhere.

  • Dockerfile 保证我们的项目在任何地方可以运行。

  1. Define the services that make up your app in docker-compose.yml so they can be run together in an isolated environment.

  • services 什么是服务。

  • docker-compose.yml 这个文件怎么写!

  1. Run docker-compose up and Compose starts and runs your entire app.

  • 启动项目

作用:批量容器编排。

理解

Compose 是Docker官方的开源项目。需要安装! Dockerfile 让程序在任何地方运行。 web服务。 redismysql、nginx ... 多个容器。 run Compose

version: "3.9"  # optional since v1.27.0
services:
  web:
    build: .
    ports:
      - "5000:5000"
    volumes:
      - .:/code
      - logvolume01:/var/log
    links:
      - redis
  redis:
    image: redis
volumes:
  logvolume01: {}

docker-compose up 100 个服务。 Compose :重要的概念。 服务services, 容器。应用。(web、redis、mysql....) 项目project。 一组关联的容器。 博客。web、mysql。

下载并安装Docker-Compose

下载Docker-Compose

sudo curl -L "https://github.com/docker/compose/releases/download/1.28.6/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
# 这个可能快点!
curl -L https://get.daocloud.io/docker/compose/releases/download/1.28.6/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

设置权限

sudo chmod +x /usr/local/bin/docker-compose

测试,在任意目录下输入docker-compose

如何使用Docker-Compose一键部署java微服务

官方体验

python 应用。计数器。 redis!

官网地址:https://docs.docker.com/compose/gettingstarted/

前提需要安装最新版的docker-compose,否则会报版本不兼容

1、应用 app.py 2、Dockerfile 应用打包为镜像 3、Docker-compose yaml文件 (定义整个服务,需要的环境。 web、redis) 完整的上线服务! 4、启动 compose 项目(docker-compose up)

流程

1、创建网络 2、执行 Docker-compose yaml 3、启动服务。

官网流程

  • 创建文件夹

     mkdir composetest
     cd composetest


  • 创建app.py

    import time
    
    import redis
    from flask import Flask
    
    app = Flask(__name__)
    cache = redis.Redis(host='redis', port=6379)
    
    def get_hit_count():
        retries = 5
        while True:
            try:
                return cache.incr('hits')
            except redis.exceptions.ConnectionError as exc:
                if retries == 0:
                    raise exc
                retries -= 1
                time.sleep(0.5)
    
    @app.route('/')
    def hello():
        count = get_hit_count()
        return 'Hello World! I have been seen {} times.\n'.format(count)


  • 创建 requirements.txt

    flask
    redis


  • 创建 Dockerfile

    FROM python:3.7-alpine
    WORKDIR /code
    ENV FLASK_APP=app.py
    ENV FLASK_RUN_HOST=0.0.0.0
    RUN apk add --no-cache gcc musl-dev linux-headers
    COPY requirements.txt requirements.txt
    RUN pip install -r requirements.txt
    EXPOSE 5000
    COPY . .
    CMD ["flask", "run"]


  • 创建 docker-compose.yml

    version: "3.9"
    services:
      web:
        build: .
        ports:
          - "5000:5000"
      redis:
        image: "redis:alpine"


  • 运行 docker-compose up

    成功截图:

如何使用Docker-Compose一键部署java微服务

Java微服务项目实战计数器使用DockerCompose部署
  • 新建项目,完成计数功能

    package com.atxiaodei.hellodockercompose.controller;
    
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.data.redis.core.StringRedisTemplate;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    /**
     * @ClassName HelloController
     * @Deacription TODO
     * @Author 王盟
     * @Date 2021/4/6 18:58
     * @Version 1.0
     **/
    @RestController
    public class HelloController {
    
        @Autowired
        StringRedisTemplate redisTemplate;
    
        @RequestMapping("/hello")
        public String helloCount(){
            Long view = redisTemplate.opsForValue().increment("view");
    
            return  "使用dockercompose部署java微服务计数器功能,view"+view;
        }
    }


  • 编写Dockerfile

    FROM java:8
    
    COPY *.jar /app.jar
    
    CMD ["--server.port=8080"]
    
    EXPOSE 8080
    
    ENTRYPOINT ["java","-jar","/app.jar"]


  • 编写docker-compose.yml

    version: '3.9'
    
    services:
      wangmengapp:
        build: .
        image: wangmengapp
        depends_on:
          - redis
        ports:
        - "8080:8080"
      redis:
        image: "redis:alpine"


  • 上传文件到服务器

  • 执行 docker-compose up

    成功截图

如何使用Docker-Compose一键部署java微服务

总结:

  • 未来项目只要有 docker-compose 文件。 按照这个规则,启动编排容器。!

  • 公司: docker-compose。 直接启动。

  • 网上开源项目: docker-compose 一键搞定。

  • 假设项目要重新部署打包 docker-compose up --build # 重新构建!

关于如何使用Docker-Compose一键部署java微服务就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI