docker-compose spring boot发布服务

spirngboot2+mysql8+redis+idea。
  首先这个一个分库分表的demo.所以引入的依赖会比较多,创建docker-compose时需要将该文件放到src文件同级的目录下如下

docker-compose

  • 第一步:配置mysql
services:
  mysql:
#实例的名字
    container_name: mysql
#mysql最新镜像,如果没有会自动下载
    image: mysql:latest
    #ports 对外暴露端口号3306并映射到主机端口号3306
    ports:
      - 3306:3306
#暴露3306端口号给同一网络下的其他容器
    expose:
      - 3306
#设置环境变量,配置root 密码
    environment:
      MYSQL_ROOT_PASSWORD: "123456"
#时候总是启动,如果实例出现问题将会重启
  #  restart: always
#挂在数据卷
    volumes:
      #更具自己配置的路径修改 这是绝对路径,相对路径是docker-compose.yml 的当前路径
      #/e/docker/mysql 表示 E:/docker/mysql 这个地方自己定义
#将实例里的数据保存在主机上实现数据的备份防止实例停止造成数据的丢失
      - "/e/docker/mysql/db:/var/lib/mysql"
#自定义配置覆盖容器里的配置
      - "/e/docker/mysql/conf/my.cnf:/etc/my.cnf"
#初始化一下mysql 配置脚本可以放到该目录下
      - "/e/docker/mysql/init:/docker-entrypoint-initdb.d/"
#将连接各个实例可以使他们之间通信
    networks:
      - web1
  • 第二步redis的配置

  redis:
    container_name: redis
    image: redis:latest
    ports:
      - 6379:6379
    expose:
      - 6379
    command:
      --requirepass "123456" --appendonly yes
    volumes:
      - /e/docker/redis/data:/data
    networks:
      - web1
  • 这个没有其他特别的和mysql一样
      command: --requirepass "123456" --appendonly yes
  • 这里是设置密码,并以守护进程模式开启redis
  • 这里也是将redis 放入web1的网络里

第三步 发布app

  web:
    container_name: shardingJdbcDemo
    image: openjdk:latest
    ports:
      - 8772:8772
    volumes:
      - "./target/shardingJdbcDemo.jar:/app.jar"
    command: "java -jar app.jar"
    networks:
      - web1
    depends_on:
      - mysql
      - redis
    expose:
      - 8772
networks:
  web1:
    driver: bridge
  • 需要注意的是volumes - "./target/shardingJdbcDemo.jar:/app.jar"
  • docker-compose 读取jar的时候是相对路径,而我的docker-compose.yml 是放在项目src的同级目录因此只需要"./target/***"就能获取对应的jar包而jar包的名字需要在对应的maven配置下修改


    jar 的名字

最后是networks

networks:
  web1:
    driver: bridge
  • 这里是配置了一个名叫web1的网络,dirver是birdge dirver有好几种感兴趣的可以自行百度查询
  • 需要注意的是networks 这个是和services平级的
需要注意的

1.   在发布web服务的时候需要发布mysql 与redis 特别是mysql 如果不在web 之前发布,app会报错这个地方通过depend_on来配置先后顺序
2.  注意数据源的配置,这个地方是个坑不注意的话会出现无法连接数据库,connection refuse的错误,需要修改成如下配置

url配置

其中我把ip 改为mysql (docker-compose里services 下的名字web,mysql,redis),这个原理不是很清楚,但是就是需要这样改。我能大概的明白他联的是mysql 这个实例的容器通过network
3.  mysql 的配置问题,我下载的是官方的镜像,在通过外部连接的时候回出现问题,root 无法连接,这时需要修改root的权限和加密方式。如下配置

#修改mysql8 的加密方式,不改的话无法登录会报错
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';
ALTER USER 'root'@'%' IDENTIFIED BY '123456' PASSWORD EXPIRE NEVER;
FLUSH PRIVILEGES;
use mysql;
#创建用户
create user 'houhaoran'@'%' identified by '123456';
#用户授权  所有数据库.所有权限;
grant all privileges on *.* to 'houhaoran'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;
  • 这个地方我修改了root 的权限与加密方式
  • 这里我连接数据库时使用的不是root所以又创建了用户并附权限和root权限一样,在创建的时候需要将该文件放到容器里的
    /docker-entrypoint-initdb.d/ 的文件夹里,在容器启动的时候会加载该脚本



