api-gateway实践(02)新服务网关 - 运行环境
一、服务网关的运行环境
1、服务配置中心
1.1、服务配置中心前台
前台 http://10.110.17.20/#/login:无源码,德奎部署在10.110.17.20的DockerStatck环境。
访问 http://10.110.17.20/#/login admin/123456a?
目前在dockerstack的前台中,随dockerstack一起启动!

1.2、服务配置中心后台
api-gateway-controller: springboot应用,配置中心前台用来保存服务定义到mysql数据库和发布服务定义到redis缓存。
- 保存和提取配置中心的数据,
- 使用mysql存储配置数据
- 使用redis缓存配置数据,供网关引擎使用。
2、服务网关引擎
服务网关引擎 api-gateway-engine:zuul工程,从redis读取服务定义,处理业务请求。
开源的zuul工程api-gateway-engine,采用gradle管理项目依赖,
- 读取redis中缓存的配置中心数据(api定义),不直接和配置中心打交道,而是通过redis解耦合。
- 拦截服务请求,进行权限检查
- 拦截服务请求,进行请求转发
gradle build
gradle jettyRun
使用 redis:10.110.17.20 : 6379
3、服务提供者应用
服务提供者:提供服务实现业务,任何一个提供http服务的web应用,都可以作为一个服务提供者应用,将其url注册到配置中心。
4、服务调用者应用
服务消费者:使用网关提供的服务,遵循网关服务调用的申请流程,
4.1、申请身份+授权
4.2、携带身份+授权,获取accessToken
4.3、携带access_token,访问服务网关业务
二、服务网关运行环境的启停
准备工作:
先要关掉centos7的防火墙!!!!
systemctl status firewalld
systemctl stop firewalld
1、启动配置中心
1.1、启动配置中心的 mysql 数据库
启动:systemctl start mariadb
查看:systemctl status mariadb
开机启动:systemctl enable mariadb (已设置)
1.2、启动配置中心的 redis 缓存
启动:systemctl start redis
查看:system status redis
开机启动:systemctl enable redis(已设置)
1.3、启动配置中心的服务层(api-gateway-controller)
这是个springBoot应用,api-gateway-controller.jar包在root下
启动:
cd /root
nohup java -jar api-gateway-controller.jar &
1.4、启动配置中心的界面层 - dockerstatck(德奎)
2、启动网关引擎(api-gateway-engine.war)
这是个jetty应用,发布在docker中。
启动:systemctl start dockerstack
查看:systemctl status dockerstack
开机启动: systemctl enable dockerstack
3、启动服务提供者
cd /opt/tomcat8.5.15/bin
./startup.sh
生成mobile的access_token, http://10.110.17.20:7070/spring-oauth-server/m/user_info?access_token=x验证服务提供者可用!!!!!!
4、启动服务消费者
此处使用postman/浏览器代替
api-gateway实践(02)新服务网关 - 运行环境的更多相关文章
- api-gateway实践(04)新服务网关 - 新手入门
一.网关引擎环境 1.下载代码 2.搭建环境 3.打包部署 二.配置中心环境 1.下载代码 2.搭建环境 3.打包部署 三.创建业务实例 1.以租户身份登录配置中心,注册 group.version. ...
- api-gateway实践(08)新服务网关 - 云端发布和日志查看
一.发布应用 1.新建应用空间 1.1.新建应用空间 1.2.新建应用 1.3.上传程序包 2.创建应用引擎服务 3.发布应用 3.1.为应用容器绑定Web运行环境(应用引擎服务) 3.2.发布应用( ...
- Spring Cloud开发实践 - 02 - Eureka服务和接口定义
服务注册 EurekaServer Eureka服务模块只有三个文件, 分别是pom.xml, application.yml 和 EurekaServerApplication.java, 内容如下 ...
- api-gateway实践(10)新服务网关 - OpenID Connect
网关指南: https://help.aliyun.com/document_detail/29487.html?spm=5176.doc48835.6.550.23Oqbl 网关控制台: https ...
- api-gateway实践(06)新服务网关 - 请求监控
一.实时监控 用户点击服务实例,系统显示服务实例-version下的api列表, 用户点击某个api的如下两个图标 1.API请求次数监控 横轴:时间,粒度为分钟 纵轴:请求访问次数 展示:失败数(红 ...
- api-gateway实践(03)新服务网关 - 网关请求拦截检查
参考链接:http://www.cnblogs.com/jivi/archive/2013/03/10/2952829.html 一.为什么要拦截检查请求? 防止重放攻击.篡改重放,进行使用规格检查 ...
- api-gateway实践(13)新服务网关 - 断路保护/熔断机制
参考链接:SpringCloud的Hystrix(五) Hystrix机制 新需求列表 1.在线测试 根据定义,生成输入界面, 点击测试, 验证参数,发起调用,返回执行结果 2.熔断保护 两个实现类: ...
- api-gateway实践(07)新服务网关 - 手动发布
应用地址:http://10.110.20.191:8080/api-gateway-engine/ 一.准备工作 1.xshell登陆云主机 1.1.配置链接 1.2.链接成功 1.3.关闭防火墙 ...
- [转载] 构建微服务:使用API Gateway
原文: http://mp.weixin.qq.com/s?__biz=MzA5OTAyNzQ2OA==&mid=206889381&idx=1&sn=478ccb35294c ...
随机推荐
- Java集合框架(二)
原文 http://www.jianshu.com/p/2070cb32accb List接口 查阅API,看 List 的介绍.有序的 collection (也称为序列).此接口的用户可以对列表 ...
- python初识(二)
伟大的"hello world" print("hello world") 第一个简单的python程序就搞定了 浅谈python语言的特点: 1. 语法简洁: ...
- Filecoin协议(挖矿)
Filecoin协议是如何运作的? 用户如何使用Filecoin系统来查询,存储数据? 存储矿工如何挖矿,如何获取FIL代币? 检索矿工如何挖矿,获取FIL代币? 本文主要回答上面的这些问题!!! 首 ...
- http协议中302和303的区别
http1.0协议中只有302码,没有303状态码:http1.1,在默认情况下,很多服务端基础程序,为了兼容http1.0,在遇到本应响应303时,也给客户端响应了302. 碰到的问题: 场景: 在 ...
- Linux基础命令详解
1 遍历目录 cd:change dicrectory的缩写 .或者./代表当前目录,..或../代表上一级目录,cd -代表进入上一次的目录. 2 文件和目录列表 ls:list的缩写,会显示目录下 ...
- 最小生成数(并查集)Kruskal算法
并查集:使用并查集可以把每个连通分量看作一个集合,该集合包含连通分量的所有点.这两两连通而具体的连通方式无关紧要,就好比集合中的元素没有先后顺序之分,只有属于和不属于的区别.#define N 100 ...
- 百度API地图的标注不居中显示,而显示在左上角
前言:今天弄个百度地图,弄了半天就是不居中,之前使用一直没有遇到这个问题.所以就一直在找原因. 百度地图对地图所在的div做了显示隐藏之类操作,标注就不再居中显示,而显示在左上角. 查了很久,有人提出 ...
- mysql授权报错
mysql> grant all privileges on zabbix.* to zabbix@localhost identified by '<zabbix>';ERROR ...
- 爬虫(scrapy第一篇)
---------------------------------------------------------------------------------------------------- ...
- echarts词云引用
最近项目中需要使用echarts的词云图,因为几经波折才引用成功,所以想记下来跟大家分享,(我的随笔不会写那么多让人需要动脑子去理解的东西,就是记录一下步骤,因为经验甚少,底层原理懂得不多,所以就先记 ...