
folioci/mod-searchmod-search是FOLIO图书馆服务平台的核心搜索模块,提供数据索引和搜索查询功能。该模块通过Kafka消费inventory(实例、holdings记录、项目等)和authorities数据事件,将数据索引至Elasticsearch,并响应搜索查询请求。代码仓库:[***]
适用于FOLIO图书馆服务平台中各类资源的搜索场景,包括:
| 参数 | 描述 | 值 |
|---|---|---|
| MODULE_PORT | 服务端口 | 8081 |
| Container memory | 容器内存限制 | ***字节(1GB) |
| Database connection | 是否需要数据库连接 | true |
| JAVA_OPTIONS | Java运行参数 | -XX:MaxRAMPercentage=85.0 |
| ENV | 环境标识 | folio |
| 参数 | 描述 | 默认值 |
|---|---|---|
| KAFKA_HOST | Kafka服务地址 | kafka |
| KAFKA_PORT | Kafka服务端口 | 9092 |
| KAFKA_SECURITY_PROTOCOL | 安全协议 | PLAINTEXT |
| KAFKA_SSL_KEYSTORE_LOCATION | SSL密钥库路径 | (空) |
| KAFKA_SSL_TRUSTSTORE_LOCATION | SSL信任库路径 | (空) |
| 参数 | 描述 | 默认值 |
|---|---|---|
| KAFKA_EVENTS_CONSUMER_PATTERN | inventory事件主题匹配模式 | (folio.)(.*.)inventory.(instance|holdings-record|item|bound-with) |
| KAFKA_EVENTS_CONCURRENCY | inventory事件消费并发数 | 2 |
| KAFKA_AUTHORITIES_CONSUMER_PATTERN | authorities事件主题匹配模式 | (folio.)(.*.)authorities.authority |
| KAFKA_AUTHORITIES_CONCURRENCY | authorities事件消费并发数 | 1 |
| 参数 | 描述 | 默认值 |
|---|---|---|
| KAFKA_CONSUMER_EVENTS_MAX_POLL_RECORDS | 事件消费者单次拉取最大记录数 | 200 |
| KAFKA_CONSUMER_EVENTS_MAX_POLL_INTERVAL_MS | 事件消费者最大拉取间隔(毫秒) | 600000 |
| KAFKA_RETRY_INTERVAL_MS | 重试间隔(毫秒) | 2000 |
| KAFKA_RETRY_DELIVERY_ATTEMPTS | 重试次数 | 6 |
| 参数 | 描述 | 默认值 |
|---|---|---|
| ELASTICSEARCH_URL | 服务地址 | [***] |
| ELASTICSEARCH_USERNAME | 访问用户名 | elastic |
| ELASTICSEARCH_PASSWORD | 访问密码 | s3cret |
| ELASTICSEARCH_COMPRESSION_ENABLED | 是否启用压缩 | true |
| INDEXING_DATA_FORMAT | 索引数据格式 | smile |
| 参数 | 描述 | 默认值 |
|---|---|---|
| INSTANCE_CHILDREN_INDEX_ENABLED | 是否启用实例子项索引 | true |
| INSTANCE_CHILDREN_INDEX_DELAY_MS | 实例子项索引延迟(毫秒) | 60000 |
| SEARCH_BY_ALL_FIELDS_ENABLED | 是否启用全字段搜索 | false |
| BROWSE_SUBJECTS_ENABLED | 是否启用主题浏览 | true |
| SEARCH_QUERY_TIMEOUT | 搜索查询超时时间 | 25s |
bashdocker run -d \ --name mod-search \ -p 8081:8081 \ -e MODULE_PORT=8081 \ -e KAFKA_HOST=kafka \ -e KAFKA_PORT=9092 \ -e ELASTICSEARCH_URL=[***] \ -e ELASTICSEARCH_USERNAME=elastic \ -e ELASTICSEARCH_PASSWORD=your_es_password \ -e DB_HOST=postgres \ -e DB_PORT=5432 \ -e DB_NAME=folio \ -e DB_USER=folio_user \ -e DB_PASSWORD=folio_password \ folio/mod-search
yamlversion: '3' services: mod-search: image: folio/mod-search ports: - "8081:8081" environment: - MODULE_PORT=8081 - Container memory=*** - JAVA_OPTIONS=-XX:MaxRAMPercentage=85.0 - ENV=folio - KAFKA_HOST=kafka - KAFKA_PORT=9092 - KAFKA_SECURITY_PROTOCOL=PLAINTEXT - ELASTICSEARCH_URL=[***] - ELASTICSEARCH_USERNAME=elastic - ELASTICSEARCH_PASSWORD=your_es_password - DB_HOST=postgres - DB_PORT=5432 - DB_NAME=folio - DB_USER=folio_user - DB_PASSWORD=folio_password depends_on: - kafka - elasticsearch - postgres
KAFKA_EVENTS_CONSUMER_PATTERN的主题

manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务