概述

Kong 是在客户端和(微)服务间转发API通信的API网关,通过插件扩展功能。

Kong 的官方网站,https://konghq.com/kong

Kong 的官方 Github 站点:https://github.com/kong/kong

Kong 有两个主要组件:

Kong Server :基于 nginx 的服务器,用来接收 API 请求。

Apache Cassandra :用来存储操作数据。

Kong 的数据存储支持两个组件,Cassandra 和 PostgreSQL 。

Kong 官方推荐的 GUI 工具叫 Kong-Dashboard,但是友好度不太好。

Kong 还有一个 GUI 的工具叫做 KongA,GitHub 地址是 https://github.com/pantsel/konga

你可以通过增加更多 Kong Server 机器对 Kong 服务进行水平扩展,通过前置的负载均衡器向这些机器分发请求。根据文档描述,两个Cassandra节点就足以支撑绝大多数情况,但如果网络非常拥挤,可以考虑适当增加更多节点。

对于开源社区来说,Kong 中最诱人的一个特性是可以通过插件扩展已有功能,这些插件在 API 请求响应循环的生命周期中被执行。插件使用 Lua 编写,而且 Kong 还有如下几个基础功能:HTTP 基本认证、密钥认证、CORS( Cross-origin Resource Sharing,跨域资源共享)、TCP、UDP、文件日志、API 请求限流、请求转发以及 nginx 监控。

Kong 包可运行在部分的 Linux 发行版(包括CentOS、RHEL、Debian、Ubuntu)、Mac OS X 和 Docker 、Kubernetes、AWS-cloud、Google-Cloud 中,无论是本地机还是云端服务器皆可运行。

除了免费的开源版本,Mashape 还提供了付费的企业版,其中包括技术支持、使用培训服务以及 API 分析插件。

基于 rpm 安装

当前基于 CentOS 7 进行安装。

当前 Kong 的最新版本是 1.3.0 。

下载软件包可以从官方地址下载

https://bintray.com/kong/kong-rpm/download_file?file_path=centos/7/kong-1.3.0.el7.amd64.rpm

也可以使用yum 仓库进行下载,

修改 yum 仓库的 repo 文件的 baseurl 路径为:

  1. baseurl=https://kong.bintray.com/kong-rpm/centos/7

我们接下来使用 yum 的 epel 源来进行安装。

安装 rpm 包

  1. yum install epel-release
  2. yum install kong-1.3.0.*.noarch.rpm --nogpgcheck

安装数据存储的数据库

Kong 在运行过程中可以有数据库,也可以没有数据库。

如果你要使用数据库,你需要使用 kong.conf 配置文件中去配置启动数据库作为数据存储的方式,以及相应的路由或者 Kong 的代理。

如果你不需要使用数据数据库,那么你在 kong.conf 文件中指定一个 kong.yml的声明式配置文件来作为数据存储的文件。

Kong 支持 PostgreSQL 9.5+ 和 Cassandra 3.xx 来作为他的数据存储数据库。

如果使用数据库:

如果你使用 PostgreSQL ,需要初始化一个数据库和一个用户,例如:

  1. CREATE USER kong; CREATE DATABASE kong OWNER kong;

现在 运行 Kong migrations

  1. kong migrations bootstrap [-c /path/to/kong.conf]

如果不使用数据库:

如果要以无db模式运行Kong,应该首先生成声明性配置文件。使用下面的命令在当前的文件夹下,生成一个普通的 kong.yml

  1. kong config init

在生成好 kong.yml 文件后,编辑你的 kong.conf 文件,设置如下参数:

  1. database = off
  2. declarative_config = /path/to/kong.yml

启动 kong

  1. kong start [-c /path/to/kong.conf]

如果要停止,请使用如下命令来停止

  1. kong stop

重载命令是

  1. kong reload

使用 Kong

Kong 默认运行在本地的 8001 端口

  1. curl -i http://localhost:8001/

基于 Docker 安装 Kong

使用数据库

接下来可以快速的连接到 Kong 容器以及他的数据库容器。

创建 Docker 网络

需要创建一个自定义的网络,运行容器发现并且彼此之间通信,接下来创建一个名称为 kong-net 的网络,也可以使用其他名称。

  1. docker network create kong-net

启动数据库

如果你想要使用 Cassandra 容器

  1. docker run -d --name kong-database \
  2. --network=kong-net \
  3. -p 9042:9042 \
  4. cassandra:3

如果你想要使用 PostgreSQL 容器

  1. docker run -d --name kong-database \
  2. --network=kong-net \
  3. -p 5432:5432 \
  4. -e "POSTGRES_USER=kong" \
  5. -e "POSTGRES_DB=kong" \
  6. postgres:9.6

初始化数据库

运行 migrations 使用一个短暂的 Kong 容器

  1. docker run --rm \
  2. --network=kong-net \
  3. -e "KONG_DATABASE=postgres" \
  4. -e "KONG_PG_HOST=kong-database" \
  5. -e "KONG_CASSANDRA_CONTACT_POINTS=kong-database" \
  6. kong:latest kong migrations bootstrap

在上边的示例中,需要你自行修改你的 KONG_DATABASE 参数。

