真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

原創(chuàng)文章,歡迎轉(zhuǎn)載。轉(zhuǎn)載請注明:轉(zhuǎn)載自IT人故事會,謝謝!
原文鏈接地址:『高級篇』docker之微服務(wù)服務(wù)docker化(18)

從網(wǎng)站建設(shè)到定制行業(yè)解決方案,為提供網(wǎng)站制作、成都網(wǎng)站制作服務(wù)體系,各種行業(yè)企業(yè)客戶提供網(wǎng)站建設(shè)解決方案,助力業(yè)務(wù)快速發(fā)展。創(chuàng)新互聯(lián)公司將不斷加快創(chuàng)新步伐,提供優(yōu)質(zhì)的建站服務(wù)。

這次進入微服務(wù)的部署,代碼也基本都通過了。如果比做一首歌曲的話,前奏已經(jīng)結(jié)束,現(xiàn)在開始我們的高潮部分,如果吧我們的服務(wù)使用docker,使用服務(wù)編排工具,把項目給部署運行起來。源碼:https://github.com/limingios/msA-docker

注意

因docker話都是在linux環(huán)境,為了方便編寫dockerfile文件,我切換到mac本上進行演示,目的只有一個方便開發(fā)sh。方便使用。CICD學(xué)習(xí)實踐首選電腦還是mac。

微服務(wù)部署

  1. 服務(wù)docker化,可以在docker下運行。
  2. Docker倉庫創(chuàng)建,docker創(chuàng)建的鏡像push到倉庫里面。
  3. 構(gòu)建高可用的集群環(huán)境,Mesos,Swarm,kubernetes。運行這3個服務(wù)編排工具把我們的服務(wù)運行和編排起來??梢詢?yōu)雅的啟動,停止,擴充容,故障的恢復(fù)。

docker化

服務(wù)有個適合的環(huán)境,服務(wù)可以運行起來,給他準(zhǔn)備一個環(huán)境,比如服務(wù)是個種子,我們需要準(zhǔn)備一片土地,服務(wù)是一條魚,就需要準(zhǔn)備一片大海。源碼中的服務(wù)有一個是python寫的,有一個是java寫的,也就是需要2個運行環(huán)境,一個基于java,一個基于python。

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

  • java鏡像

    去hub.docker.com 搜索java,找到tag

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

  • 下載java鏡像

    先配置加速,https://www.daocloud.io/mirror

 docker pull java:openjdk-8
 docker images|grep jdk

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

  • 安裝jdk容器
    docker run -it --entrypoint bash java:openjdk-8
    java -version

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

開始dockerfile的開發(fā)

熟悉docker的老鐵應(yīng)該都知道,如果要編譯docker的話需要docker化,首選需要開發(fā)dockerfile文件。

  • 準(zhǔn)備工作

    文件中不能有寫死的情況,如果寫死了,每次服務(wù)的變更都需要變更鏡像。為了減少構(gòu)建鏡像的過程,盡量吧數(shù)據(jù)庫的訪問地址,經(jīng)常會發(fā)生變化的東西,需要踢出去,不要在配置文件中配置死,針對數(shù)據(jù)庫的訪問,不能地址直接寫死,MySQL的地址,當(dāng)服務(wù)運行在docker之后,他的ip是實時都在變化的,不能寫死在鏡像里,直接就找不到了就報錯了。還有個問題,我們的服務(wù)以什么樣的形式放在我們docker里面,springboot之所以說適用于微服務(wù),他有個很大的好處,它可以將咱們的服務(wù)構(gòu)建成一個fat jar,只有一個jar包,然后通過java的一個命令:java -jar 文件.jar 運行起來,這種方式對于微服務(wù)來說也是很友好的,也非常的簡單,就使用這種方式來做。變量的方式就可以通過springboot --mysql.address 就可以傳遞進來了。

  • 構(gòu)建user-thrift-service

    修改配置文件 和 pom.xml文件

application.properties

service.name=user-thrift-service
service.port=7911

#數(shù)據(jù)源的配置
spring.datasource.url=jdbc:mysql://{mysql.address}:3306/db_user
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