最后完整的docker-compose.yml配置
version: "3.1"
services:
  mysql:
    container_name: mysql
    image: mysql:latest
    ports:
      - 3306:3306
    expose:
      - 3306
    environment:
      MYSQL_ROOT_PASSWORD: "123456"
  #  restart: always
    volumes:
      #更具自己配置的路径修改 这是绝对路径,相对路径是docker-compose.yml 的当前路径
      #/e/docker/mysql 表示 E:/docker/mysql 这个地方自己定义
      - "/e/docker/mysql/db:/var/lib/mysql"
      - "/e/docker/mysql/conf/my.cnf:/etc/my.cnf"
      - "/e/docker/mysql/init:/docker-entrypoint-initdb.d/"
    networks:
      - web1
  redis:
    container_name: redis
    image: redis:latest
    ports:
      - 6379:6379
    expose:
      - 6379
    command:
      --requirepass "123456" --appendonly yes
    volumes:
      - /e/docker/redis/data:/data
    networks:
      - web1
  web:
    container_name: shardingJdbcDemo
    image: openjdk:latest
    ports:
      - 8772:8772
    volumes:
      - "./target/shardingJdbcDemo.jar:/app.jar"
    command: "java -jar app.jar"
    networks:
      - web1
    depends_on:
      - mysql
      - redis
    expose:
      - 8772
networks:
  web1:
    driver: bridge


maven完整的配置

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>demo</groupId>
    <artifactId>sharding-jdbc-demo</artifactId>
    <version>1.0-SNAPSHOT</version>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.2.RELEASE</version>
        <relativePath />
    </parent>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.4</version>
            <scope>provided</scope>
        </dependency>
        <!--sharding-jdbc 开始-->
        <!--sharding-jdbc -->
        <dependency>
            <groupId>io.shardingsphere</groupId>
            <artifactId>sharding-jdbc-spring-boot-starter</artifactId>
            <version>3.1.0</version>
        </dependency>
        <!--sharding-jdbc结束-->
        <!--mysql 驱动开始-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <!--mysql 结束-->
        <!--mybatis 依赖开始-->
        <!-- mybatis 依赖jar包-->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.0.0</version>
        </dependency>
        <!--mybatis的自动生成器配置-->
        <dependency>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-core</artifactId>
            <version>1.3.5</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/tk.mybatis/mapper-spring-boot-starter -->
        <dependency>
            <groupId>tk.mybatis</groupId>
            <artifactId>mapper-spring-boot-starter</artifactId>
            <version>2.1.0</version>
        </dependency>
        <!--mybatis 依赖结束-->
        <!--durid  阿里巴巴连接池-->
        <!-- https://mvnrepository.com/artifact/com.alibaba/druid -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.14</version>
        </dependency>
        <!--durid 结束-->
        <!--spring boot test 使用进行单元测试 开始-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>
        <!--spring boot test 结束-->
        <!--spring boot 整合redis-->
        <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-data-redis -->

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
            <version>2.1.3.RELEASE</version>
        </dependency>
        <!--spring boot 整合reids 结束-->
        <!--spring boot z整合log4j2-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-log4j2</artifactId>
            <version>2.1.3.RELEASE</version>
        </dependency>
        <!-- 加上这个才能辨认到log4j2.yml文件 --><!-- c.?-->
        <dependency>
            <groupId>com.fasterxml.jackson.dataformat</groupId>
            <artifactId>jackson-dataformat-yaml</artifactId>
        </dependency>
        <!--jwt 使用开始-->
        <dependency>
            <groupId>com.auth0</groupId>
            <artifactId>java-jwt</artifactId>
            <version>3.4.0</version>
        </dependency>
        <!--jwt认证使用结束-->

        <!-- mybatis的分页插件 -->
        <!-- https://mvnrepository.com/artifact/com.github.pagehelper/pagehelper-spring-boot-starter -->
        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper-spring-boot-starter</artifactId>
            <version>1.2.10</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 -->
                <dependency>
                    <groupId>org.apache.commons</groupId>
                    <artifactId>commons-lang3</artifactId>
                    <version>3.9</version>
                </dependency>
        <!--临时使用-->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.15</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml-schemas</artifactId>
            <version>3.15</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.15</version>
        </dependency>
        <!--临时使用-->
        <dependency>
            <groupId>com.google.code.gson</groupId>
            <artifactId>gson</artifactId>
            <version>2.8.5</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.58</version>
        </dependency>
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.6</version>
        </dependency>
    </dependencies>
    <build>
        <finalName>shardingJdbcDemo</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <!--fork :  如果没有该项配置,肯呢个devtools不会起作用,即应用不会restart -->
                    <fork>true</fork>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,560评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,104评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,297评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,869评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,275评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,563评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,833评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,543评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,245评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,512评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,011评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,359评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,006评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,062评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,825评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,590评论 2 273
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,501评论 2 268

推荐阅读更多精彩内容