
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
运行在生物样本库站点的目录同步服务,用于保持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
http://www.apache.org/licenses/LICENSE-2.0
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.
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务