
В основном методом проб и ошибок я создал файл конфигурации Apache, представленный ниже.
Его цель — разрешить серверу на localhost:8002 и серверу Trac через WSGI совместно использовать сервер LDAP и при этом выглядеть так, будто они находятся в одном домене/на одном порту.
Правила работают изолированно, но не параллельно.
В частности, trac WSGI будет работать правильно только если строки ProxyPass
/ ProxyPassReverse
закомментированы. Без этого перенаправления сервер localhost:8002, очевидно, не будет сопоставлен с исходящим портом 8022.
Я предполагаю, что сочетание правил каталога, прокси-сервера и местоположения является причиной моей проблемы, или, может быть, их порядок?
WSGIDaemonProcess trac stack-size=524288 python-path=/usr/lib/python2.5/site-packages
WSGIScriptAlias /trac /home/web/foo/parts/trac/tracwsgi/cgi-bin/trac.wsgi
<VirtualHost foo.bar.com:8022>
ServerName foo.bar.com
ServerAlias foo.bar.com
ProxyRequests Off
<Proxy *>
Order deny,allow
Allow from all
</Proxy>
ProxyPreserveHost On
ProxyPass / http://localhost:8002/VirtualHostBase/http/foo.bar.com:8022/foo/VirtualHostRoot/
ProxyPassReverse / http://localhost:8002/VirtualHostBase/http/foo.bar.com:8022/foo/VirtualHostRoot/
<Directory "/home/web/foo/parts/trac/tracwsgi/cgi-bin">
WSGIApplicationGroup %{GLOBAL}
Options +Indexes FollowSymLinks
AllowOverride None
Allow from all
Order allow,deny
</Directory>
<Location "/trac">
AuthBasicProvider ldap
AuthType Basic
AuthzLDAPAuthoritative off
AuthName "Login"
AuthLDAPURL "ldap://127.0.0.1:389/dc=foo-bar,dc=org?uid"
AuthLDAPBindDN "cn=admin, dc=foo-bar, dc=org"
AuthLDAPBindPassword secret
require valid-user
</Location>
</VirtualHost>
решение1
Добавлять:
ProxyPass /trac !
перед ProxyPass для '/'.
Видеть:
http://httpd.apache.org/docs/2.2/mod/mod_proxy.html#proxypass
У вас также отсутствует директива WSGIProcessGroup. Этот экземпляр Trac не будет запущен в созданном вами процессе режима демона. Смотрите: