女主宣言

360私有云容器服务团队和人工智能研究院团队一起配合,在云端提升机器学习的效能方面进行了深入的研究和实践,为业务提供了“人脸检测”、“花屏检测”、“色情检测”、“宠物检测”、“图片风格化”、“文字识别”、“智能裁图”等多种深度学习服务。

下面主要介绍实践中涉及的“微服务网关与容器服务”技术。

PS:丰富的一线技术、多元化的表现形式,尽在“360云计算”,点关注哦!

微服务网关(kong)与容器服务

1

什么是微服务架构

微服务是一种构建软件的架构和方法。在微服务中,以前的单体应用被拆分成多个小的组件,并彼此独立。不同于将所有组件内置于一个架构中的传统单体式应用的构建方法,在微服务架构中,所有的部分都是相互独立的(可以使用不同的语言,不同团队来开发不同的服务模块)。通过合作来完成相同的任务。其中的每一个组件或流程都是微服务。总结微服务的特点就是:更小,更快,更强。

可能通过上面对微服务的描述还是不是特别的直观,将传统的单体应用架构和微服务架构进行下比较,就比较直观了。

单体应用架构

最早对于web程序的开发(比如JAVA),通常将整个程序打包到一个WAR文件中,然后直接部署到服务器即可。

单体应用架构易于测试和部署,但是在服务的可伸缩性,可靠性, 系统迭代, 跨语言程序, 团队协作等方便没有微服务方便。

微服务架构

为了解决单体应用架构的这些诸多弊端(不是说单体应用架构不好,需要根据不同的业务场景选择不同的服务架构),可以将单体应用架构拆分成多个独立的小的组件。 这样就可以每个团队使用自己的技术栈来实现自己的组件,并在系统迭代的时候独立的进行迭代而不影响整个应用的整体使用。

2

为什么需要微服务网关

首先介绍下什么是API网关,API网关可以提供一个单独且统一的API入口用于访问内部一个或多个API服务。API网关常会提供负载均衡,访问频率限制,认证授权,监控,缓存等功能。

通过API网关,可以将内部服务对外部用户隐藏,而暴露给外部用户真实需要的API,并可以对外部访问进行访问频率的限制同时还可以对外部的用户设置认证授权。来保证应用整体的稳定及安全等等。而网关内部的服务则可以根据自己的需求通过相关的协议(REST API, GRPC)进行通信。

3

微服务网关(kong)介绍

kong是一款基于nginx_lua模块写的高可用,易扩展的API网关。由于kong是基于nginx的,所以可以水平的扩展多个kong服务实例,通过前置的负载均衡配置把请求均匀地分到各个server,来应对大批量的网络请求。

kong网关组成:

  • Kong server: 基于nginx的服务器,接收外部的api请求。

  • PostgreSQL: 用来存储操作的数据。

并且kong采用插件机制进行功能的定制,插件集在API请求响应循环的生命周期中被执行。插件使用lua编写。

4

微服务网关与容器服务结合使用

通过一个具体的例子来描述部署到容器上的服务是如何与微服务网关结合使用的。比如我们现在有人脸检测, 宠物检测, 鉴黄服务等将这个单独的服务组成一个完成的应用实体来对外提供多功能的服务。

1. 首先在容器服务平台上部署我的三个服务实例(人脸检测,宠物检测,鉴黄服务)。并为这些服务实例申请vip。

2. 服务注册完成之后,管理端将这三个服务注册到微服务网关(kong),kong会将注册的信息持久化到PostgreSQL数据库。并可以根据不同的业务为各个服务已插件的形式注册认证授权,访问频率限制,CORS等插件。

3. 当服务注册完成之后,用户端可以基于被授权的用户token去访问他们想要使用的服务。

本文只是简单地介绍了下整体的流程。但是每一个部分都需要用户自己去深入了解了~~

相关文章

  • https://konghq.com/kong-community-edition/

  • https://martinfowler.com/articles/microservices.html?spm=a2c4e.11153940.blogcont2764.12.61092766Awrptv

  • https://github.com/Kong/kong

  • https://www.redhat.com/zh/topics/microservices

  • https://www.nginx.com/blog/introduction-to-microservices/

最新活动

在搜索、推荐,电商等场景下,用户数据规模持续爆炸性增长,而同时用户对产品实时性要求越来越高,但只有少数公司真正具备了提供这种大规模海量数据的实时服务引擎能力。

本次活动我们邀请了来自360、京东、滴滴的多位资深技术专家现场分享来自第一线的大规模服务架构实践经验,覆盖了对象存储系统、微服务、数据库、搜索引擎等多个领域。

精彩内容都在

360互联网技术训练营第十五期——大规模服务架构实践

识别下方二维码或点击阅读原文,立即报名

360云计算

由360云平台团队打造的技术分享公众号,内容涉及数据库、大数据、微服务、容器、AIOps、IoT等众多技术领域,通过夯实的技术积累和丰富的一线实战经验,为你带来最有料的技术分享

