专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏
轩辕镜像 官方专业版
轩辕镜像 官方专业版轩辕镜像 官方专业版官方专业版
首页个人中心搜索镜像

交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 1072982923

coco/public-things-api Docker 镜像 - 轩辕镜像

public-things-api
coco/public-things-api
自动构建
coco
提供存储在Neo4j图数据库中的事物的公共读取API,目前正迁移至Public Concepts API,未来将被弃用,2018年7月起请求会重定向至概念API并转换格式返回。
0 次下载
🚀 生产环境还在裸拉官方镜像?一次故障=一次通宵
中文简介版本下载
🚀 生产环境还在裸拉官方镜像?一次故障=一次通宵

Public API for Things (public-things-api)

镜像概述和主要用途

提供存储在Neo4j图数据库中的事物(Things)的公共API。目前事物正迁移至新的Public Concepts API,因此本API最终将被弃用。自2018年7月起,对本服务的请求将通过概念API重定向,然后转换以匹配现有契约并返回。

核心功能和特性

  • 提供事物描述的读取接口,支持通过UUID获取单个事物信息
  • 支持批量获取多个事物描述,自动处理非规范UUID并解析为规范UUID
  • 可通过showRelationship查询参数获取事物间的关系(包括broader、broaderTransitive、narrower、related类型)
  • 提供健康检查端点(/__gtg、/__health、/__build-info、/__ping)
  • 支持缓存控制,可配置GET请求的缓存时长
  • 基于环境变量配置,便于容器化部署

使用场景和适用范围

适用于需要读取Neo4j图数据库中存储的事物信息的应用,可获取事物的基本信息及其与其他概念的关系。注意:本API正处于迁移阶段,未来将被Public Concepts API替代,建议新应用直接使用Public Concepts API。

详细使用方法和配置说明

环境变量配置
参数名描述默认值环境变量对应
--app-system-code应用的系统代码public-things-apiAPP_SYSTEM_CODE
--port监听端口8080APP_PORT
--env应用运行环境(local/生产等)local-
--cache-durationGET请求的缓存时长(例如2h45m表示7440秒)30sCACHE_DURATION
--logLevel日志级别(debug/info/warn/error)infoLOG_LEVEL
--publicConceptsApiURLPublic Concepts API端点URLhttp://localhost:8080CONCEPTS_API
Docker部署示例
基本运行
bash
docker run -d -p 8080:8080 \
  -e APP_SYSTEM_CODE=public-things-api \
  -e APP_PORT=8080 \
  -e CACHE_DURATION=30s \
  -e LOG_LEVEL=info \
  -e CONCEPTS_API=[***] \
  coco/public-things-api
自定义配置
bash
docker run -d -p 8081:8081 \
  -e APP_SYSTEM_CODE=my-things-api \
  -e APP_PORT=8081 \
  -e CACHE_DURATION=5m \
  -e LOG_LEVEL=debug \
  -e CONCEPTS_API=[***] \
  coco/public-things-api --env=production
服务端点
获取单个事物描述

通过UUID获取事物的基本信息:

bash
curl http://localhost:8080/things/{concept-uuid} | jq

响应示例:

json
{
  "id": "[***]",
  "apiUrl": "[***]",
  "prefLabel": "Solar Wars",
  "types": [
    "[***]",
    "[***]",
    "[***]"
  ],
  "directType": "[***]",
  "aliases": [
    "Solar Wars"
  ]
}
获取带关系的事物描述

通过showRelationship参数获取事物与其他概念的关系,支持的值:broader( broader关系)、broaderTransitive(broader传递关系)、narrower(narrower关系)、related(related关系)。

bash
curl "http://localhost:8080/things/{concept-uuid}?showRelationship=broaderTransitive&showRelationship=related&showRelationship=narrower" | jq

响应示例(包含关系):

json
{
  "id": "[***]",
  "apiUrl": "[***]",
  "prefLabel": "Solar Wars",
  "types": [
    "[***]",
    "[***]",
    "[***]"
  ],
  "directType": "[***]",
  "aliases": [
    "Solar Wars"
  ],
  "narrowerConcepts": [
    {
      "id": "[***]",
      "apiUrl": "[***]",
      "prefLabel": "Macroeconomics",
      "types": [
        "[***]",
        "[***]",
        "[***]"
      ],
      "directType": "[***]",
      "predicate": "[***]"
    }
  ],
  "broaderConcepts": [
    {
      "id": "[***]",
      "apiUrl": "[***]",
      "prefLabel": "Trade disputes",
      "types": [
        "[***]",
        "[***]",
        "[***]"
      ],
      "directType": "[***]",
      "predicate": "[***]"
    }
  ],
  "relatedConcepts": [
    {
      "id": "[***]",
      "apiUrl": "[***]",
      "prefLabel": "Renewable Energy",
      "types": [
        "[***]",
        "[***]",
        "[***]"
      ],
      "directType": "[***]",
      "predicate": "[***]"
    }
  ]
}
批量获取多个事物描述