pom.xml



    
        org.springframework.boot
        spring-boot-starter-parent
        1.5.3.RELEASE
    
    4.0.0

    com.idig8
    user-thrift-service
    1.0-SNAPSHOT

    
        
            org.springframework.boot
            spring-boot-starter
        
        
            org.apache.thrift
            libthrift
            0.10.0
        
        
            com.idig8
            user-thrift-service-api
            1.0-SNAPSHOT
        
        
            org.mybatis.spring.boot
            mybatis-spring-boot-starter
            1.3.1
        

        
            mysql
            mysql-connector-java
            5.1.44
        

    

    
        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                2.3.2
                
                    1.8
                    1.8
                
            
            
                org.springframework.boot
                spring-boot-maven-plugin
                
                    
                        
                            repackage
                        
                    
                
            
        
    

Dockfile編寫

FROM java:openjdk-8
MAINTAINER liming www.idig8.com

COPY target/user-thrift-service-1.0-SNAPSHOT.jar /user-thrift-service.jar

ENTRYPOINT ["java","-jar","/user-thrift-service.jar"]

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

執(zhí)行build生成鏡像

docker build -t user-thrift-service:latest .

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

查看ip地址

ifconfig

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

生成容器

docker run -it user-thrift-service:latest --mysql.address=192.168.1.140

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

新建立build.sh

#!/usr/bin/env bash

mvn package
docker build -t user-thrift-service:latest .


![](/upload/otherpic69/11223715-966e41457da6513c.png%7CimageView2/2/w/1240)

* 構(gòu)建message-thrift-python-service
>后面很多的服務(wù),都依賴它,必須把它做好。它是一個python的服務(wù),我們需要找一個python的鏡像。去官方找吧