容器赋能AI-人工智能在360私有云容器服务上的实践相关推荐

  1. 360私有云容器镜像仓库简介

    奇技指南 镜像仓库,顾名思义就是存储镜像的.Docker 仓库的概念跟Git 类似,注册服务器可以理解为 GitHub 这样的托管服务.用户制作好镜像push到仓库,这样下次在另外一台机器上使用这个镜 ...

  2. 360私有云平台Elasticsearch服务初探

    Elasticsearch Elasticsearch 是一款基于Apache Lucene框架构建的开源的.分布式的.可扩展的.(准)实时的文档存储和搜索引擎.在提供搜索服务以及日志分析方面已经日趋 ...

  3. 360私有云发布Windows平台测试版

    游侠安全网在前一段曾经给大家介绍过360私有云的一些情况(原文).当时的系统基于CentOS,而今天游侠拿到的版本则是Windows版本. 当然,Windows下的360私有云部署是非常简单的,安装包 ...

  4. VMware+CentOS7搭建私有云桌面服务

    VMware+CentOS7搭建私有云桌面服务 1. 安装VMware虚拟机工作台 官网下载安装包 版本:14.1.3 Pro 地址:https://my.vmware.com/en/web/vmwa ...

  5. 梅林固件路由器搭建私有云盘服务

    梅林固件路由器搭建私有云盘服务 1.开放路由器ssh登录 2.ssh登录路由器 3.安装服务 安装entware vi entware-ngu-setup.sh # 复制文末脚本内容 chmod +x ...

  6. 用多备份将网站数据备份到百度云,七牛云存储,阿里云OSS,亚马逊S3,金山云等云存储服务上

    真正运营过网站的人都知道,数据对一个网站来说至关重要,因此,网站数据备份也是日常必做工作.因为误操作,网站被攻击等种种原因都会导致数据丢失,这时,你才会明白"有备无患"的道理.备份 ...

  7. 360私有云平台-HULK 5岁啦~

    HULK五周年 2017 12.25 祝大家圣诞节快乐哦- 今天也是HULK宝宝来到360的第1825天. 喏~~这是小HULK的自我介绍 HULK云平台是奇虎360WEB平台部于2012年底开始立项 ...

  8. 360 私有云平台 MySQL 自动化实现剖析

      本文源自 7 月 13 日『高效开发运维』微信群的在线分享,转载请在文章开头注明来自『高效开发运维』公众号.加群学习请关注『高效开发运维』公众号,并点击菜单中的"加群学习"或直 ...

  9. 让业务容器化更安全便捷,阿里云容器镜像服务 ACR 推出免费制品中心

    作者:容器镜像服务团队 伴随着企业 IT 数字化转型演变的进程,越来越多的企业采用云原生化架构升级的方式,改善应用开发运维迭代的效率,加速企业业务创新:改进资源弹性管理和迁移的效率,帮助企业降本增效. ...

最新文章

  1. android 壁纸 裁剪,Android图片裁剪之自由裁剪
  2. 你必须知道的ADO.NET(一) 初识ADO.NET
  3. python大一考试_python 考试补缺
  4. VMware QueryPerformanceCounter/GetTickCount 悬案
  5. 【数据竞赛】图像赛排行榜拉开100名差距的技巧
  6. 列出和过滤NIO.2中的目录内容
  7. 2018-2019-1 20189213《Linux内核原理与分析》第四周作业
  8. c语言cin cou头文件,c+第五次实验
  9. python 数据结构与算法 day04 快速排序
  10. 小米回应造车传闻;饿了么就春节“套路”骑手活动致歉;Go 1.16 正式发布 | 极客头条...
  11. Lucene.NET入门实例
  12. No module named ‘win32com‘
  13. Babelua 调试
  14. 计算机一级大学生一定要考吗,关于大学大学生要考计算机一级吗
  15. 一碗泡面背后的努力,康师傅连续十次斩获“食安管理十强企业”
  16. Buuctf --hellow world
  17. 轻松完成word格式的接口文档
  18. Openstack-nova(placement)组件部署流程
  19. 在计算机上打印机驱动程序,如何安装打印机驱动程序,小编教你如何给电脑安装打印机驱动程序...
  20. audio实现歌词同步

热门文章

  1. 《天下无贼》经典对白
  2. 诗与远方:无题(一)
  3. JSP小项目,会员管理系统之实现登录功能
  4. SpringCloud创建Gateway模块
  5. Storm集群开启HA高可用
  6. maven 打包部署时访问远程仓库中没有的jar
  7. arraychangekeycase php,浅谈php数组array_change_key_case() 函数和array_chunk()函数
  8. c语言常用算法分析 微盘,C语言常用算法归纳.pdf
  9. JDK8的JVM优化实操及部分原理加深理解
  10. 小知识:vue中的name的作用