
运行在生物样本库站点的目录同步服务,用于保持BBMRI Directory与样本库中的样本数量等信息同步,同时从Directory更新本地FHIR存储中的联系详情等信息。若运行Bridgehead,目录同步已预装,无需单独部署(详见https://github.com/samply/bridgehead?tab=readme-ov-file#directory-sync-tool%EF%BC%89%E3%80%82
该服务需访问包含患者、样本信息及生物样本库详情的FHIR存储,数据需符合GBA profile。若运行https://github.com/samply/bridgehead%EF%BC%8C%E5%88%99%E5%B7%B2%E5%8C%85%E5%90%AB%E5%9F%BA%E4%BA%8Ehttps://github.com/samply/blaze%E7%9A%84%E5%90%88%E9%80%82FHIR%E5%AD%98%E5%82%A8%E3%80%82
服务支持通过Quartz以cron语法定时启动同步,若无cron配置,则仅运行一次。需提供Directory的URL、用户名、密码及本地FHIR存储的URL。
适用于运行生物样本库且需要与BBMRI Directory保持数据同步的站点,特别是未使用Bridgehead(已预装该服务)的场景。需具备符合GBA profile的FHIR存储,用于存储患者、样本及生物样本库信息。
以下环境变量用于配置服务,建议存储在.env文件中:
| 变量 | 用途 | 未指定时默认值 |
|---|---|---|
| DS_DIRECTORY_URL | Directory的基础URL | [***] |
| DS_DIRECTORY_USER_NAME | 登录Directory的用户名 | (必填) |
| DS_DIRECTORY_USER_PASS | 登录Directory的密码 | (必填) |
| DS_DIRECTORY_DEFAULT_COLLECTION_ID | 样本未指定集合时使用的默认集合ID | (可选) |
| DS_DIRECTORY_MIN_DONORS | 星型模型超立方体的最小***者数量 | 10 |
| DS_DIRECTORY_MAX_FACTS | 生成的星型模型超立方体最大数量 | (无) |
| DS_DIRECTORY_ALLOW_STAR_MODEL | 设置为'True'时向Directory发送星型模型信息 | False |
| DS_DIRECTORY_MOCK | 设置为'True'时模拟Directory,不实际连接,返回模拟值 | False |
| DS_DIRECTORY_ONLY_LOGIN | 设置为'True'时仅登录Directory,不执行其他操作 | False |
| DS_FHIR_STORE_URL | FHIR存储的URL | [***] |
| DS_TIMER_CRON | 同步执行间隔(cron格式),若为-或未指定则仅执行一次 | (无) |
| DS_RETRY_MAX | 同步失败时的最大重试次数 | 10 |
| DS_RETRY_INTERVAL | 重试间隔(秒) | 20 seconds |
| DS_IMPORT_BIOBANKS | 设置为'True'时从Directory导入生物样本库元数据 | False |
| DS_IMPORT_COLLECTIONS | 设置为'True'时从Directory导入集合元数据 | False |
注意:
DS_DIRECTORY_USER_NAME和DS_DIRECTORY_USER_PASS为必填项,需联系Directory管理员获取登录凭证DS_DIRECTORY_DEFAULT_COLLECTION_IDDS_DIRECTORY_ALLOW_STAR_MODEL前,建议咨询本地数据保护组DS_TIMER_CRON未指定或为-时,服务执行一次后终止DS_DIRECTORY_MOCK为'True'时仍需提供登录凭证(但会被忽略).env文件示例
envDS_DIRECTORY_URL=https://bbmritestnn.gcc.rug.nl DS_DIRECTORY_USER_NAME=foo@foomail.com DS_DIRECTORY_USER_PASS=qwelmqwldmqwklmdLKJNJKNKJN DS_FHIR_STORE_URL=http://store:8080/fhir
使用docker run运行
bashdocker run --env-file .env samply/directory_sync_service
使用docker-compose运行
仓库中包含示例docker-compose.yml文件,启动命令:
bashdocker-compose up
前提条件
构建
bashmvn clean install
运行
设置环境变量后,执行:
bashjava -jar target/directory_sync_service*.jar
使用JaCoCo工具测量单元测试覆盖率:
bashmvn clean verify
测试结果位于:
target/site/jacoco/index.html
用浏览器打开查看,第5列显示行覆盖率(未覆盖行数/总行数,覆盖率计算公式:(总行数-未覆盖行数)/总行数×100%)。
ci目录包含集成测试所需文件,用于GitHub CI流水线。手动运行步骤:
ci目录ci/data/input)bashcd ci export DATASET=1patient_1collection docker volume rm -f store-db-data # 清空Blaze存储 docker-compose up --abort-on-container-exit docker-compose down bash compare_test_results_with_reference.sh $DATASET
测试将启动Blaze FHIR存储,加载测试数据,运行目录同步,将结果转储到文件并与ci/data/output中的参考数据比较。
Copyright 2024 The Samply Community
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
[***]
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。






探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务