加入收藏 | 设为首页 | 会员中心 | 我要投稿 厦门网 (https://www.xiamenwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

基于 Spring Cloud 与 Vue.js 的前后端一站式部署

发布时间:2019-10-31 19:26:23 所属栏目:建站 来源:老马
导读:本文将带大家从一台全新的 CentOS 服务器开始,部署一套完整的前后端分离项目。操作步骤非常详细,新手友好型文章~ 后端技术栈:Spring Cloud 微服务架构 + Redis + RabbitMQ + MySQL; 前端技术栈:Vue + ElementUI; 部署工具:后端用 Docker 容器化部署,

那这些变量是在哪设置的呢?待会儿编写 Dockerfile 的时候就可以看到,会在 Dockerfile 里设置这几个变量为环境变量,当启动 Docker 容器的时候,程序就会读取到 Dockerfile 中设置的值并应用到项目中。

编写Dockerfile

下面是 education 模块的 Dockerfile:

  1. FROM java:8 
  2. VOLUME /tmp 
  3. ADD education.jar app.jar 
  4. RUN bash -c 'touch /app.jar' 
  5.  
  6. ENV SPRING-CLOUD-EUREKA-ZONE http://123.456.789.10:8761/eureka/ 
  7. ENV SPRING-CLOUD-MYSQL-HOST 123.456.789.10 
  8. ENV SPRING-CLOUD-DB-NAME edu 
  9. ENV SPRING-CLOUD-RABBIT-MQ-HOST 123.456.789.10 
  10. ENV SPRING-CLOUD-REDIS-HOST 123.456.789.10 
  11.  
  12. ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"] 
  13. EXPOSE 8899 

简单的解释下每句话的作用:

  • FROM java:8:指定基础镜像,必须为第一个命令
  • VOLUME /tmp:用于指定持久化目录
  • ADD education.jar app.jar:将本地文件 education.jar 添加到容器中并命名为 app.jar。注意这里的 education.jar 要换成你自己项目打包出来的 jar 包名字,如果你打的包名字叫 abc.jar,那应该这么写:ADD abc.jar app.jar。
  • RUN bash -c 'touch /app.jar':在镜像容器中执行的命令,运行 jar 包。
  • ENV:这几行以 ENV 开头的是设置环境变量,还记得上面 application-pro.yml 文件里的那几个 ${} 变量吗?就是在这里设置的。把该填地址的地方都换成这台服务器的公网 IP 地址,本配置假设你服务器的地址是 123.456.789.10 ,用的时候把这个地址换成你自己服务器地址即可。
  • ENTRYPOINT:配置容器,使其可执行化。
  • EXPOSE 8899:对外暴露 8899 端口。这个端口要和项目的配置文件中 server.port 设置的端口一致。

总结一下,Dockerfile 文件你要改的,只有三个地方:

  • 第三行 education.jar 换成你打包出来的 jar 包名字
  • ENV 开头的环境变量自己根据 application-pro.yml 的配置进行设置
  • 最后一行 EXPOSE 8899 改成你项目的端口号

再贴一个模块的 Dockerfile 作对比:

  1. FROM java:8 
  2. VOLUME /tmp 
  3. ADD gateway.jar app.jar 
  4. RUN bash -c 'touch /app.jar' 
  5.  
  6. ENV SPRING-CLOUD-EUREKA-ZONE http://123.456.789.10:8761/eureka/ 
  7. ENV SPRING-CLOUD-REDIS-HOST 123.456.789.10 
  8.  
  9. ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"] 
  10. EXPOSE 8888 

按照这种方法,把每个需要打包的微服务项目的 Dockerfile 写好。

打包

配置好三个 applicaiton.yml 和 Dockerfile(其实打包这一步用不到 Dockerfile),在项目的根目录下执行以下命令打包:

  1. mvn clean package -Dmaven.test.skip=true 

看到控制台输出 SUCCESS 则打包成功:

基于 Spring Cloud 与 Vue.js 的前后端一站式部署

打完的包在项目目录/target 里,如图:

基于 Spring Cloud 与 Vue.js 的前后端一站式部署

检查一下 jar 包的大小,如果是好几十 M 就没啥问题,如果是几百 K 那就是打包配置有问题,检查 pom.xml 文件的 标签配置是否正确。

附 <build>配置:

  1. <build> 
  2. <plugins> 
  3.   <plugin> 
  4.     <groupId>org.springframework.boot</groupId> 
  5.     <artifactId>spring-boot-maven-plugin</artifactId> 
  6.     <executions> 
  7.       <execution> 
  8.         <goals> 
  9.           <goal>repackage</goal> 
  10.         </goals> 
  11.       </execution> 
  12.     </executions> 
  13.   </plugin> 
  14.   <plugin> 
  15.     <groupId>org.springframework.boot</groupId> 
  16.     <artifactId>spring-boot-maven-plugin</artifactId> 
  17.   </plugin> 
  18. </plugins> 
  19. <finalName>education</finalName> 
  20. </build> 

编写自动化脚本

写完 Dockerfile 文件还要执行命令打包成 image 镜像,还需要运行起容器,两行代码虽然不多但每次写还是麻烦,把它封装成一个 sh 脚本,每次直接运行脚本省时省力。

(编辑:厦门网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读