Hello.  
We're setting up fts solr and want to have the solr server host be set per-user 
via UserDB.

It looks like if a user connects and fts indexes mail, and then another user 
connects and indexes mail, indexer-worker is connecting to the first user's fts 
host:

User1, [email protected] connects, does a SEARCH for the first time, 
indexer-worker gets UserDB settings and correctly indexes mail on ftsvs01:

[...]
auth-worker(2195): Debug: dict([email protected]): lookup 
shared/userdb/[email protected]
auth-worker(2195): Debug: dict([email protected]): result: 
{"uid":"8","fts":"solr","quota_rule4":"Spam:ignore","_session":"talk15_590ec6d100042","quota_rule3":"Trash:ignore","quota_rule2":"*:messages=2684354","quota_rule":"*:storage=5242880k","mail":"maildir:/mail/mailstore01/215/573/[email protected]/:INDEX=/mail/index01/215/573/[email protected]/","fts_solr":"debug
 url=http://ftsvs01:8080/solr/","gid":"8"}
auth: Debug: userdb out: USER   1       [email protected] uid=8   
fts=solr        quota_rule4=Spam:ignore _session=talk15_590ec6d100042   
quota_rule3=Trash:ignore        quota_rule2=*:messages=2684354  
quota_rule=*:storage=5242880k   
mail=maildir:/mail/mailstore01/215/573/[email protected]/:INDEX=/mail/index01/215/573/[email protected]/
    fts_solr=debug url=http://ftsvs01:8080/solr/    gid=8
indexer-worker: Debug: auth input: [email protected] uid=8 fts=solr 
quota_rule4=Spam:ignore _session=talk15_590ec6d100042 quota_rule3=Trash:ignore 
quota_rule2=*:messages=2684354 quota_rule=*:storage=5242880k 
mail=maildir:/mail/mailstore01/215/573/[email protected]/:INDEX=/mail/index01/215/573/[email protected]/
 fts_solr=debug url=http://ftsvs01:8080/solr/ gid=8
indexer-worker: Debug: Added userdb setting: 
plugin/_session=talk15_590ec6d100042
indexer-worker: Debug: Added userdb setting: plugin/fts=solr
indexer-worker: Debug: Added userdb setting: plugin/fts_solr=debug 
url=http://ftsvs01:8080/solr/
indexer-worker: Debug: Added userdb setting: 
mail=maildir:/mail/mailstore01/215/573/[email protected]/:INDEX=/mail/index01/215/573/ha
[email protected]/
indexer-worker: Debug: Added userdb setting: 
plugin/quota_rule=*:storage=5242880k
indexer-worker: Debug: Added userdb setting: 
plugin/quota_rule2=*:messages=2684354
indexer-worker: Debug: Added userdb setting: plugin/quota_rule3=Trash:ignore
indexer-worker: Debug: Added userdb setting: plugin/quota_rule4=Spam:ignore
indexer-worker([email protected]): Debug: Effective uid=8, gid=8, home=
indexer-worker([email protected]): Debug: Namespace inbox: type=private, 
prefix=, sep=, inbox=yes, hidden=no, list=yes, subscriptions
=yes 
location=maildir:/mail/mailstore01/215/573/[email protected]/:INDEX=/mail/index01/215/573/[email protected]/
indexer-worker([email protected]): Debug: maildir++: 
root=/mail/mailstore01/215/573/[email protected], index=/mail/index01/215/
573/[email protected], indexpvt=, control=, 
inbox=/mail/mailstore01/215/573/[email protected], alt=
indexer-worker([email protected]): Debug: Ignoring unknown cache field: 
pop3.order
indexer-worker([email protected]): Debug: Ignoring unknown cache field: 
binary.parts
indexer-worker([email protected]): Warning: Created dotlock file's 
timestamp is different than current time (1380294685 vs 1380294612
): /mail/index01/215/573/[email protected]/.INBOX/dovecot.index.log
indexer-worker([email protected]): Debug: http-client: request [POST 
http://ftsvs01:8080/solr/update]: Submitted
[...]


User1 index finishes and imap searches against ftsvs01
[...]
imap([email protected]): Debug: http-client: request [GET 
http://ftsvs01:8080/solr/select?fl=uid,score&rows=2&sort=uid+asc&q=(hdr:%22moo%22+OR+body:%22moo%22)&fq=%2Bbox:42faee1f735b1e52b3210000386e9ade+%2Buser:%[email protected]%22]:
 Submitted
[...]


User2 [email protected] connects and does a SEARCH, index worker gets gets 
UserDB settings, including fts host ftsvs02, but connects to ftsvs01 (also note 
index-worker initially shows wrong user in loglines)
[...]
auth-worker(2195): Debug: dict([email protected]): lookup 
shared/userdb/[email protected]
auth-worker(2195): Debug: dict([email protected]): result: 
{"uid":"8","fts":"solr","quota_rule4":"Spam:ignore","_session":"cow80_609fed7600001","quota_rule3":"Trash:ignore","quota_rule2":"*:messages=2684354","quota_rule":"*:storage=5242880k","mail":"maildir:/mail/mailstore01/812/023/[email protected]/:INDEX=/mail/index01/812/023/[email protected]/","fts_solr":"debug
 url=http://ftsvs02:8080/solr/","gid":"8"}
auth: Debug: userdb out: USER   2       [email protected]  uid=8   
fts=solr        quota_rule4=Spam:ignore _session=cow80_609fed7600001    
quota_rule3=Trash:ignore        quota_rule2=*:messages=2684354  
quota_rule=*:storage=5242880k   
mail=maildir:/mail/mailstore01/812/023/[email protected]/:INDEX=/mail/index01/812/023/[email protected]/
      fts_solr=debug url=http://ftsvs02:8080/solr/    gid=8
indexer-worker([email protected]): Debug: auth input: 
[email protected] uid=8 fts=solr quota_rule4=Spam:ignore 
_session=cow80_609fed7600001 quota_rule3=Trash:ignore 
quota_rule2=*:messages=2684354 quota_rule=*:storage=5242880k 
mail=maildir:/mail/mailstore01/812/023/[email protected]/:INDEX=/mail/index01/812/023/[email protected]/
 fts_solr=debug url=http://ftsvs02:8080/solr/ gid=8
indexer-worker([email protected]): Debug: Added userdb setting: 
plugin/_session=cow80_609fed7600001
indexer-worker([email protected]): Debug: Added userdb setting: 
plugin/fts=solr
indexer-worker([email protected]): Debug: Added userdb setting: 
plugin/fts_solr=debug url=http://ftsvs02:8080/solr/
indexer-worker([email protected]): Debug: Added userdb setting: 
mail=maildir:/mail/mailstore01/812/023/[email protected]/:INDEX=/mail/index01/812/023/[email protected]/
indexer-worker([email protected]): Debug: Added userdb setting: 
plugin/quota_rule=*:storage=5242880k
indexer-worker([email protected]): Debug: Added userdb setting: 
plugin/quota_rule2=*:messages=2684354
indexer-worker([email protected]): Debug: Added userdb setting: 
plugin/quota_rule3=Trash:ignore
indexer-worker([email protected]): Debug: Added userdb setting: 
plugin/quota_rule4=Spam:ignore
indexer-worker([email protected]): Debug: Effective uid=8, gid=8, home=
indexer-worker([email protected]): Debug: Namespace inbox: type=private, 
prefix=, sep=, inbox=yes, hidden=no, list=yes, subscriptions=yes 
location=maildir:/mail/mailstore01/812/023/[email protected]/:INDEX=/mail/index01/812/023/[email protected]/
indexer-worker([email protected]): Debug: maildir++: 
root=/mail/mailstore01/812/023/[email protected], 
index=/mail/index01/812/023/[email protected], indexpvt=, control=, 
inbox=/mail/mailstore01/812/023/[email protected], alt=
indexer-worker([email protected]): Debug: Ignoring unknown cache field: 
pop3.order
indexer-worker([email protected]): Debug: Ignoring unknown cache field: 
binary.parts
indexer-worker([email protected]): Warning: Created dotlock file's 
timestamp is different than current time (1380294736 vs 1380294664): 
/mail/index01/812/023/[email protected]/.INBOX/dovecot.index.cache
indexer-worker([email protected]): Warning: Created dotlock file's 
timestamp is different than current time (1380294736 vs 1380294664): 
/mail/index01/812/023/[email protected]/.INBOX/dovecot.index.log
indexer-worker([email protected]): Warning: Created dotlock file's 
timestamp is different than current time (1380294736 vs 1380294664): 
/mail/index01/812/023/[email protected]/.INBOX/dovecot.index.cache
indexer-worker([email protected]): Debug: http-client: request [POST 
http://ftsvs01:8080/solr/update]: Submitted
[...]

indexer-worker indexes User2's mail on wrong fts host:
[...]
indexer-worker([email protected]): Debug: http-client: request [POST 
http://ftsvs01:8080/solr/update]: Sent header
indexer-worker([email protected]): Debug: http-client: request [POST 
http://ftsvs01:8080/solr/update]: Partially sent payload
indexer-worker([email protected]): Debug: http-client: request [POST 
http://ftsvs01:8080/solr/update]: Partially sent payload
indexer-worker([email protected]): Debug: http-client: request [POST 
http://ftsvs01:8080/solr/update]: Partially sent payload
indexer-worker([email protected]): Debug: http-client: request [POST 
http://ftsvs01:8080/solr/update]: Partially sent payload
indexer-worker([email protected]): Debug: http-client: request [POST 
http://ftsvs01:8080/solr/update]: Partially sent payload
indexer-worker([email protected]): Debug: http-client: request [POST 
http://ftsvs01:8080/solr/update]: Partially sent payload
[...]

indexer-worker finishes and imap searches against correct fts host ftsvs02
[...]
imap([email protected]): Debug: http-client: request [GET 
http://ftsvs02:8080/solr/select?fl=uid,score&rows=194&sort=uid+asc&q=(hdr:%22Fasdf%22+OR+body:%22Fasdf%22)&fq=%2Bbox:62d61f003b5a1e52af130000386e9ade+%2Buser:%[email protected]%22]:
 Submitted
[...]




Reply via email to