Kong Document(0.9.x) Note

1. Installation

略。

每个平台的安装方式不一样,我目前使用的是 Debian 8来安装的。

数据库:Postgres 9.4

参考

2. Quickstart

  1. start kong

    kong start
    # 可以同 -c <path_to_config> 的选项指向配置文件。默认在/etc/kong下边
    
  2. 验证是否启动成功

    1. :8000:API 请求的代理层端口
    2. :8001:RESTful Admin API for configuration
  3. 其他

    kong stop
    kong reload
    

3. 添加 API

  1. 使用 RESTful API 添加你的 API

    curl -i -X POST \
      --url http://localhost:8001/apis/ \
      --data 'name=mockbin' \
      --data 'upstream_url=http://mockbin.com/' \
      --data 'request_host=mockbin.com'
    
  2. 验证你的 API 是否被添加

    出于安全考虑,建议启用 Request Size Limiting 插件,防止 DOS 攻击

    HTTP/1.1 201 Created
    Content-Type: application/json
    Connection: keep-alive
    
    {
      "request_host": "mockbin.com",
      "upstream_url": "http://mockbin.com/",
      "id": "2eec1cb2-7093-411a-c14e-42e67142d2c4",
      "created_at": 1428456369000,
      "name": "mockbin"
    }
    
  3. 通过 Kong 转发你的请求

    以下代码验证 Kong 会正确的转发你的请求到你的 API:

    $ curl -i -X GET \
      --url http://localhost:8000/ \
      --header 'Host: mockbin.com'
    

    成功返回response,意味着 Kong 转发了请求到 我们第一步中设置的upstream_url了,并给我们返回了信息回来。Kong 知道这么做的原因是通过我们上边请求中定义的 --header

启动插件

Kong 的核心部分就是通过插件的高扩展性。通过插件可以容易在 API 上添加新的功能或者让你的 API 易于管理、

给 API 配置插件

$ curl -i -X POST \
  --url http://localhost:8001/apis/mockbin/plugins/ \
  --data 'name=key-auth'
# 给之前创建的mockbin的 API 添加插件
# 这个插件接收一个 config.key_names 的参数,默认值是:apiKey. 它是在headers和 parameters names(两种都支持)

验证这个插件是否正确的配置

$ curl -i -X GET \
  --url http://localhost:8000/ \
  --header 'Host: mockbin.com'
  
# 如果没有在 header 或者 parameters里指定 apiKey, 这个请求返回 403 Forbidden

添加消费者(Consumers)

上一个section说了怎么添加插件到Kong,这个 section 将学会怎么添加消费者到 Kong 的实例中。

消费者是关系到谁访问你的 API的时候,可以用来tracking\access management等等。

通过 API 创建一个消费者

$ curl -i -X POST \
  --url http://localhost:8001/consumers/ \
  --data "username=Jason"
  
# Kong 可以接收一个 custom_id 的参数,用来创建消费者的时候关联已存在的用户数据库

为消费者设定一个 key 凭证

$ curl -i -X POST \
  --url http://localhost:8001/consumers/Jason/key-auth/ \
  --data 'key=ENTER_KEY_HERE'

验证创建的消费者凭证是否有效

$ curl -i -X GET \
  --url http://localhost:8000 \
  --header "Host: mockbin.com" \
  --header "apikey: ENTER_KEY_HERE"
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,230评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,261评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,089评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,542评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,542评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,544评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,922评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,578评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,816评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,576评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,658评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,359评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,937评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,920评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,859评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,381评论 2 342

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,580评论 18 139
  • kong简介 Kong 是在客户端和(微)服务间转发API通信的API网关,通过插件扩展功能。Kong 有两个主要...
    pingforever阅读 11,556评论 0 10
  • (守谦学堂转发) 为什么有些人的思维很敏捷,但是,到了另外一个人面前,他的思维会突然错乱或停顿了呢...
    般若之光阅读 1,266评论 0 0
  • 不要听别人的意见。 听从自己内心的声音。 我自己内心的声音?是什么?来自哪里?他就一定不是别人意见的遗留产品吗?
    大橙大橙阅读 98评论 0 0
  • Complications 是 watchOS 2 新加入的特性,它是表盘上的小界面元素,用于自定义表盘,可以支持...
    RY_zheng阅读 3,739评论 1 5