Docker 部署 Kong云原生API網關

Docker 部署 Kong云原生API網關

本指南提供了在 Docker Compose 上配置 Kong Gateway 的步驟,基于有數據庫模式的配置。本指南中使用的數據庫是 PostgreSQL。
在這里插入圖片描述

前置條件

準備一臺Ubuntu服務器:

  • 節點IP: 192.168.73.11
  • 操作系統: Ubuntu 24.04
  • 已安裝docker及docker-compose

部署kong網關

創建docker-compose文件

root@user-service:/data/apps/kong# cat docker-compose.yaml
name: 'kong-gateway'services:kong-db:image: postgres:17.5container_name: kong-dbrestart: alwaysenvironment:POSTGRES_DB: kongPOSTGRES_USER: kongPOSTGRES_PASSWORD: kongpassvolumes:- kong_db_data:/var/lib/postgresql/datanetworks:- kong-nethealthcheck:test: ["CMD-SHELL", "pg_isready -U kong -d kong"]interval: 10stimeout: 5sretries: 5kong-migrations:image: kong:3.9.1container_name: kong-migrationsdepends_on:kong-db:condition: service_healthyenvironment:KONG_DATABASE: postgresKONG_PG_HOST: kong-dbKONG_PG_USER: kongKONG_PG_PASSWORD: kongpasscommand: "kong migrations bootstrap"networks:- kong-netrestart: on-failurekong:image: kong:3.9.1container_name: kong-gatewayrestart: alwaysdepends_on:kong-migrations:condition: service_completed_successfullyenvironment:# kong databaseKONG_DATABASE: postgresKONG_PG_HOST: kong-dbKONG_PG_DATABASE: kongKONG_PG_USER: kongKONG_PG_PASSWORD: kongpass# kong proxyKONG_PROXY_LISTEN: 0.0.0.0:8000KONG_PROXY_LISTEN_SSL: 0.0.0.0:8443# kong adminKONG_ADMIN_LISTEN: 0.0.0.0:8001, 0.0.0.0:8444 ssl# kong managerKONG_ADMIN_GUI_LISTEN: 0.0.0.0:8002, 0.0.0.0:8445 ssl# kong logsKONG_PROXY_ACCESS_LOG: /dev/stdoutKONG_PROXY_ERROR_LOG: /dev/stderrKONG_ADMIN_ACCESS_LOG: /dev/stdoutKONG_ADMIN_ERROR_LOG: /dev/stderrports:- "8000:8000" # Proxy- "8443:8443" # Proxy SSL- "8001:8001" # Admin API- "8444:8444" # Admin API SSL- "8002:8002" # Kong Manager- "8445:8445" # Kong Manager SSLnetworks:- kong-nethealthcheck:test: ["CMD-SHELL", "kong health"]interval: 15stimeout: 10sretries: 3networks:kong-net:driver: bridgevolumes:kong_db_data:driver: local

啟動服務

docker compose up -d

確認容器啟動狀態

root@user-service:/data/apps/kong# docker compose ps -a
NAME              IMAGE           COMMAND                  SERVICE           CREATED          STATUS                      PORTS
kong-db           postgres:17.5   "docker-entrypoint.s…"   kong-db           3 days ago       Up 3 days (healthy)         5432/tcp
kong-gateway      kong:3.9.1      "/docker-entrypoint.…"   kong              24 minutes ago   Up 24 minutes (healthy)     0.0.0.0:8000-8002->8000-8002/tcp, [::]:8000-8002->8000-8002/tcp, 0.0.0.0:8443-8445->8443-8445/tcp, [::]:8443-8445->8443-8445/tcp
kong-migrations   kong:3.9.1      "/docker-entrypoint.…"   kong-migrations   3 days ago       Exited (0) 24 minutes ago   
root@user-service:/data/apps/kong# 

瀏覽器訪問kong manager GUI
在這里插入圖片描述

部署示例應用

下面是一個簡單且貼近實際業務場景的系統,模擬一個訂單系統的調用流程,基于docker構建:

  • A 是前端頁面,用戶點擊“創建訂單”按鈕;
  • A 通過 Kong 網關調用后端 B(訂單服務);
  • B 接收到請求后,再通過 Kong 網關調用后端 C(庫存服務)進行扣減庫存;
  • 最后返回響應到前端。

Kong 網關地址為:http://192.168.73.11:8000

在這里插入圖片描述
創建相關目錄

mkdir -p /data/app/order-app{order-ui,order-servcie,inventory-service}
cd /data/app/order-app

1. 后端 C:庫存服務(inventory-service)

inventory-service/app.py

root@ubuntu:~# cat /data/app/order-app/inventory-service/app.py
from flask import Flask, jsonifyapp = Flask(__name__)@app.route("/inventory/decrease", methods=["POST"])
def decrease_inventory():print("庫存扣減成功")return jsonify({"msg": "庫存扣減成功"}), 200if __name__ == "__main__":app.run(host="0.0.0.0", port=5002)

inventory-service/Dockerfile

root@ubuntu:~# cat /data/app/order-app/inventory-service/Dockerfile
FROM python:3.9-slim
WORKDIR /app
COPY app.py .
RUN pip install flask
EXPOSE 5002
CMD ["python", "app.py"]

2. 后端 B:訂單服務(order-service)

order-service/app.py

root@ubuntu:~# cat /data/app/order-app/order-service/app.py
from flask import Flask, jsonify
import requestsapp = Flask(__name__)@app.route("/order/create", methods=["POST"])
def create_order():print("收到創建訂單請求,調用庫存服務扣減庫存")try:# 通過Kong調用庫存服務resp = requests.post("http://192.168.73.11:8000/inventory/decrease")return jsonify({"msg": "訂單創建成功", "inventory_response": resp.json()})except Exception as e:return jsonify({"msg": "訂單創建失敗", "error": str(e)}), 500if __name__ == "__main__":app.run(host="0.0.0.0", port=5001)

order-service/Dockerfile

root@ubuntu:~# cat /data/app/order-app/order-service/Dockerfile
FROM python:3.9-slim
WORKDIR /app
COPY app.py .
RUN pip install flask requests
EXPOSE 5001
CMD ["python", "app.py"]

3. 前端 A:訂單創建頁面

order-ui/index.html