启动 Kong

当 migration 已经执行,并且数据库已经准备好,启动 Kong 容器来连接数据库容器,比如:

  1. docker run -d --name kong \
  2. --network=kong-net \
  3. -e "KONG_DATABASE=postgres" \
  4. -e "KONG_PG_HOST=kong-database" \
  5. -e "KONG_CASSANDRA_CONTACT_POINTS=kong-database" \
  6. -e "KONG_PROXY_ACCESS_LOG=/dev/stdout" \
  7. -e "KONG_ADMIN_ACCESS_LOG=/dev/stdout" \
  8. -e "KONG_PROXY_ERROR_LOG=/dev/stderr" \
  9. -e "KONG_ADMIN_ERROR_LOG=/dev/stderr" \
  10. -e "KONG_ADMIN_LISTEN=0.0.0.0:8001, 0.0.0.0:8444 ssl" \
  11. -p 8000:8000 \
  12. -p 8443:8443 \
  13. -p 8001:8001 \
  14. -p 8444:8444 \
  15. kong:latest

使用 Kong

Kong 运行在 8001

  1. curl -i http://localhost:8001/

无数据库模式

创建 Docker 网络

需要创建一个自定义的网络,运行容器发现并且彼此之间通信,接下来创建一个名称为 kong-net 的网络,也可以使用其他名称。

  1. docker network create kong-net

在没有数据库的模式下,不一定需要创建一个专用的网络,但是创建以后可以更好的用来添加其他内容,比如 Redis 集群支持的限速插件。

创建 Docker 卷

对于本指南的目的,Docker 卷是主机内的一个文件夹。可以将其映射到容器中的文件夹,我们给卷起一个名字,叫 kong-vol

  1. docker volume create kong-vol

使用 如下命令查看 卷的 挂载点路径

  1. $ docker volume inspect kong-vol
  2. [
  3. {
  4. "CreatedAt": "2019-05-28T12:40:09Z",
  5. "Driver": "local",
  6. "Labels": {},
  7. "Mountpoint": "/var/lib/docker/volumes/kong-vol/_data",
  8. "Name": "kong-vol",
  9. "Options": {},
  10. "Scope": "local"
  11. }
  12. ]

记录 MountPoint 的路径,下边会用到。

初始化配置文件

按照声明是配置文件的规范进行修改配置文件,添加必要的配置项,比如 serveice、route、plugins、consumer 等等,保存配置文件在 MountPoint 的路径下,本文会放在 /var/lib/docker/volumes/kong-vol/_data/kong.yml

在无数据库模式下启动 Kong

使用如下命令启动 Kong ,并且使用 -v 参数挂载数据卷,使用 -e 参数指定必须的环境变量。

  1. $ docker run -d --name kong \
  2. --network=kong-net \
  3. -v "kong-vol:/usr/local/kong/declarative" \
  4. -e "KONG_DATABASE=off" \
  5. -e "KONG_DECLARATIVE_CONFIG=/usr/local/kong/declarative/kong.yml" \
  6. -e "KONG_PROXY_ACCESS_LOG=/dev/stdout" \
  7. -e "KONG_ADMIN_ACCESS_LOG=/dev/stdout" \
  8. -e "KONG_PROXY_ERROR_LOG=/dev/stderr" \
  9. -e "KONG_ADMIN_ERROR_LOG=/dev/stderr" \
  10. -e "KONG_ADMIN_LISTEN=0.0.0.0:8001, 0.0.0.0:8444 ssl" \
  11. -p 8000:8000 \
  12. -p 8443:8443 \
  13. -p 8001:8001 \
  14. -p 8444:8444 \
  15. kong:latest

使用 Kong

Kong 启动后,就可以使用了,可以使用如下方式来访问 Kong

  1. curl -i http://localhost:8001/

比如,获取一个service 的列表

  1. curl -i http://localhost:8001/services

Kong 的默认端口

Kong 一切正常,启动以后会默认监听如下端口

  • :8000 Kong 监听来自客户端的传入 HTTP 请求,并将其转发到上游服务。
  • :8443 Kong 监听来自 HTTPS 流量,这个端口的行为类似于 :8000,只是用来监控 HTTPS 的请求,没有转发功能,这个端口可以在配置文件里关闭。
  • :8001 Admin API 接口用来对 Kong 的监听服务进行配置。
  • :8444 Admin API 监听 HTTPS 的流量。

小结

本文描述了 Kong 是什么,以及如何在 CentOS 下和 Docker 下进行安装。Kong 是 OpenResty 的一个应用组件,如果要从源码安装 Kong 的话,需要先安装 OpenResty,具体参考 Compile Source

