前言:
學習Docker的過程中,一直想使用Docker運行SpringCloud程序,今天就將搭建過程記錄下來,以作總結。
一、Docker安裝
這里因為一些原因,被迫寫了個Centos下的Docker安裝腳本。至於為什么被迫,這里先埋下一個伏筆。
#!/bin/bash # Centos新版本Docker安裝:https://www.cnblogs.com/Peter2014/p/7704306.html # step 1: 安裝必要的一些系統工具 yum install -y yum-utils device-mapper-persistent-data lvm2 # Step 2: 添加軟件源信息 yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo # Step 3: 更新並安裝 Docker-CE yum makecache fast yum install docker-ce-18.06.0.ce -y # Step 4: 開啟Docker服務 systemctl restart docker mkdir -p /etc/docker tee /etc/docker/daemon.json <<-'EOF' { "registry-mirrors": ["https://vcugatat.mirror.aliyuncs.com"], "hosts": [ "tcp://0.0.0.0:0306", "unix:///var/run/docker.sock" ] } EOF systemctl daemon-reload systemctl restart docker systemctl enable docker
二、使用Maven插件生成鏡像
在本地使用Maven插件可以直接在遠程服務器生成鏡像,比較方便,但是此方法會暴露Docker服務的端口,可能產生隱患,請謹慎使用!
<!-- docker的maven插件,官網:https://github.com/spotify/docker-maven-plugin --> <plugin> <groupId>com.spotify</groupId> <artifactId>docker-maven-plugin</artifactId> <version>1.0.0</version> <configuration> <!-- Docker服務地址 --> <dockerHost>http://122.152.000.000:6030</dockerHost> <!-- 鏡像名 --> <imageName>${project.artifactId}</imageName> <!-- Dockerfile文件地址 --> <dockerDirectory>src/main/docker</dockerDirectory> <imageTags>1.0</imageTags> <resources> <resource> <targetPath>/</targetPath> <directory>${project.build.directory}</directory> <include>${project.build.finalName}.jar</include> </resource> </resources> </configuration> </plugin>
application.yml配置文件中,注冊中心的ip修改為容器名。
eureka: client: serviceUrl: # defaultZone: http://localhost:1111/eureka defaultZone: http://eureka-server:1111/eureka #注冊中心地址改為容器名
注意:
請使用自己的docker服務地址,上面的地址本人做過改動;
Dockerfile文件編寫請參考博客:docker部署spring cloud項目。請注意,此Dockerfile文件使用的基礎鏡像是 frolvlad/alpine-oraclejdk8:slim ,且我打開了服務器上的Docker端口。這兩個因素導致了我后面一直重裝系統,不得不寫一個腳本安裝docker。因為一旦使用 frolvlad/alpine-oraclejdk8:slim 鏡像,且Docker服務端口開放,我的服務器必定會被注入一個挖礦鏡像,從而成為礦機!!因此,我強烈推薦使用官方鏡像:openjdk:8,且謹慎開放Docker服務端口。
三、使用Docker搭建SpringCloud項目
常規啟動三個鏡像,容器是不能聯通的,必須手動為三個容器創建一個共同的網絡,容器間才可以保持通訊。
首先創建一個名為cloud的橋接網絡 docker network create -d bridge cloud 依次啟動三個鏡像,並且連接到創建的cloud網絡上 docker run -d --name eureka-server -p 1111:1111 --network cloud eureka-server docker run -d --name provider -p 8000:8000 --network cloud provider docker run -d --name consumer -p 8001:8001 --network cloud consumer
可以看到,服務已經注冊到注冊中心並且可以正常訪問。
四、使用Docker-compose搭建springcloud項目
version: "3" services: eureka-server: image: eureka-server:1.0 ports: - "1111:1111" volumes: - /usr/local/cloud/logs/eureka-server:/logs networks: - cloud #container_name: simple-provider-user: image: simple-provider-user:1.0 ports: - "8000:8000" volumes: - /usr/local/cloud/logs/provider:/logs networks: - cloud depends_on: - eureka-server simple-consumer-movie: image: simple-consumer-movie:1.0 ports: - "8001:8001" volumes: - /usr/local/cloud/logs/consumer:/logs networks: - cloud depends_on: - eureka-server networks: clooud: driver: bridge
在此docker-compose.yml目錄,運行docker-compose up -d,OK。
至此,使用docker搭建springcloud項目就已經完成了,但是遠遠不夠到生產級別,還需繼續學習!