gateway网关_宜信开源|SIA-GateWay之API网关安装部署指南

SIA-GATEWAY是基于SpringCloud微服务生态体系下开发的一个分布式微服务网关系统。具备简单易用、可视化、高可扩展、高可用性等特征,提供云原生、完整及成熟的接入服务解决方案。本文介绍API网关的安装部署。

一、环境

1.1 编译环境

  • Maven3+
  • nodejs
  • Jdk1.8+

1.2 运行时第三方依赖

  • Mysql5.6+
  • elasticsearch 5.5.2
  • kibana-5.5.2
  • kafka 2.12-2.0.0
  • redis 3.2.11
  • eureka-server

1.3 运行环境

  • 64bit OS,Linux/Mac/Windows/docker
  • JDK1.8+

二、源码下载

git clone https://github.com/siaorg/sia-gateway.git

2.1 源码结构如下:

.├── sia-gateway-admin-buildcomponent 网关admin组件集合│ ├── sia-gateway-admin 网关admin监控系统组件│ ├── sia-gateway-synchspeed 网关对下游服务实时感知组件│ ├── sia-gateway-stream 网关日志组件│ ├── sia-gateway-service 网关系统辅助组件│ ├── sia-gateway-monitor 网关监控、日志组件│ │ ├── sia-gateway-reactive │ │ ├── sia-gateway-messaging 基础依赖 │ │ ├── sia-gateway-sink│ │ ├── sia-gateway-esclient│ │ ├── sia-gateway-base├── sia-gateway-admin-display 网关系统前端代码├── sia-gateway-buildcomponent 网关core-buildcomponent│ ├── sia-gateway-core 网关Core节点│ │ ├── sia-gateway-base│ │ ├── sia-gateway-messaging 基础依赖│ │ ├── sia-gateway-reactive│ │ ├── sia-gateway-template

三、初始化“API网关数据库”

1)MySQL的安装和配置详见MySQL官方文档

2)请下载项目源码并解压,获取 "API网关数据库初始化SQL脚本" 并执行即可。

"API网关数据库初始化SQL脚本" 位置为:

/sia-gateway/sia-gateway-admin/src/main/resources/db/gateway_admin.sql

四、配置“网关系统”

4.1 网关配置文件地址

# 网关admin中心conf/sia-gateway/sia-gateway-admin-buildcomponent/config/gateway_admin_test.yml# 网关监控服务conf/sia-gateway/sia-gateway-admin-buildcomponent/config/gateway_monitor_test.yml# 网关辅助节点conf/sia-gateway/sia-gateway-admin-buildcomponent/config/gateway_service_test.yml# 网关日志服务conf/sia-gateway/sia-gateway-admin-buildcomponent/config/gateway_stream_test.yml# 网关实时感知服务conf/sia-gateway/sia-gateway-admin-buildcomponent/config/gateway_synchspeed_test.yml# 网关核心节点conf/sia-gateway/sia-gateway-buildcomponent/config/gateway_test.yml

1)gateway_admin_test.yml

a25b1ac4c7e67174b5cdef2e158b67f5.png
a9b06ab66a84138e186ace58558b6f64.png

2)gateway_service_test.yml

a9e09fe3513767b4341182b55aa14a77.png

3)gateway_stream_test.yml

d045f8ef0c7de766c556ceaf852a68ab.png

4)gateway_synchspeed_test.yml

5612242af9d38b6e1ab9b6bcab4dded0.png

5)gateway_monitor_test.yml

618ee0d8b14da0a11f7c5b0227909de7.png

6)gateway_test.yml

49d956c22999035b4fc22f34c9f4b8e6.png
ea027767b7bc7ff1f7eaaff77ecde30c.png
99b7f289e95ce62f6f21612ad2d72acf.png

说明:spring.application.name为网关组名称,开发者可以修改此属性,搭建新的网关组

4.2 maven 仓库地址配置

 alimavenaliyun mavenhttp://maven.aliyun.com/nexus/content/groups/public/centraljdk-1.8  true 1.81.81.81.8downloadSourcestruetruespring pluginsspring pluginsspring pluginsSpring pluginshttps://maven.aliyun.com/repository/spring-plugindefaultalways  downloadSources  

五、构建部署项目

5.1 编译项目

1)如果已经正确进行上述配置,可将项目编译打包部署。

2)操作步骤:

 cd sia-gateway  chmod +x *.sh  sh build.sh

3)打包成功后,会出现以下标注文件。

  • /sia-gateway/sia-gateway-admin-buildcomponent/target/gatewayadmin1.0.zip
04baba197787f00bd01e6d90395eca10.png
  • /sia-gateway/sia-gateway-buildcomponent/target/gateway_1.0.zip
61771e67c3291b9282a961827798de43.png
  • /sia-gateway/sia-gateway-admin-display/dist/
1a765aca97ed6913b5415c5c391796ab.png

注:前端打包需要用到nodeJs,如未安装,可请参考 nodejs安装文档。