``` bash
 docker pull python:3.6
 docker images|grep python

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

編寫Dockerfile

FROM python:3.6
MAINTAINER liming www.idig8.com

RUN pip install thrift

ENV PYTHONPATH /
COPY message /message
ENTRYPOINT ["python","/message/message_service.py"]

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

 docker build -t message-thrift-python-service:latest .

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

build開發(fā)

#!/usr/bin/env bash

docker build -t message-thrift-python-service:latest .

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

鏡像生成容器

docker run -it message-thrift-python-service:latest

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

  • 構(gòu)建user-edge-service

    微服務(wù)的依賴,了解docker的老鐵應(yīng)該知道可以通過link的方式,去根據(jù)名字搜索到這個服務(wù),只要不在開發(fā)范圍內(nèi)的,認(rèn)為是通過另外的介入方式ip,域名的方式。通過docker分為2種情況,微服務(wù)和微服務(wù)之間的通信,微服務(wù)和外圍系統(tǒng)的通信。
    修改配置文件 和 pom.xml文件

application.properties

server.name=user-edge-service
server.port=8082

thrift.user.ip=user-thrift-service
thrift.user.port=7911

thrift.message.ip=message-thrift-python-service
thrift.message.port=9090

#redis config
spring.redis.host=${redis.address}
spring.redis.port=6379
spring.redis.password=liming
spring.redis.timeout=30000

pom.xml



    
        org.springframework.boot
        spring-boot-starter-parent
        1.5.3.RELEASE
    
    4.0.0

    com.idig8
    user-edge-service
    1.0-SNAPSHOT

    
        
            org.springframework.boot
            spring-boot-starter-web
        
        
            org.apache.thrift
            libthrift
            0.10.0
        
        
            com.idig8
            user-thrift-service-api
            1.0-SNAPSHOT
        

        
            com.idig8
            message-thrift-service-api
            1.0-SNAPSHOT
        

        
            org.springframework.boot
            spring-boot-starter-data-redis
        
        
            commons-lang
            commons-lang
            2.6
        

        
            org.springframework.boot
            spring-boot-starter-thymeleaf
        

    

    
        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                2.3.2
                
                    1.8
                    1.8
                
            
            
                org.springframework.boot
                spring-boot-maven-plugin
                
                    
                        
                            repackage
                        
                    
                
            
        
    

Dockerfile編寫

FROM java:openjdk-8
MAINTAINER liming www.idig8.com

COPY target/user-edge-service-1.0-SNAPSHOT.jar /user-edge-service.jar

ENTRYPOINT ["java","-jar","/user-edge-service.jar"]

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

build.sh 編寫

#!/usr/bin/env bash

mvn package
docker build -t user-edge-service:latest .

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

sh build.sh

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

創(chuàng)建容器

docker run -it user-edge-service:latest --redis.address=192.168.1.140

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

  • 構(gòu)建course-dubbo-service

微服務(wù)的依賴,了解docker的老鐵應(yīng)該知道可以通過link的方式,去根據(jù)名字搜索到這個服務(wù),只要不在開發(fā)范圍內(nèi)的,認(rèn)為是通過另外的介入方式ip,域名的方式。通過docker分為2種情況,微服務(wù)和微服務(wù)之間的通信,微服務(wù)和外圍系統(tǒng)的通信。
修改配置文件 和 pom.xml文件

application.properties

#dubbo 配置
spring.dubbo.application.name=course-dubbo-service
spring.dubbo.registry.address=zookeeper://${zookeeper.address}:2181
spring.dubbo.protocol.name=dubbo
spring.dubbo.protocol.port=20880
#spring.dubbo.protocol.host=127.0.0.1
spring.dubbo.scan=com.idig8.course

#數(shù)據(jù)源的配置
spring.datasource.url=jdbc:mysql://${mysql.address}:3306/db_course
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

thrift.user.ip=user-thrift-service
thrift.user.port=7911

pom.xml



    
        org.springframework.boot
        spring-boot-starter-parent
        1.5.3.RELEASE
    
    4.0.0

    com.idig8
    course-dubbo-service
    1.0-SNAPSHOT

    
        
            io.dubbo.springboot
            spring-boot-starter-dubbo
            1.0.0
        
        
            org.springframework.boot
            spring-boot-starter
        
        
            org.apache.thrift
            libthrift
            0.10.0
        

        
            org.mybatis.spring.boot
            mybatis-spring-boot-starter
            1.3.1
        

        
            mysql
            mysql-connector-java
            5.1.44
        
        
            com.idig8
            course-dubbo-service-api
            1.0-SNAPSHOT
        

        
            com.idig8
            user-thrift-service
            1.0-SNAPSHOT
        
        
            com.idig8
            user-thrift-service-api
            1.0-SNAPSHOT
        
    

    
        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                2.3.2
                
                    1.8
                    1.8
                
            
            
                org.springframework.boot
                spring-boot-maven-plugin
                
                    
                        
                            repackage
                        
                    
                
            
        
    

Dockerfile編寫

FROM java:openjdk-8
MAINTAINER liming www.idig8.com

COPY target/course-dubbo-service-1.0-SNAPSHOT.jar /course-dubbo-service.jar

ENTRYPOINT ["java","-jar","/course-dubbo-service.jar"]

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

build.sh 編寫

#!/usr/bin/env bash

mvn package
docker build -t course-dubbo-service:latest .
sh build.sh

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

創(chuàng)建容器

docker run -it course-dubbo-service:latest --redis.address=192.168.1.140 --zookeeper.address=192.168.1.140

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

  • 構(gòu)建course-edge-service

    跟之間的基本是一樣的,都是重復(fù)的工作。直接看源碼吧

    1. 修改pom文件增加maven構(gòu)建
    2. 增加dockerfile文件
    3. 增加build.sh文件
    4. 資源文件的修改

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

docker run -it course-edge-service:latest --zookeeper.address=192.168.1.140

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

docker run -it gataway-zuul:latest                                         

『高級篇』docker之微服務(wù)服務(wù)docker化(18)

PS:把所有單獨的服務(wù),做成了鏡像,下次想個辦法服務(wù)和鏡像統(tǒng)一的運行起來。

『高級篇』docker之微服務(wù)服務(wù)docker化(18)


文章名稱:『高級篇』docker之微服務(wù)服務(wù)docker化(18)
URL分享:http://weahome.cn/article/pdpido.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部