当前位置:首页 > 技术文章 > 正文内容

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

arlanguage3个月前 (01-31)技术文章30

优质文章,及时送达

准备工作

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、微服务、数据库、数据结构、架构等等。

扫描二维码推送至手机访问。

版权声明:本文由AR编程网发布,如需转载请注明出处。

本文链接:http://www.arlanguage.com/post/1918.html

标签: nginx流程
分享给朋友:

“使用 Docker 部署 Spring Cloud 项目详细步骤” 的相关文章

Windows中使用Nginx解决前后端分离部署中的跨域问题

说明现在的Java Web项目好多都使用前后端分离的开发部署方式,这样的好处有很多,比如:可以实现真正的前后端解耦,可以减少后端服务器的并发/负载压力,方便实现多端应用(网页端、移动端共用一个后台服务)、增加代码的维护性&易读性。一般我们会采用Nginx来部署前端代码,使用Tomcat来部署后台服务...

Linux 网络延迟排查方法 linux延迟10秒

在 Linux 服务器中,可以通过内核调优、DPDK 以及 XDP 等多种方式提高服务器的抗攻击能力,降低 DDoS 对正常服务的影响。在应用程序中,可以使用各级缓存、WAF、CDN 等来缓解 DDoS 对应用程序的影响。但是需要注意的是,如果 DDoS 流量已经到达 Linux 服务器,那么即使应...

C# 实现高并发 Web 应用的性能优化秘籍

在现代的互联网应用中,尤其是大型 Web 应用,性能和可扩展性成为了核心竞争力。随着用户访问量和数据量的增大,高并发处理成为了系统稳定性和响应速度的关键因素。无论是电商平台、社交网站还是 SaaS 应用,如何应对海量用户的同时访问,确保系统高效运转,已经成为了技术人员面临的重要挑战。C# 和 ASP...

php手把手教你做网站(二十四)jquery ajax上传大的附件

上传大的附件分为两种情况,可以改变服务器配置;不能改变配置;第2种使用分片上传优势:可以突破服务器上传大小的限制,可以web存储上传到哪一块了,在浏览器关闭或者刷新的情况下可以断点续传;劣势:上传速度慢,在我本地电脑测试,200M的文件,改变配置按照正常方式上传大约需要12到15秒,但是使用第2种分...

Linux Shell

基本语法第一行第一行必须是 #!/bin/sh。它不是注释,#!/bin/sh 是对shell的声明,说明你所用的是那种类型的shell及其路径所在如果没有声明,则脚本将在默认的shell中执行,默认shell是由用户所在的系统定义为执行shell脚本的shell如果脚本被编写为在Kornshell...

为什么服务器管理用户都使用宝塔面板?

宝塔面板宝塔面板到底是个什么鬼?为什么这么多站长使用宝塔面板?宝塔Linux面板是提升运维效率的服务器管理软件,支持一键LAMP/LNMP/集群/监控/网站/FTP/数据库/JAVA等100多项服务器管理功能。有30个人的专业团队研发及维护,经过200多个版本的迭代,功能全,少出错且足够安全,已获得...