通过多个uuid参数批量获取事物描述,支持自动解析非规范UUID:

bash
curl "http://localhost:8080/things?uuid={canonical-uuid}&uuid={non-canonical-uuid}&uuid={another-uuid}" | jq

响应示例:

json
{
  "things": {
    "a11fa00f-777d-484a-9ebc-fbf81b774fc0": {
      "id": "[***]",
      "apiUrl": "[***]",
      "prefLabel": "Solar Wars",
      "types": [
        "[***]",
        "[***]",
        "[***]"
      ],
      "directType": "[***]",
      "aliases": [
        "Solar Wars"
      ]
    },
    "non-canonical-uuid": {
      "id": "[***]",
      "apiUrl": "[***]",
      "prefLabel": "Resolved Thing",
      "types": [
        "[***]",
        "[***]"
      ],
      "directType": "[***]",
      "aliases": []
    }
  }
}
健康检查端点
  • /__gtg: 健康状态检查(返回200表示正常)
  • /__health: 详细健康信息
  • /__build-info: 应用构建信息
  • /__ping: 心跳检查(返回"pong")
日志
  • 使用logrus记录日志,配置在main.go中初始化
  • 日志输出位置:
    • local环境:日志输出到控制台
    • 其他环境:日志输出到文件
  • /__build-info和/__ping端点的请求不记录日志

安装(源码)

如需从源码构建,执行以下步骤:

  1. 安装依赖管理工具:
bash
curl [***] | sh
  1. 创建目录并克隆代码:
bash
mkdir $GOPATH/src/github.com/Financial-Times/public-things-api
cd $GOPATH/src/github.com/Financial-Times
git clone [***]
cd public-things-api && dep ensure -vendor-only
  1. 构建:
bash
go build .

本地运行

  1. 运行测试并安装二进制:
bash
go test ./...
go install
  1. 启动服务(使用--help查看参数):
bash
$GOPATH/bin/public-things-api --help

参数说明:

Options:
  --app-system-code        应用的系统代码(环境变量 $APP_SYSTEM_CODE)(默认 "public-things-api")
  --port                   监听端口(环境变量 $APP_PORT)(默认 "8080")
  --env                    应用运行环境(默认 "local")
  --cache-duration         GET请求缓存时长(例如2h45m)(环境变量 $CACHE_DURATION)(默认 "30s")
  --logLevel               日志级别(环境变量 $LOG_LEVEL)(默认 "info")
  --publicConceptsApiURL   Public Concepts API端点URL(环境变量 $CONCEPTS_API)(默认 "http://localhost:8080")
查看更多 public-things-api 相关镜像 →
eclipse/ditto-things logo
eclipse/ditto-things
Eclipse Ditto的“things”微服务,负责持久化Things数据。
1100K+ pulls
上次更新:未知
eclipse/ditto-things-search logo
eclipse/ditto-things-search
Eclipse Ditto的“事物搜索”微服务镜像,负责IoT事物搜索索引的实时更新与高效查询,是Ditto数字孪生框架的核心组件。
2100K+ pulls
上次更新:未知
rootpublic/tomcat logo
rootpublic/tomcat
Root Curated tomcat镜像是基于官方tomcat的安全、轻量级容器化应用起点,具有减小镜像大小、最小化攻击面及改善初始安全态势的特点。
50K+ pulls
上次更新:未知
webthingsio/gateway logo
webthingsio/gateway
基于Debian Buster的Docker镜像,用于运行WebThings Gateway。
131M+ pulls
上次更新:未知
airbyte/source-public-apis logo
airbyte/source-public-apis
暂无描述
10K+ pulls
上次更新:未知
rootpublic/eclipse-temurin logo
rootpublic/eclipse-temurin
Root精选eclipse-temurin镜像是基于官方eclipse-temurin的安全、轻量且便捷的容器化应用起点,具有减小镜像大小、最小化攻击面和提升初始安全态势的特点。
10K+ pulls
上次更新:未知

轩辕镜像配置手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

登录仓库拉取

通过 Docker 登录认证访问私有仓库

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

Docker Compose

Docker Compose 项目配置

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

Dev Containers

VS Code Dev Containers 配置

MacOS OrbStack

MacOS OrbStack 容器配置

宝塔面板

在宝塔面板一键配置镜像

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

极空间

极空间 NAS 系统配置服务

爱快路由

爱快 iKuai 路由系统配置

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

专属域名拉取

无需登录使用专属域名

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像支持哪些镜像仓库?

专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
coco/public-things-api
官方博客Docker 镜像使用技巧与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
咨询镜像拉取问题请 提交工单,官方技术交流群:1072982923
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
咨询镜像拉取问题请提交工单,官方技术交流群:
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
官方邮箱:点击复制邮箱
©2024-2026 源码跳动
官方邮箱:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.