Мне не удалось найти решение именно этой проблемы:
Первое приложение должно ссылаться на некоторые файлы localhost: 3333 css и js:
<link rel="stylesheet" href="/css/my-css.css"/>
<script src="/js/my-js.js" defer></script>
Я пробовал этот конф (и варианты):
<VirtualHost *:443>
ServerName qa.mysite.com
SSLEngine on
SSLProxyEngine on
SSLProxyVerify none
SSLProxyCheckPeerCN off
SSLProxyCheckPeerName off
SSLProxyCheckPeerExpire off
SSLCertificateFile "/etc/apache2/server.crt"
SSLCertificateKeyFile "/etc/apache2/server.key"
ProxyVia Full
ProxyPreserveHost On
ProxyPass "/" "http://localhost:3000/"
ProxyPassReverse "/" "http://localhost:3000/"
ProxyPass "/css/my-css.css" "http://localhost:3333/css/my-css.css"
ProxyPassReverse "/css/my-css.css" "http://localhost:3333/css/my-css.css"
ProxyPass "/js/my-js.js" "http://localhost:3333/js/my-js.js"
ProxyPassReverse "/js/my-js.js" "http://localhost:3333/js/my-js.js"
</VirtualHost>
Есть идеи, что я делаю не так? :)
Сначала вам нужно указать более конкретные правила ProxyPass. "/css/my-css.css" сначала оценит "/". Поскольку это верно, вы получите порт 3000.
Поместите ProxyPass в "/" последним, поскольку это всеобъемлющий запасной вариант.
<VirtualHost *:443>
ServerName qa.mysite.com
SSLEngine on
SSLProxyEngine on
SSLProxyVerify none
SSLProxyCheckPeerCN off
SSLProxyCheckPeerName off
SSLProxyCheckPeerExpire off
SSLCertificateFile "/etc/apache2/server.crt"
SSLCertificateKeyFile "/etc/apache2/server.key"
ProxyVia Full
ProxyPreserveHost On
#Specific /css
ProxyPass "/css/my-css.css" "http://localhost:3333/css/my-css.css"
ProxyPassReverse "/css/my-css.css" "http://localhost:3333/css/my-css.css"
#Specific /js
ProxyPass "/js/my-js.js" "http://localhost:3333/js/my-js.js"
ProxyPassReverse "/js/my-js.js" "http://localhost:3333/js/my-js.js"
#Catch ALL for servername
ProxyPass "/" "http://localhost:3000/"
ProxyPassReverse "/" "http://localhost:3000/"
</VirtualHost>