Kong01-Kong 介绍的更多相关文章

  1. HTTP API网关选择之一Kong介绍

    为什么需要 API 网关 在微服务架构之下,服务被拆的非常零散,降低了耦合度的同时也给服务的统一管理增加了难度.如上图左所示,在旧的服务治理体系之下,鉴权,限流,日志,监控等通用功能需要在每个服务中单 ...

  2. kong介绍-个人分享

    kong简介 背景 我们在提供api或微服务时,通常借助openresty nginx进行流量转发或者添加一些规则或功能,但是随着服务数量和引用增多,复杂的网络环境, 使维护变得困难,不容易扩展,一些 ...

  3. 单机闭环 使用Nginx+Lua开发高性能Web应用

    [西域骆驼D1532101213]西域骆驼(VANCAMEL)D1532101213 休闲套脚鞋 卡其43[行情 报价 价格 评测]-京东 http://item.jd.com/1856564.htm ...

  4. OpenResty api 网关

    1,Orange网关 Orange是一个基于OpenResty的API网关.除Nginx的基本功能外,它还可用于API监控.访问控制(鉴权.WAF).流量筛选.访问限速.AB测试.动态分流等.它有以下 ...

  5. 1-Kong文章记录

    参考: https://www.cnblogs.com/duanxz/p/9770645.html 系列博客可参考: 开源API网关系统(Kong教程)入门到精通 https://www.cnblog ...

  6. API网关系列之Kong的介绍以及安装

    一.API网关产生背景 在微服务的架构中,一个大的应用会被拆分成多个小的单一的服务提供出来,这些小的服务有自己的处理,有自己的数据库(也可以共用),也许语言也是不一样的,他们可以部署在一个或多个服务器 ...

  7. Kong网关介绍与安装小记

    本文主要为kong安装小记,系统环境为centos 6.7                                本文转载请注明出处 —— xiaoEight 介绍 Kong 是在客户端和(微 ...

  8. API gateway 之 kong 基本介绍 (一)

    一.API网关概念介绍 API 网关,即API Gateway,是大型分布式系统中,为了保护内部服务而设计的一道屏障,可以提供高性能.高可用的 API托管服务,从而帮助服务的开发者便捷地对外提供服务, ...

  9. 网关服务Kong和konga介绍安装使用教程

    介绍 Kong是一款基于OpenResty(Nginx + Lua模块)编写的高可用.易扩展的,由Mashape公司开源的API Gateway项目.Kong是基于NGINX和Apache Cassa ...

  10. MySQL备份还原——AutoMySQLBackup介绍

    AutoMySQLBackup是一个开源的MySQL备份脚本.可以说它是一个轻量级的备份方案,AutoMySQLBackup的安装.配置非常简单.方便.AutoMySQLBackup的sourcefo ...

随机推荐

  1. php获取文件的文件名(误区)

    文件路径:$path = '/home/files/1234.jpg'; php获取文件名,大家应该是轻车熟路了,写个小函数,分分钟 <?php //获取文件名 function get_fil ...

  2. asp.net开源流程引擎API开发调用接口大全-工作流引擎设计

    关键词: 工作流引擎 BPM系统 接口调用 工作流快速开发平台  工作流流设计  业务流程管理   asp.net 开源工作流 一.程序调用开发接口二.   接口说明 所谓的驰骋工作流引擎的接口,在B ...

  3. Windows搭建SVN服务器

    安装 1.下载地址:https://www.visualsvn.com/files/VisualSVN-Server-4.0.3-x64.msi 2.开始安装: 3.安装配置: 4.Next直到完成 ...

  4. php微信支付v3版本签名生成

    前几天需要对接微信支付卡包营销活动需要对接微信新版SDKv3版 签名生成规则,微信的官方文档里面说明的还算可以吧,不过个人觉得不太理想- -.  自己调试的时候调试了半天才找了错误原因. https: ...

  5. 1.linux系统基础笔记(互斥量、信号量)

    操作系统是很多人每天必须打交道的东西,因为在你打开电脑的一刹那,随着bios自检结束,你的windows系统已经开始运行了.如果问大家操作系统是什么?可能有的人会说操作系统就是windows,就是那些 ...

  6. 编译 lame for iOS

    网上找了许多编译lame的教程,结果都是编译失败,多次尝试后发现是编译脚本放错路径了,记录下编译的过程,把编译脚本放到源码文件夹中和修改编译脚本中的目录是关键: 一.首先去Lame官网 http:// ...

  7. 基于KVM的SRIOV直通配置及性能测试

    SRIOV介绍.VF直通配置,以及包转发率性能测试 小慢哥的原创文章,欢迎转载 目录 ▪ 1. SRIOV介绍 ▪ 2. 环境说明 ▪ 3. 开启SRIOV ▪ 4. 生成VF ▪ 5. VF直通 ▪ ...

  8. Poco XMLconfiguration 解析xml配置文件

    环境: Centos7 GCC: 7.3.0 准备需要读取的xml文件: <config> <prop1>1.23</prop1> <prop2>2.3 ...

  9. vue-electron 使用sqlite3数据库,执行npm run build 报错 .NET Framework 2.0 SDK,Microsoft Visual Studio 2005[C:\temp\wechat\node_modules\sqlite3\build\binding.sln]

    问题描述 vue-electron 使用sqlite3数据库,执行npm run build 报错如下: .NET Framework 2.0 SDK,Microsoft Visual Studio ...

  10. webpack4.0入门总结

    1. 安装webpack: // 初始化.安装webpack以及webpack-clinpm init npm install --save-dev webpack webpack-cli 2.创建配 ...