1.SOA架构介绍
SOA (Service Oriented Architecture)“面向服务的架构":是一种设计方法,其中包含多个服务,服务之间通过相互依赖最终提供一系列的功能。一个服务通常以独立的形式存在与操作系统进程中。各个服务之间通过网络调用。
微服务架构=80%的SOA服务架构思想+100%的组件化架构思想+80%的领域建模思想
微服务架构是在SOA的基础上进行了升华,它强调业务需要彻底的组件化和服务化。
在微服务架构中,原有的单个业务系统会被拆分为多个可以独立开发、设计、运行的小应用。
这些小应用之间通过服务完成交互和集成,每个微服务都可以被单独部署和扩展。
2.应用代码示例
如上图所示,在k8s环境中的容器暴露了两个service,分别是服务A与服务B
- 服务A kubeflow-dashboard:python代码实现,该服务为kubeflow相关的业务后端容器,其中包括启动notebook、pipeline、k8s等相关功能
- 服务B xxx-service:go代码实现,该服务为平台相关的容器,如资源购买、用户鉴权、计费等功能
2.1 服务B调用服务A的restapi
首先根据k8s暴露出的service,当然由于是ClusterIP的service,故只能在集群内部访问,服务访问链接如下所示
# 域名访问http://kubeflow-dashboard.infra/
CubeStudioUrl := "http://kubeflow-dashboard.infra/"
# ip访问http://21.201.27.12/
clusterIP := service.Spec.ClusterIP
FrontExternalIpSchema := "http://" + clusterIP + "/"
因此,我们直接根据以上暴露的服务与接口即可调用服务A,如下所示。
2.2 服务A调用服务B的restapi
与上例类似,仅有语法区别