百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

使用 Docker 部署 Spring Cloud 项目详细步骤

off999 2025-03-05 20:12 25 浏览 0 评论

优质文章,及时送达

准备工作

JDK1.8、Docker1.12.1、CentOS7.0

1.CentOS7.0下JDK1.8的安装

(1)到Oracle官网下载好
jdk-8u181-linux-x64.tar.gz 备用 (2)卸载系统自带的java

java -version 
rpm -qa|grep java
yum -y remove [上面查出来的东西,多个用空格分隔]

(3)安装jdk

cd /usr #进入到要安装jdk的目录
mkdir java #创建java目录,将jdk-8u181-linux-x64.tar.gz上传到此目录
tar -zxvf jdk-8u181-linux-x64.tar.gz #将jdk压缩包解压安装

(4)配置环境变量

vim /etc/profile

找到: export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE HISTCONTROL 这一行,并在其下面一行添加如下内容:

export JAVA_HOME=/usr/java/jdk1.8.0_181 
export PATH=$JAVA_HOME/bin:$PATH
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

使环境变量生效

source /etc/profile

测试安装

java -version

2.Docker的安装

(1) 查看内核版本(Docker需要64位版本,同时内核版本在3.10以上,如果版本低于3.10,需要升级内核)

uname -r

(2) 更新yum包:

yum update

(3) 添加yum仓库:

sudo tee /etc/yum.repos.d/docker.repo <<-'EOF'
[dockerrepo]
name=Docker Repository
baseurl=https://yum.dockerproject.org/repo/main/centos/7/
enabled=1
gpgcheck=1
gpgkey=https://yum.dockerproject.org/gpg
EOF

(4) 安装Docker

yum install docker-engine

(5) 启动Docker

service docker start

(6)配置docker远程访问

执行命令编辑文件

vim /usr/lib/systemd/system/docker.service

找到这一行

ExecStart=/usr/bin/dockerd

改为

ExecStart=/usr/bin/dockerd -H tcp:
unix:

修改完成后保存并重启Docker

service docker restart

测试访问
http://125.35.86.214:2375/version 如果有返回数据则配置成功。

(7)使用Docker国内镜像(为Docker镜像下载提速,非必须)

curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s
http://fe8a7d6e.m.daocloud.io

3. Docker Compose的安装

(1)下载docker-compose ,并放到/usr/local/bin/