root@ubuntu:~# cat /data/app/order-app/order-ui/index.html
<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><title>訂單系統</title>
</head>
<body><h1>訂單系統</h1><button onclick="createOrder()">創建訂單</button><pre id="result"></pre><script>function createOrder() {fetch('http://192.168.73.11:8000/order/create', { method: 'POST' }).then(async res => {const text = await res.text();try {const json = JSON.parse(text);document.getElementById("result").innerText = JSON.stringify(json, null, 2);} catch (err) {console.error("非 JSON 響應內容:", text); // 只打印在控制臺document.getElementById("result").innerText = "請求失敗:服務暫時不可用,請稍后再試。";}}).catch(err => {console.error("請求錯誤:", err);document.getElementById("result").innerText = "網絡異常或服務器未響應,請檢查后端服務狀態。";});}</script></body>
</html>

order-ui/Dockerfile

root@ubuntu:~# cat /data/app/order-app/order-ui/Dockerfile
FROM nginx:alpine
COPY index.html /usr/share/nginx/html/index.html
EXPOSE 80

4. Docker Compose

構建docker鏡像

root@ubuntu:~# cd /data/app/order-app/order-ui
docker build -t registry.cn-shenzhen.aliyuncs.com/cnmirror/order-ui:v1.0 .
root@ubuntu:~# cd /data/app/order-app/order-service  
docker build -t registry.cn-shenzhen.aliyuncs.com/cnmirror/order-service:v1.0 .
root@ubuntu:~# cd /data/app/order-app/order-service  
docker build -t registry.cn-shenzhen.aliyuncs.com/cnmirror/inventory-service:v1.0 .

創建docker-compose

root@ubuntu:~# cat /data/app/order-app/docker-compose.yaml
name: "order-app"
services:ui:image: registry.cn-shenzhen.aliyuncs.com/cnmirror/order-ui:v1.0container_name: order-uiports:- "8080:80"networks:- order-netorder-service:image: registry.cn-shenzhen.aliyuncs.com/cnmirror/order-service:v1.0container_name: order-serviceports:- "5001:5001"networks:- order-netinventory-service:image: registry.cn-shenzhen.aliyuncs.com/cnmirror/inventory-service:v1.0container_name: inventory-serviceports:- "5002:5002"networks:- order-netnetworks:order-net:driver: bridge

啟動服務

docker compose up -d

確認容器啟動狀態

root@ubuntu:~# cd /data/app/order-app/
root@ubuntu:/data/app/order-app# docker compose ps
NAME                IMAGE                                                               COMMAND                  SERVICE             CREATED          STATUS          PORTS
inventory-service   registry.cn-shenzhen.aliyuncs.com/cnmirror/inventory-service:v1.0   "python app.py"          inventory-service   19 seconds ago   Up 18 seconds   0.0.0.0:5002->5002/tcp, [::]:5002->5002/tcp
order-service       registry.cn-shenzhen.aliyuncs.com/cnmirror/order-service:v1.0       "python app.py"          order-service       19 seconds ago   Up 18 seconds   0.0.0.0:5001->5001/tcp, [::]:5001->5001/tcp
order-ui            registry.cn-shenzhen.aliyuncs.com/cnmirror/order-ui:v1.0            "/docker-entrypoint.…"   order-ui            19 seconds ago   Up 3 seconds    0.0.0.0:8080->80/tcp, [::]:8080->80/tcp

Kong配置建議(注冊B和C)

創建 Service(服務)

服務代表你后端的 API 服務,告訴 Kong 請求最終要發到哪里。

# 注冊服務B(訂單)
curl -i -X POST http://192.168.73.11:8001/services \--data name=order-service \--data url=http://192.168.73.11:5001# 注冊服務C(庫存)
curl -i -X POST http://192.168.73.11:8001/services \--data name=inventory-service \--data url=http://192.168.73.11:5002

查看注冊的服務
在這里插入圖片描述

創建 Route(路由)

路由是入口規則,告訴 Kong 哪些路徑/域名/方法應該映射到哪個 Service。

# order-service 的路由(例如 /order)
curl -i -X POST http://192.168.73.11:8001/services/order-service/routes \--data name=order-route \--data paths[]=/order \--data 'strip_path=false'# inventory-service 的路由(例如 /inventory)
curl -i -X POST http://192.168.73.11:8001/services/inventory-service/routes \--data name=inventory-route \--data paths[]=/inventory \--data 'strip_path=false'

查看注冊的路由
在這里插入圖片描述

全局啟用cores插件,解決跨域問題

curl -i -X POST http://192.168.73.11:8001/plugins \--data "name=cors" \--data "config.origins=*" \--data "config.methods[]=GET" \--data "config.methods[]=POST" \--data "config.methods[]=PUT" \--data "config.methods[]=DELETE" \--data "config.methods[]=OPTIONS" \--data "config.headers[]=Accept" \--data "config.headers[]=Authorization" \--data "config.headers[]=Content-Type" \--data "config.exposed_headers[]=X-Custom-Header" \--data "config.credentials=true" \--data "config.max_age=3600"

演示應用請求調用

演示流程:

  1. 啟動服務和Kong;
  2. 注冊 B 和 C 到 Kong;
  3. 瀏覽器訪問 http://192.168.73.11:8080
  4. 點擊“創建訂單”;
  5. 查看鏈路:A → B → C。

驗證inventory-service接口

root@user-service:~# curl -s -X POST http://192.168.73.11:5002/inventory/decrease | jq
{"msg": "庫存扣減成功"
}

驗證order-service接口

root@user-service:~# curl -s -X POST http://192.168.73.11:5001/order/create | jq
{"inventory_response": {"msg": "庫存扣減成功"},"msg": "訂單創建成功"
}

驗證通過kong網關請求inventory-service接口

root@user-service:~# curl -s -X POST http://192.168.73.11:8000/inventory/decrease | jq
{"msg": "庫存扣減成功"
}

驗證通過kong網關請求order-service接口

root@user-service:~# curl -s -X POST http://192.168.73.11:8000/order/create | jq
{"inventory_response": {"msg": "庫存扣減成功"},"msg": "訂單創建成功"
}

瀏覽器輸出
在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/86785.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/86785.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/86785.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

深度剖析 Apache Pulsar:架構、優勢與選型指南

Apache Pulsar 是一款云原生分布式消息流平臺&#xff0c;融合了消息隊列、流處理和存儲能力&#xff0c;采用獨特的“存儲計算分離”架構&#xff08;Broker 無狀態 BookKeeper 持久化存儲&#xff09;。以下從核心特性、對比優勢及適用場景展開分析&#xff1a; 一、Pulsar…

java 導出word 實現循環表格

如果是固定的值 用 {{}} 即可 但是如果是循環表格&#xff0c;那么就需要制定模板為如圖 然后在處理表格數據時候&#xff1a; /*** 傳入 節點對象 返回生成的word文檔* param flangeJoint* return* throws IOException*/private XWPFTemplate getXwpfTemplate(CmComplaintEn…

XIP (eXecute In Place)

NOR Flash 能直接執行代碼(XIP)而 NAND Flash 不能,根本原因在于它們的物理結構和訪問接口存在本質區別。下面用技術原理 + 現實比喻幫你徹底理解: 1. XIP 是什么? XIP (eXecute In Place) 指代碼不需要從存儲介質復制到 RAM,而是 CPU 直接從存儲介質(如 Flash)中讀取…

【android bluetooth 協議分析 10】【AVRCP詳解1】【PlaybackStateCompat類如何查看】

1. 問題 android/app/src/com/android/bluetooth/avrcpcontroller/AvrcpControllerService.java import android.support.v4.media.MediaBrowserCompat.MediaItem; import android.support.v4.media.session.PlaybackStateCompat;private int toPlaybackStateFromJni(int fro…

【AI學習從零至壹】LLM模型prompt開發及?模型應?

LLM模型prompt開發及?模型應? ?語?模型 LLM如何構建?個AI對話系統關于模型的訓練 ollama調?LLM模型設置API KEY測試一個對話 prompt提示詞提示詞結構特征提示詞的五大核心價值1. 信息傳遞的精準性2. 輸出質量的可控性3. 用戶意圖的對?性4. 復雜任務的拆解性5. 倫理?險的…

ubuntu20.04如何給appImage創建快捷方式

ubuntu20.04如何給appImage創建快捷方式 1. 確保AppImage是可執行的 chmod x /path/to/your/appimage2. 創建.desktop文件 在~/.local/share/applications/目錄下創建一個新的 .desktop 文件&#xff1a; vi ~/.local/share/applications/your-appname.desktop添加以下內容…

RT-Thread 詳解:國產開源實時操作系統

一、RT-Thread 概述 定義&#xff1a;RT-Thread 是中國自主研發的開源實時操作系統&#xff08;RTOS&#xff09;&#xff0c;兼具實時性與物聯網&#xff08;IoT&#xff09;特性&#xff0c;支持從資源受限的 MCU&#xff08;如 STM32、ESP32&#xff09;到高性能處理器&…

Wan2 1-VACE

簡介 VACE是阿里新開源的視頻編輯/生成框架&#xff0c;號稱能夠執行任意的視頻編輯/生成。總體而言&#xff0c;該模型在整體結構上并沒有太大改變&#xff0c;僅僅是在原Wan2.1模型的基礎上&#xff0c;加了一個接受mask和視頻輸入的controlnet而已。但是這篇文章認為&#…

基于 opencv+yolov8+easyocr的車牌追蹤識別

&#xff08;本項目所有代碼打包至我的資源中&#xff0c;大家可在我的文章底部選擇下載&#xff09; 目錄 需求 實現效果 學習視頻 大致思路 代碼實現 資源下載 需求 通過車輛識別技術&#xff0c;識別視頻中每個車輛及其車牌號&#xff0c;車輛應進行追蹤&#xff0c;避免重復…

sqlserver函數與過程(二)

過程 SQLserver 過程是具有特定功能&#xff0c;可多次對數據表操作的獨立模塊。返回值通常用return 返回整數 0&#xff0c;1…。(可選&#xff09;也可通過output 參數或select 語句返回結果集。 1.過程的定義 本過程定義了一個過程&#xff0c;輸入一個動態SQL語句&#…

OpenCV學習3

1、創建圖像窗口滑動條 OpenCV 4中通過createTrackbar()函數在顯示圖像的窗口上創建滑動條。 int cv::createTrackbar(const String &trackbarname,const String &winname, int *value, int count, TrackbarCallback onChange 0, void *us…

SRS流媒體服務器之本地測試rtc推流bug

SRS環境版本 commit 44f0c36b61bc7c3a1d51cb60be0ec184c840f09d Author: winlin <winlinvip.126.com> Date: Wed Aug 2 10:34:41 2023 0800 Release v4.0-r5, 4.0 release5, v4.0.271, 145574 lines. bug1: 無法推流 WebRTC推流必須是HTTPS或者localhost&#xff1a;Ht…

物理服務器是指的什么?作用有哪些?-哈爾濱云前沿

物理服務器是一種基于傳統硬件架構構建的服務器&#xff0c;物理服務器是具有處理器、硬盤和網絡接口等硬件組件的獨立服務器&#xff0c;可以用于托管和存儲數據服務&#xff0c;&#xff0c;是計算機網絡的核心組件之一&#xff0c;本文就來詳細了解一下物理服務器。 物理服務…

Lua現學現賣

一、Lua的變量類型 全局變量&#xff1a;MyVar 局部變量&#xff1a;local MyVar 二、Lua的數據類型 1.nil&#xff1a;一個空值 類似C的nullptr 2.Boolean&#xff1a;true/false 類似C的bool 3.string&#xff1a;字符串 類似C的std::string 4.Number&#xff1a;數字 類似C…

(24)如何在 Qt 里創建 c++ 類,以前已經學習過如何在 Qt 里引入資源圖片文件。以及如何為繼承于 Qt已有類的自定義類重新實現虛函數

&#xff08;1&#xff09; 如何在Qt里創建 c 類 &#xff1a; 效果圖如下 &#xff1a; &#xff08;2&#xff09;開始完善自定義類里面的成員函數 &#xff1a; 接著 &#xff1a; 以及 &#xff1a; 接著重新實現這些繼承來的虛函數就可以了。 &#xff08;3&#xff09…

怎樣優化HDFS的網絡傳輸

優化HDFS&#xff08;Hadoop Distributed File System&#xff09;的網絡傳輸可以從多個方面入手&#xff0c;以下是一些常見的優化策略&#xff1a; 1. 網絡硬件升級 增加帶寬&#xff1a;使用更高帶寬的網絡設備&#xff0c;如10Gbps或更高速度的交換機和網卡。減少延遲&am…

深入探索 Pdfium.Net:在 .NET 中處理和渲染 PDF 文件

在現代軟件開發中&#xff0c;PDF 文件的處理變得愈加重要&#xff0c;尤其是在文檔管理、報表生成和在線內容展示等領域。為了高效地處理和渲染 PDF 文件&#xff0c;開發者通常會選擇一些強大的 PDF 處理庫。而 Pdfium.Net&#xff0c;作為 PDFium 庫的 .NET 封裝&#xff0c…

當無人機遇到AI智能體:多領域自主空中智能和無人機智能體綜述

作者&#xff1a;Ranjan Sapkota, Konstantinos I. Roumeliotis, Manoj Karkee 單位&#xff1a;康奈爾大學生物與環境工程系&#xff0c;希臘伯羅奔尼撒大學信息與電信系 論文標題&#xff1a;UAVs Meet Agentic AI: A Multidomain Survey of Autonomous Aerial Intelligenc…

從 0 到 1 玩轉 React:打造你的趣味美食相冊

想象一下&#xff0c;你想制作一個超酷的 “美食相冊” 網頁&#xff0c;能展示各種美食圖片&#xff0c;還能隨時切換查看不同美食。這聽起來是不是很有趣&#xff1f;別擔心&#xff0c;React 能幫你輕松實現&#xff01;作為前端開發領域最受歡迎的庫之一&#xff0c;React …

深入淺出:RocketMQ與Kafka的雙劍合璧,實現高可用與高吞吐

本文在創作過程中借助 AI 工具輔助資料整理與內容優化。圖片來源網絡。 文章目錄 引言一、RocketMQ與Kafka的江湖地位1.1 RocketMQ的獨門絕技1.2 Kafka的凌厲攻勢 二、雙劍合璧的策略&#xff1a;雙寫隊列2.1 策略概述2.2 代碼實現 三、雙劍合璧的實戰應用3.1 電商訂單處理3.2 …