5.2 部署项目

  • API网关系统的部署方式为分布式部署集中式管理模式,即网关Core节点可以按业务线划分为不同的网关组,网关管理端作为网关的管理中心,供统一的管理界面,用户可在此进行 API、组件、系统基础信息的设置和维护,收集监控日志、生成各种运维管理报表、自动告警等。
  • sia-gateway-admin-buildcomponent是网关管理端组件集,包括:admin、stream、service、synchspeed、monitor;管理端部署单个节点即可(目前不支持集群)。
  • sia-gateway-buildcomponent为网关Core组件,可以按业务线分组,组内以单节点或集群方式部署。

5.3 Vmware方式部署

1)后端部署

unzip gateway_admin_1.0.zipcd /gatewayadmin/binchmod +x *.sh #启动网关管理服务,包括:admin、stream、service、synchspeed、monitor。sh onekey_start.sh---------------------------------------------------unzip gateway_1.0.zipcd /gateway/binchmod +x *.sh #启动网关Core服务sh start_gateway_test.sh

2)前端部署

  • 修改前端site-map.js
9d58184ab0a74d7dd19fe71064749e69.png
  • nginx的代理配置,进入nginx的目录下nginx.conf,添加如下配置:
 upstream apigateway.open.location1 {  #### sia-gateway-admin服务IP server *******:8090 ;  } server { # nginx 监听端口 listen 18086; server_name localhost; access_log logs/host.access.log main; #access_log "pipe:rollback logs/host.access_log interval=1d baknum=7 maxsize=2G" main; location / { #root html; #index index.html index.htm; root /app/jar/ROOT/dist; index index.html index.htm; } # 后端服务location  location ^~ /vv1/ { proxy_pass http://apigateway.open.location1/;  proxy_set_header Host $host;  proxy_set_header X-Real-IP $http_x_forwarded_for;  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  proxy_http_version 1.1; } error_page 500 502 503 504 /50xcn.html; location = /50xcn.html { root html/error_page; index 50xcn.html; } location /check_status { vhost_traffic_status_display; vhost_traffic_status_display_format json; } }
  • 重启nginx
#校验配置是否正确./nginx -t# 重新启动./nginx -s reload

5.4 Docker 镜像方式部署

说明:如果docker环境和编译环境是在同一个操作系统上,可直接执行以下步骤;反之,需要先将以下文件按原目录结构上传docker环境所在服务器。

  • /sia-gateway/sia-gateway-admin-buildcomponent/target/gatewayadmin1.0.zip
  • /sia-gateway/sia-gateway-buildcomponent/target/gateway_1.0.zip
  • /sia-gateway/sia-gateway-admin-display/dist/
  • /sia-gateway/third-libary
  • /sia-gateway/build.sh
  • /sia-gateway/docker-start.sh
  • /sia-gateway/docker-run.sh
  • /sia-gateway/Dockerfile

步骤:

1)配置:修改site-map.js,位置:/dist/static/site-map.js

 /** * vmware部署: 127.0.0.1 ----> nginx的ip地址 * docker镜像部署: 127.0.0.1 ----> docker容器的宿主机ip */ 'CESHI_API_HOST': '127.0.0.1:18086/vv1',  /** * 127.0.0.1 ----> kibana的ip地址 */ 'CESHI_API_HOST_LOG': '127.0.0.1:5601'

2)下载centos基础镜像,如果已经下载,此步忽略。

3)修改Dockerfile,FROM 镜像名 : 版本号

a009b7a115f040963016c3aabe0dd7d6.png

4)配置yum源,如果部署机器能够使用阿里yum源,此步忽略。

将yum源文件名称修改成 CentOS-Base.repo,并替换到/sia-gateway/third-libary/下

5)构建镜像,并启动容器和服务

 # 构建镜像 cd /sia-gateway/   # 授权 chmod +x *.sh  # 构建镜像 sh docker-build.sh  # 启动容器和服务 sh docker-run.sh  # 查看容器是否启动成功 docker ps   # 进入容器查看服务运行情况 docker exec -it gateway-test:v1 bash

访问地址: http://宿主机IP:18086/

8eb2bb30c503ea386150b01c9ce3a314.png
8088e2b87806c362c18dbbf5ddc75453.png

说明:

  • Docker镜像部署方式是我们为方便开发者简单、快速地基于docker环境搭建网关系统而提供的一种ALL-IN-ONE形式的网关部署Demo,即网关监控服务、预警、网关核心节点等都构建在一个docker镜像中;开发者可以根据开发环境条件来灵活选择部署方案,推荐使用vmware+docker镜像部署方式,即将网关管理端服务部署在vmware上,网关核心节点部署在docker环境中。

SIA相关开源产品链接

  • 微服务任务调度框架:sia-task:https://github.com/siaorg/sia-task
  • 微服务路由网关:sia-gateway :https://github.com/siaorg/sia-gateway
  • Rabbitmq队列服务PLUS:sia-rabbitmq-plus:https://github.com/siaorg/sia-rabbitmq-plus
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值