https://github.com/docker/compose/releases/download/1.8.0/docker-compose-`uname
-s`-`uname -m` > /usr/local/bin/docker-compose

(2)为Docker Compose脚本添加执行权限

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

(3)安装完成,测试

docker-compose --version

结果显示:

docker-compose version 1.8.0, build f3628c7

说明Docker Compose已经安装完成了。

4. Docker使用Maven插件构建并上传镜像

(1)新建Dockerfile文件

在项目的/src/main下新增文件夹docker,并在文件夹下创建Dockerfile文件,文件内容如下

# 基于哪个镜像
FROM java:8
# 将本地文件夹挂载到当前容器
VOLUME /tmp
# 拷贝文件到容器,handcuffs-reg-0.0.1-SNAPSHOT.jar这里是maven打包后的名字
ADD handcuffs-reg-0.0.1-SNAPSHOT.jar app.jar
RUN bash -c 'touch /app.jar'
# 配置容器启动后执行的命令
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

(2)修改pom.xml文件增加如下plugin

imageName:镜像名称

dockerDirectory:Dockerfile文件所在目录

dockerHost:docker所在宿主机ip 2375为docker开启的远程访问端口

其他配置采取默认即可


com.spotify
docker-maven-plugin
0.4.14

reg-service
src/main/docker
http://125.35.86.214:2375


/
${project.build.directory}
${project.build.finalName}.jar



每一个微服务项目都要进行配置。

(3)构建镜像并上传至docker

使用maven运行如下命令

clean package docker:build -DskipTests

上传成功后,在服务器输入

docker images

可以看到所有的docker镜像啦。

5. 使用Docker Compose进行服务编排

(1)在服务器任意目录,新建文件docker-compose.yml

version: '2'
services:
eureka-server1:
restart: on-failure
image: reg-service
ports:
- "8761:8761"
networks:
- eureka-net
environment:
SERVER_PORT: "8761"

config:
image: config-service
networks:
- eureka-net
ports:
- "8091:8091"
environment:
REGISTER_URL: "http://114.115.185.152:8761/eureka/"
SERVER_PORT: "8091"
SERVER_GIT_URL: "https://gitee.com/deanTheOne/handcuffs-config.git"
SERVER_GIT_USERNAME: "test"
SERVER_GIT_PASSWORD: "test"
RABBITMQ_HOST: "39.105.152.144"
RABBITMQ_PORT: "5672"
RABBITMQ_USERNAME: "mqTest"
RABBITMQ_PASSWORD: "mqTest"


zuul:
restart: on-failure
image: gateway-service
ports:
- "8000:8000"
environment:
REGISTER_URL: "http://114.115.185.152:8761/eureka/"
SERVER_PORT: "8000"
SERVER_ADDR: "114.115.185.152"
networks:
- eureka-net
networks:
eureka-net:

driver: bridge

文件编写完毕保存,切换到当前文件所在目录,输入命令启动Docker Compose

docker-compose -f docker-compose.yml up -d

停止Docker Compose命令

docker-compose-fdocker-compose.ymldown

作者:现实太狗oc

https://blog.csdn.net/u011508407/article/details/82153562

-END-

如果看到这里,说明你喜欢这篇文章,请 转发、点赞。同时标星(置顶)本公众号可以第一时间接受到博文推送。

1. 一行命令下载全网视频,这个项目牛逼了!

最近整理一份面试资料《Java技术栈学习手册》,覆盖了Java技术、面试题精选、Spring全家桶、Nginx、SSM、微服务、数据库、数据结构、架构等等。

相关推荐

阿里云国际站ECS:阿里云ECS如何提高网站的访问速度?

TG:@yunlaoda360引言:速度即体验,速度即业务在当今数字化的世界中,网站的访问速度已成为决定用户体验、用户留存乃至业务转化率的关键因素。页面加载每延迟一秒,都可能导致用户流失和收入损失。对...

高流量大并发Linux TCP性能调优_linux 高并发网络编程

其实主要是手里面的跑openvpn服务器。因为并没有明文禁p2p(哎……想想那么多流量好像不跑点p2p也跑不完),所以造成有的时候如果有比较多人跑BT的话,会造成VPN速度急剧下降。本文所面对的情况为...

性能测试100集(12)性能指标资源使用率

在性能测试中,资源使用率是评估系统硬件效率的关键指标,主要包括以下四类:#性能测试##性能压测策略##软件测试#1.CPU使用率定义:CPU处理任务的时间占比,计算公式为1-空闲时间/总...

Linux 服务器常见的性能调优_linux高性能服务端编程

一、Linux服务器性能调优第一步——先搞懂“看什么”很多人刚接触Linux性能调优时,总想着直接改配置,其实第一步该是“看清楚问题”。就像医生看病要先听诊,调优前得先知道服务器“哪里...

Nginx性能优化实战:手把手教你提升10倍性能!

关注△mikechen△,十余年BAT架构经验倾囊相授!Nginx是大型架构而核心,下面我重点详解Nginx性能@mikechen文章来源:mikechen.cc1.worker_processe...

高并发场景下,Spring Cloud Gateway如何抗住百万QPS?

关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen。高并发场景下网关作为流量的入口非常重要,下面我重点详解SpringCloudGateway如何抗住百万性能@m...

Kubernetes 高并发处理实战(可落地案例 + 源码)

目标场景:对外提供HTTPAPI的微服务在短时间内收到大量请求(例如每秒数千至数万RPS),要求系统可弹性扩容、限流降级、缓存减压、稳定运行并能自动恢复。总体思路(多层防护):边缘层:云LB...

高并发场景下,Nginx如何扛住千万级请求?

Nginx是大型架构的必备中间件,下面我重点详解Nginx如何实现高并发@mikechen文章来源:mikechen.cc事件驱动模型Nginx采用事件驱动模型,这是Nginx高并发性能的基石。传统...

Spring Boot+Vue全栈开发实战,中文版高清PDF资源

SpringBoot+Vue全栈开发实战,中文高清PDF资源,需要的可以私我:)SpringBoot致力于简化开发配置并为企业级开发提供一系列非业务性功能,而Vue则采用数据驱动视图的方式将程序...

Docker-基础操作_docker基础实战教程二

一、镜像1、从仓库获取镜像搜索镜像:dockersearchimage_name搜索结果过滤:是否官方:dockersearch--filter="is-offical=true...

你有空吗?跟我一起搭个服务器好不好?

来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。昨天闲的没事的时候,随手翻了翻写过的文章,发现一个很严重的问题。就是大多数时间我都在滔滔不绝的讲理论,却很少有涉及动手...

部署你自己的 SaaS_saas如何部署

部署你自己的VPNOpenVPN——功能齐全的开源VPN解决方案。(DigitalOcean教程)dockovpn.io—无状态OpenVPNdockerized服务器,不需要持久存储。...

Docker Compose_dockercompose安装

DockerCompose概述DockerCompose是一个用来定义和管理多容器应用的工具,通过一个docker-compose.yml文件,用YAML格式描述服务、网络、卷等内容,...

京东T7架构师推出的电子版SpringBoot,从构建小系统到架构大系统

前言:Java的各种开发框架发展了很多年,影响了一代又一代的程序员,现在无论是程序员,还是架构师,使用这些开发框架都面临着两方面的挑战。一方面是要快速开发出系统,这就要求使用的开发框架尽量简单,无论...

Kubernetes (k8s) 入门学习指南_k8s kubeproxy

Kubernetes(k8s)入门学习指南一、什么是Kubernetes?为什么需要它?Kubernetes(k8s)是一个开源的容器编排系统,用于自动化部署、扩展和管理容器化应用程序。它...

取消回复欢迎 发表评论: