Deployment Angular: Unterschied zwischen den Versionen
| (19 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) | |||
| Zeile 11: | Zeile 11: | ||
== Als Maven Dependency == | == Als Maven Dependency == | ||
=== Dependency erstellen === | |||
<pre> | |||
cd dist/<projekt folder>/ | |||
ng build --prod | |||
zip -r angular-client.zip * | |||
# Kontrolle der Zip-Datei | |||
unzip -l angular-client.zip | |||
mvn install:install-file \ | |||
-Dfile=angular-client.zip \ | |||
-DgroupId=at.or.kirner \ | |||
-DartifactId=<project name>-client \ | |||
-Dversion=0.1 \ | |||
-Dpackaging=zip \ | |||
-DgeneratePom=true | |||
</pre> | |||
==== Links ==== | |||
[https://stackoverflow.com/questions/4955635/how-to-add-local-jar-files-to-a-maven-project https://stackoverflow.com/questions/4955635/how-to-add-local-jar-files-to-a-maven-project] | |||
=== Dependency in WAR entpacken === | |||
<pre> | <pre> | ||
... | |||
<properties> | |||
... | |||
<client-version>${project.version}</client-version> | |||
... | |||
</properties> | |||
... | |||
<plugin> | <plugin> | ||
<!-- copy the latest | <!-- copy the latest angular client from the repository into the war file --> | ||
<groupId>org.apache.maven.plugins</groupId> | <groupId>org.apache.maven.plugins</groupId> | ||
<artifactId>maven-dependency-plugin</artifactId> | <artifactId>maven-dependency-plugin</artifactId> | ||
<version>${dependency-plugin-version}</version> | |||
<executions> | <executions> | ||
<execution> | <execution> | ||
<id>unpack-web-client</id> | <id>unpack-web-client</id> | ||
<phase> | <phase>prepare-package</phase> | ||
<goals> | <goals> | ||
<goal>unpack</goal> | <goal>unpack</goal> | ||
</goals> | </goals> | ||
<configuration> | <configuration> | ||
<artifactItems> | <artifactItems> | ||
<artifactItem> | <artifactItem> | ||
groupId>at.or.kirner</groupId> | |||
<artifactId> | <artifactId><project name>-client</artifactId> | ||
<version>${ | <version>${project.version}</version> | ||
<type>zip</type> | <type>zip</type> | ||
<overWrite>true</overWrite> | <overWrite>true</overWrite> | ||
<outputDirectory>${project.build.directory}/${project.artifactId}-${project.version}</outputDirectory> | <outputDirectory>${project.build.directory}/${project.artifactId}-${project.version}/angular-client</outputDirectory> | ||
</artifactItem> | </artifactItem> | ||
</artifactItems> | </artifactItems> | ||
| Zeile 39: | Zeile 75: | ||
</execution> | </execution> | ||
</executions> | </executions> | ||
</plugin> | </plugin> | ||
... | |||
</pre> | </pre> | ||
==== Links ==== | |||
[https://maven.apache.org/plugins/maven-dependency-plugin/examples/unpacking-artifacts.html https://maven.apache.org/plugins/maven-dependency-plugin/examples/unpacking-artifacts.html] | |||
== webpack == | == webpack == | ||
| Zeile 83: | Zeile 125: | ||
[https://medium.com/@anandshende1994/setting-base-href-dynamically-in-angular-6-b7fe824848cf https://medium.com/@anandshende1994/setting-base-href-dynamically-in-angular-6-b7fe824848cf] | [https://medium.com/@anandshende1994/setting-base-href-dynamically-in-angular-6-b7fe824848cf https://medium.com/@anandshende1994/setting-base-href-dynamically-in-angular-6-b7fe824848cf] | ||
== Reloading == | |||
In <code>src/main/webapp/WEB-INF/web.xml</code> folgenden Eintrag für Error-Page hinzufügen: | |||
<pre> | |||
<error-page> | |||
<error-code>404</error-code> | |||
<location>/index.html</location> | |||
</error-page> | |||
</pre> | |||
=== Links === | |||
[https://stackoverflow.com/questions/47366792/404-error-on-refresh-for-angularv4-deployed-on-tomcat-server https://stackoverflow.com/questions/47366792/404-error-on-refresh-for-angularv4-deployed-on-tomcat-server] | |||
== Apache HTTP == | == Apache HTTP == | ||
| Zeile 92: | Zeile 149: | ||
RewriteEngine On | RewriteEngine On | ||
RewriteOptions InheritDownBefore | |||
RewriteRule | # If an existing asset or directory is requested go to it as it is | ||
# RewriteCond %{DOCUMENT_ROOT}%{REQUEST_URI} -f [OR] | |||
# RewriteCond http://10.2.0.100:8080/video-archive/archive-client/%{REQUEST_URI} -f [OR] | |||
# RewriteCond %{DOCUMENT_ROOT}%{REQUEST_URI} -d | |||
# RewriteCond http://10.2.0.100:8080/video-archive/archive-client/%{REQUEST_URI} -d | |||
# RewriteRule / %{REQUEST_SCHEME}://10.2.0.99:8080/video-archive/archive-client/index.html [L] | |||
RewriteRule "/(.*)$" "%{REQUEST_SCHEME}://10.2.0.100:8080/video-archive/archive-client/$1" [P] | |||
ErrorLog ${APACHE_LOG_DIR}/video.kirner.or.at-error.log | ErrorLog ${APACHE_LOG_DIR}/video.kirner.or.at-error.log | ||
| Zeile 109: | Zeile 165: | ||
</VirtualHost> | </VirtualHost> | ||
</pre> | </pre> | ||
[https://httpd.apache.org/docs/trunk/rewrite/flags.html#flag_p https://httpd.apache.org/docs/trunk/rewrite/flags.html#flag_p] | |||
=== Links === | === Links === | ||
| Zeile 115: | Zeile 173: | ||
[https://www.netnea.com/cms/apache-tutorial-9-reverse-proxy-einrichten/ https://www.netnea.com/cms/apache-tutorial-9-reverse-proxy-einrichten/] | [https://www.netnea.com/cms/apache-tutorial-9-reverse-proxy-einrichten/ https://www.netnea.com/cms/apache-tutorial-9-reverse-proxy-einrichten/] | ||
[https://httpd.apache.org/docs/trunk/rewrite/ https://httpd.apache.org/docs/trunk/rewrite/] | |||
Zurück zu [[Angular#Deployment|Angular]] | Zurück zu [[Angular#Deployment|Angular]] | ||
Aktuelle Version vom 21. Juli 2020, 18:23 Uhr
Noch in Bearbeitung
Als Multimodule Maven Project
Siehe dazu Multimodule Maven Project
Links
https://www.devglan.com/spring-boot/spring-boot-angular-deployment
Als Maven Dependency
Dependency erstellen
cd dist/<projekt folder>/
ng build --prod
zip -r angular-client.zip *
# Kontrolle der Zip-Datei
unzip -l angular-client.zip
mvn install:install-file \
-Dfile=angular-client.zip \
-DgroupId=at.or.kirner \
-DartifactId=<project name>-client \
-Dversion=0.1 \
-Dpackaging=zip \
-DgeneratePom=true
Links
https://stackoverflow.com/questions/4955635/how-to-add-local-jar-files-to-a-maven-project
Dependency in WAR entpacken
...
<properties>
...
<client-version>${project.version}</client-version>
...
</properties>
...
<plugin>
<!-- copy the latest angular client from the repository into the war file -->
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>${dependency-plugin-version}</version>
<executions>
<execution>
<id>unpack-web-client</id>
<phase>prepare-package</phase>
<goals>
<goal>unpack</goal>
</goals>
<configuration>
<artifactItems>
<artifactItem>
groupId>at.or.kirner</groupId>
<artifactId><project name>-client</artifactId>
<version>${project.version}</version>
<type>zip</type>
<overWrite>true</overWrite>
<outputDirectory>${project.build.directory}/${project.artifactId}-${project.version}/angular-client</outputDirectory>
</artifactItem>
</artifactItems>
</configuration>
</execution>
</executions>
</plugin>
...
Links
https://maven.apache.org/plugins/maven-dependency-plugin/examples/unpacking-artifacts.html
webpack
Aktuell nicht verwendet
base-href
Da sich durch das Integrieren des Angular-Front-End in der WAR-Datei der Pfad ändert (z.B. 'http://10.0.0.100:8080/video-archive/archive-client') muss auch der Basispfad in Angular geändert werden.
Dazu im <head>-Abschnitt vom index.html <base href="/"> folgendermaßen anpassen:
<script>
if (window.location.port == 4200) {
document.write('<base href="/">');
} else {
document.write('<base href="/video-archive/archive-client/">');
}
window['base-href'] = window.location.pathname;
</script>
Und im Basis-Modul (z.B. 'app.module.ts') gehört APP_BASE_HREF angepasst:
import { APP_BASE_HREF } from '@angular/common';
...
@NgModule({
...
providers: [
{ provide: APP_BASE_HREF, useValue: window['base-href'] }
]
})
...
Links
https://medium.com/@anandshende1994/setting-base-href-dynamically-in-angular-6-b7fe824848cf
Reloading
In src/main/webapp/WEB-INF/web.xml folgenden Eintrag für Error-Page hinzufügen:
<error-page>
<error-code>404</error-code>
<location>/index.html</location>
</error-page>
Links
Apache HTTP
<VirtualHost *:80>
ServerName video.kirner.or.at
RewriteEngine On
RewriteOptions InheritDownBefore
# If an existing asset or directory is requested go to it as it is
# RewriteCond %{DOCUMENT_ROOT}%{REQUEST_URI} -f [OR]
# RewriteCond http://10.2.0.100:8080/video-archive/archive-client/%{REQUEST_URI} -f [OR]
# RewriteCond %{DOCUMENT_ROOT}%{REQUEST_URI} -d
# RewriteCond http://10.2.0.100:8080/video-archive/archive-client/%{REQUEST_URI} -d
# RewriteRule / %{REQUEST_SCHEME}://10.2.0.99:8080/video-archive/archive-client/index.html [L]
RewriteRule "/(.*)$" "%{REQUEST_SCHEME}://10.2.0.100:8080/video-archive/archive-client/$1" [P]
ErrorLog ${APACHE_LOG_DIR}/video.kirner.or.at-error.log
CustomLog ${APACHE_LOG_DIR}/video.kirner.or.at-access.log combined
</VirtualHost>
https://httpd.apache.org/docs/trunk/rewrite/flags.html#flag_p
Links
https://angular.io/guide/deployment
https://www.netnea.com/cms/apache-tutorial-9-reverse-proxy-einrichten/
https://httpd.apache.org/docs/trunk/rewrite/
Zurück zu Angular