设置“solr.allowPaths”时,Apache Solr 云备份出现路径问题

J.A*_*lex 5 solr backups solrcloud docker docker-volume

我正在尝试备份 solr 云集合。Solr 和 Zookeeper 在 Docker 容器中运行。有3个solr(使用端口:8981,8982,8983)和3个ZKs容器正在运行。我将 docker 卷传递给 solr 容器

volumes:
    - solr_backups:/solr-backups/storage
Run Code Online (Sandbox Code Playgroud)

在 Dockerfile 中,构建并给出了文件夹chmod 777。因此,所有 solr 容器都会将该文件夹视为网络共享(我假设)。

执行中

$ curl "localhost:8981/solr/admin/collections?action=BACKUP&name=test1&collection=myColl&location=/solr-backups/storage"
Run Code Online (Sandbox Code Playgroud)

返回以下内容

...
 "failure":{
    "172.19.0.22:8983_solr":"org.apache.solr.client.solrj.impl.HttpSolrClient$RemoteSolrException:
Error from server at http://172.19.0.22:8983/solr: 
Failed to backup core=myColl_shard1_replica_n1 because org.apache.solr.common.SolrException: 
Path /solr-backups/storage/test1 must be relative to SOLR_HOME, SOLR_DATA_HOME coreRootDirectory. 
Set system property 'solr.allowPaths' to add other allowed paths."},
  "Operation backup caused exception:":"org.apache.solr.common.SolrException:org.apache.solr.common.SolrException: 
Could not backup all shards",
  "exception":{
    "msg":"Could not backup all shards",
    "rspCode":500},
  "error":{
    "metadata":[
      "error-class","org.apache.solr.common.SolrException",
      "root-error-class","org.apache.solr.common.SolrException"],
    "msg":"Could not backup all shards",
...
Run Code Online (Sandbox Code Playgroud)

卷曲发送到8981(可以发送到3个中的任何一个)。从 8983 报告错误。8981myColl上没有分片。test1正在创建备份文件夹,所有 3 个正在运行的 solr 容器都可以访问该备份文件夹。

在其中一个容器中执行 shell。

$ ls -al /solr-backups/storage/
total 16
drwxrwxrwx 4 root root 4096 Nov 30 16:49 .
drwxr-xr-x 3 root root 4096 Nov 30 16:22 ..
drwxr-xr-x 2 solr root 4096 Nov 30 16:49 test1
drwxr-xr-x 2 solr root 4096 Nov 30 16:25 test3
Run Code Online (Sandbox Code Playgroud)

显示该文件夹在那里并且由 solr 所有。

来自 solr.xml

  <str name="allowPaths">${solr.allowPaths:*,_ALL_,/solr-backups/storage/}</str>
Run Code Online (Sandbox Code Playgroud)

我已经尝试了上面的方法,仅使用 * 和路径。此外,所有特价商品和路径。

我还在执行 docker-compose up 时设置了集群属性

curl \"http://solr1:8983/solr/admin/collections?action=CLUSTERPROP&name=location&val=/solr-backups/storage\";
Run Code Online (Sandbox Code Playgroud)

任何帮助将不胜感激。

小智 0

错误消息显示:

/solr-backups/storage/test1 must be relative to SOLR_HOME, SOLR_DATA_HOME coreRootDirectory. 
Run Code Online (Sandbox Code Playgroud)

所以你需要有一个像$SOLR_HOME/solr-backups/storage/$SOLR_DATA_HOME/solr-backups/storage/这样的目录

对于 solr v8.11 $SOLR_HOME 是 /var/solr/data