-
minikube:1.1.1
-
Java:1.8.0_191
-
Maven:3.6.0
-
fabric8-maven-plugin插件:3.5.37
-
spring-cloud-kubernetes:1.0.1.RELEASE
-
spring cloud:Greenwich.SR2
-
springboot:2.1.6.RELEASE
<>源码下载
如果您不打算写代码,也可以从GitHub上下载本次实战的源码,地址和链接信息如下表所示:
| 名称 | 链接 | 备注 |
| :-- | :-- | :-- |
| 项目主页 | https://github.com/zq2599/blog_demos | 该项目在GitHub上的主页 |
| git仓库地址(https) | https://github.com/zq2599/blog_demos.git | 该项目源码的仓库地址,https协议 |
| git仓库地址(ssh) | git@github.com:zq2599/blog_demos.git | 该项目源码的仓库地址,ssh协议 |
这个git项目中有多个文件夹,本章的两个应用分别在webdemo和k8sgatewaydemo文件夹下;
下图红框中是webdemo应用的源码:

下图红框中是k8sgatewaydemo应用的源码:

下面是详细的编码过程;
<>开发webdemo
webdemo是个极其普通的spring boot应用,和SpringCloud没有任何关系;
- webdemo提供一个http接口,将请求header中名为extendtag的参数返回给请求方,controller类如下:
@RestController
@RequestMapping("/hello")
public class HelloController {
@RequestMapping(value = "time", method = RequestMethod.GET)
public String hello(HttpServletRequest request){
return "hello, "
-
new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())
-
", extendtag ["
-
request.getHeader("extendtag")
-
"]";
}
}
- 启动类WebdemoApplication.java:
@SpringBootApplication
public class WebdemoApplication {
public static void main(String[] args) {
SpringApplication.run(WebdemoApplication.class, args);
}
}
- 要注意的是pom.xml,里面通过名为fabric8-maven-plugin的maven插件,将webdemo快速部署到minikube环境:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
4.0.0
org.springframework.boot
spring-boot-starter-parent
2.1.6.RELEASE
com.bolingcavalry
webdemo
0.0.1-SNAPSHOT
webdemo
Demo project for Spring Boot
<java.version>1.8</java.version>
<spring-boot.version>2.1.6.RELEASE</spring-boot.version>
<fabric8.maven.plugin.version>3.5.37</fabric8.maven.plugin.version>
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-test
test
org.springframework.boot
spring-boot-maven-plugin
${spring-boot.version}
repackage
org.apache.maven.plugins
maven-deploy-plugin
${maven-deploy-plugin.version}
true
org.apache.maven.plugins
maven-surefire-plugin
${maven-surefire-plugin.version}
true
false
io.fabric8
fabric8-maven-plugin
${fabric8.maven.plugin.version}
fmp
resource
kubernetes
io.fabric8
fabric8-maven-plugin
${fabric8.maven.plugin.version}
fmp
resource
build
NodePort
- 以上就是webdemo应用的内容了,接下来要编译、构建、部署到minikube环境,在pom.xml执行以下命令即可:
mvn clean install fabric8:deploy -Dfabric8.generator.from=fabric8/java-jboss-openjdk8-jdk -Pkubernetes
部署完成后终端输出类似如下成功信息:
INFO
INFO\] \<\<\< fabric8-maven-plugin:3.5.37:deploy (default-cli) \< install @ webdemo \<\<\< \[INFO
INFO
INFO\] --- fabric8-maven-plugin:3.5.37:deploy (default-cli) @ webdemo ---
\[INFO\] F8: Using Kubernetes at https://192.168.121.133:8443/ in namespace default with manifest /usr/local/work/k8s/webdemo/target/classes/META-INF/fabric8/kubernetes.yml
\[INFO\] Using namespace: default
\[INFO\] Updating a Service from kubernetes.yml
\[INFO\] Updated Service: target/fabric8/applyJson/default/service-webdemo.json
\[INFO\] Using namespace: default
\[INFO\] Updating Deployment from kubernetes.yml
\[INFO\] Updated Deployment: target/fabric8/applyJson/default/deployment-webdemo.json
\[INFO\] F8: HINT: Use the command `kubectl get pods -w` to watch your pods start up
\[INFO\] ------------------------------------------------------------------------
\[INFO\] BUILD SUCCESS
\[INFO\] ------------------------------------------------------------------------
\[INFO\] Total time: 11.804 s
\[INFO\] Finished at: 2019-07-07T21:32:26+08:00
\[INFO\] ------------------------------------------------------------------------
5. 查看service和pod,确认一切正常:
\[root@minikube webdemo\]# kubectl get service
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes ClusterIP 10.96.0.1 443/TCP 29d
webdemo NodePort 10.106.98.137 8080:30160/TCP 115m
\[root@minikube webdemo\]# kubectl get pod
NAME READY STATUS RESTARTS AGE
webdemo-c9f774b9-gsbgx 1/1 Running 0 3m13s
6. 使用minikube命令取得webdemo服务对外暴露的地址:
\[root@minikube webdemo\]# minikube service webdemo --url
http://192.168.121.133:30160
可见外部通过地址:[http://192.168.121.133:30160]() 即可访问到webdemo应用;
7. 在浏览器输入地址:[http://192.168.121.133:30160/hello/time]() ,即可验证webdemo的http接口是否正常,如下图,由于header中没有extendtag属性,因此返回的extendtag为null:

至此,webdemo在minikue上已经正常运行,该开发gateway应用了;
#### <>开发k8sgatewaydemo
1. 基于maven创建一个名为k8sgatewaydemo的springboot应用,pom.xml内容如下:
\
\
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

独家面经总结,超级精彩
本人面试腾讯,阿里,百度等企业总结下来的面试经历,都是真实的,分享给大家!
外链图片转存中...(img-Kib3bznK-1712679411301)
外链图片转存中...(img-GFb1nDXe-1712679411302)
外链图片转存中...(img-S68zEA44-1712679411302)
外链图片转存中...(img-k6dogSOX-1712679411302)
Java面试准备
准确的说这里又分为两部分:
- Java刷题
- 算法刷题
Java刷题:此份文档详细记录了千道面试题与详解;
外链图片转存中...(img-MVnb35cl-1712679411302)
外链图片转存中...(img-Jhu0h2KV-1712679411302)
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!