1. docker 部署kong-database(postgres)
- 详细参考 docker 部署数据库 (kong不支持postgres12及以上版本,latest版本已经13+了)
- 启动数据库服务:
/usr/bin/docker run --net host --restart=always -d --name kong-database \
-e POSTGRES_DB=kong -e POSTGRES_USER=kong -e POSTGRES_PASSWORD=kong postgres:11.10
2. docker 部署kong
- 查找镜像: docker search kong
- 下载镜像: docker pull kong
- 初始化数据库: KONG_CASSANDRA_CONTACT_POINTS 是cassandra的配置,可以忽略。
/usr/bin/docker run --rm --net host \ -e "KONG_DATABASE=postgres" \ -e "KONG_PG_HOST=172.17.0.8" \ -e "KONG_PG_PORT=5432" \ -e "KONG_PG_USER=kong" \ -e "KONG_PG_PASSWORD=kong" \ -e "KONG_CASSANDRA_CONTACT_POINTS=kong-database" \ kong:latest kong migrations bootstrap
- 拷贝配置文件:
docker cp kong:/etc/kong/kong.conf.default ./conf/kong.conf
配置内容如下:
pg_host = 172.17.0.8
pg_port = 5432
pg_user = kong
pg_password = kong
pg_database = kong - 启动kong服务:
使用host网络(--net host),端口映射(-p) 可以去掉。我这里一开始是通过自定义网络装的,然后改的脚本就没去掉。数据库配置也可以像初始化脚本那样通过-e选项指定。/usr/bin/docker run -d --name kong --net host \ -v $PWD/conf/kong.conf:/etc/kong/kong.conf \ -e "KONG_DATABASE=postgres" \ -e "KONG_PROXY_ACCESS_LOG=/dev/stdout" \ -e "KONG_ADMIN_ACCESS_LOG=/dev/stdout" \ -e "KONG_PROXY_ERROR_LOG=/dev/stderr" \ -e "KONG_ADMIN_ERROR_LOG=/dev/stderr" \ -e "KONG_ADMIN_LISTEN=0.0.0.0:8001, 0.0.0.0:8444 ssl" \ -p 8000:8000 \ -p 8443:8443 \ -p 8001:8001 \ -p 8444:8444 \ kong
3. docker 部署konga
- 查找镜像: docker search konga
- 下载镜像: docker pull pantsel/konga
- 初始化数据库:
/usr/bin/docker run --rm --net host pantsel/konga:latest -c prepare -a \ postgres -u postgresql://kong:kong@172.17.0.8:5432/konga_db
-
启动konga服务
/usr/bin/docker run -d --net host \ -e "NODE_ENV=production" \ -e "TOKEN_SECRET=john1234567890" \ -e "DB_ADAPTER=postgres" \ -e "DB_URI=postgresql://kong:kong@172.17.0.8:5432/konga_db" \ --name konga \ pantsel/konga
4. 查看安装结果
-
查看容器:
-
数据库:
-
界面: