https://wiki.archlinux.de/api.php?action=feedcontributions&user=Axman&feedformat=atomwiki.archlinux.de - Benutzerbeiträge [de]2024-03-29T13:35:04ZBenutzerbeiträgeMediaWiki 1.41.0https://wiki.archlinux.de/index.php?title=Nginx&diff=17813Nginx2014-08-01T11:09:05Z<p>Axman: Link auf Apache im Arch-Wiki eingefügt.</p>
<hr />
<div>{{SEITENTITEL:nginx}}<br />
[[Bild:Nginx.gif|thumb|Offizielles Nginx Logo]]<br />
Der ursprüngliche Entwickler Igor Sysoev beschreibt nginx (englisch ausgesprochen ''Engine X'') als äußerst leistungsfähigen, aber dennoch schlanken Webserver, Reverse Proxy und E-Mail-Proxy. Er stellt damit eine ausgezeichnete Alternative oder Ergänzung zu [[Apache|Apache2]] oder [[lighttpd]] dar.<br />
<br />
{{installation|repo=community|paket=nginx}}<br />
<br />
Nach der Installation sollte nginx noch über systemd aktiviert werden, damit sichergestellt ist, dass der Webserver bei einem Neustart automatisch mitgestartet wird.<br />
systemctl enable nginx<br />
<br />
Nach Abschluss der Konfiguration kann man nginx direkt mittels {{ic|systemctl start nginx}} starten.<br />
<br />
== Benutzung und Anpassung ==<br />
Standardmäßig sollte nginx bereits funktionieren. Dies kann getestet werden, indem die IP oder der Reverse DNS des Servers im Browser eingegeben wird. Sollten dennoch Änderungen in der Konfiguration erwünscht sein, so kann hierzu die Datei {{ic|/etc/nginx/nginx.conf}} den eigenen Wünschen nach angepasst werden. Um beispielsweise einen neuen Hosteintrag vorzunehmen, gilt es innerhalb des http-Abschnittes folgendes hinzuzufügen:<br />
<br />
http {<br />
server {<br />
listen 80;<br />
server_name domain.tld;<br />
<br />
location / {<br />
root /home/username/webseite;<br />
index index.html;<br />
}<br />
}<br />
}<br />
<br />
Bei dieser Konfiguration ist zu beachten, dass nginx entweder unter dem Benutzer username oder root ausgeführt wird, da sonst keine Zugriffsberechtigungen auf /home/username bestehen. Hierzu gilt es die Zeile<br />
#user http;<br />
in<br />
user username users;<br />
zu verändern.<br />
<br />
Weitere Konfigurationsmöglichkeiten sind bitte dem [http://wiki.nginx.org/Main offiziellen Wiki] zu entnehmen.<br />
<br />
=== Die wichtigsten Befehle ===<br />
Zweifelsohne die wichtigsten Befehle sind Stop, Neustart, Start und Reload. Diese lassen sich wie folgt bedienen:<br />
systemctl start nginx<br />
systemctl stop nginx<br />
systemctl restart nginx<br />
systemctl reload nginx<br />
<br />
Diese sind beispielsweise dann nützlich, wenn die Konfigurationsdatei verändert wurde, aber noch nicht geladen wurde. Hierfür reicht ein reload bereits aus.<br />
<br />
== Nginx und mod_wsgi ==<br />
Mit einem Patch ist es möglich, in Python geschriebene Webanwendungen (beispielsweise in Django oder Bottle) per Python Web Server Gateway Interface, kurz WSGI, über nginx auszuliefern. Hierzu kann die bereits {{AUR|nginx-mod_wsgi|gepatchte Version}} aus dem [[AUR]] installiert werden.<br />
Anschließend ist die Datei {{ic|/etc/nginx/wsgi_vars}} mit folgendem Inhalt anzulegen.<br />
# /etc/nginx/wsgi_vars<br />
wsgi_var REQUEST_METHOD $request_method;<br />
#wsgi_var SCRIPT_NAME $uri; # TODO<br />
#wsgi_var PATH_INFO $uri; # TODO<br />
wsgi_var QUERY_STRING $query_string;<br />
wsgi_var CONTENT_TYPE $content_type;<br />
wsgi_var CONTENT_LENGTH $content_length;<br />
wsgi_var SERVER_NAME $server_name;<br />
wsgi_var SERVER_PORT $server_port;<br />
wsgi_var SERVER_PROTOCOL $server_protocol;<br />
#<br />
# additional variables<br />
# (they will be present in the WSGI environment only if not empty)<br />
#<br />
wsgi_var REQUEST_URI $request_uri;<br />
wsgi_var DOCUMENT_URI $document_uri;<br />
wsgi_var DOCUMENT_ROOT $document_root;<br />
wsgi_var SERVER_SOFTWARE $nginx_version;<br />
wsgi_var REMOTE_ADDR $remote_addr;<br />
wsgi_var REMOTE_PORT $remote_port;<br />
wsgi_var SERVER_ADDR $server_addr;<br />
set $auth_type '';<br />
if ($remote_user) {<br />
set $auth_type Basic;<br />
}<br />
#wsgi_var REMOTE_USER $remote_user;<br />
#wsgi_var AUTH_TYPE $auth_type;<br />
<br />
Nun sollte es ausreichen, einen entsprechenden server-Eintrag in der {{ic|/etc/nginx/conf/nginx.conf}} vorzunehmen. <br />
<br />
server {<br />
server_name foo.bar.org<br />
listen 80;<br />
access_log off;<br />
location /admin_media/ {<br />
alias /var/lib/python-support/python2.6/django/contrib/admin/media/;<br />
}<br />
location /media/ {<br />
alias /home/foo/bar/media/;<br />
}<br />
location / {<br />
include /etc/nginx/wsgi_vars;<br />
wsgi_pass /home/foo/bar.wsgi;<br />
}<br />
}<br />
<br />
== Weblinks ==<br />
* [http://nginx.org/ Offizielle Webseite] {{sprache|en}}<br />
* [http://wiki.nginx.org/Main Offizielles Wiki] {{sprache|en}}<br />
<br />
[[Kategorie:HTTP-Server]]<br />
[[en:Nginx]]</div>Axmanhttps://wiki.archlinux.de/index.php?title=Nginx&diff=17812Nginx2014-08-01T10:42:54Z<p>Axman: </p>
<hr />
<div>{{SEITENTITEL:nginx}}<br />
[[Bild:Nginx.gif|thumb|Offizielles Nginx Logo]]<br />
Der ursprüngliche Entwickler Igor Sysoev beschreibt nginx (englisch ausgesprochen ''Engine X'') als äußerst leistungsfähigen, aber dennoch schlanken Webserver, Reverse Proxy und E-Mail-Proxy. Er stellt damit eine ausgezeichnete Alternative oder Ergänzung zu Apache2 oder [[lighttpd]] dar.<br />
<br />
{{installation|repo=community|paket=nginx}}<br />
<br />
Nach der Installation sollte nginx noch über systemd aktiviert werden, damit sichergestellt ist, dass der Webserver bei einem Neustart automatisch mitgestartet wird.<br />
systemctl enable nginx<br />
<br />
Nach Abschluss der Konfiguration kann man nginx direkt mittels {{ic|systemctl start nginx}} starten.<br />
<br />
== Benutzung und Anpassung ==<br />
Standardmäßig sollte nginx bereits funktionieren. Dies kann getestet werden, indem die IP oder der Reverse DNS des Servers im Browser eingegeben wird. Sollten dennoch Änderungen in der Konfiguration erwünscht sein, so kann hierzu die Datei {{ic|/etc/nginx/nginx.conf}} den eigenen Wünschen nach angepasst werden. Um beispielsweise einen neuen Hosteintrag vorzunehmen, gilt es innerhalb des http-Abschnittes folgendes hinzuzufügen:<br />
<br />
http {<br />
server {<br />
listen 80;<br />
server_name domain.tld;<br />
<br />
location / {<br />
root /home/username/webseite;<br />
index index.html;<br />
}<br />
}<br />
}<br />
<br />
Bei dieser Konfiguration ist zu beachten, dass nginx entweder unter dem Benutzer username oder root ausgeführt wird, da sonst keine Zugriffsberechtigungen auf /home/username bestehen. Hierzu gilt es die Zeile<br />
#user http;<br />
in<br />
user username users;<br />
zu verändern.<br />
<br />
Weitere Konfigurationsmöglichkeiten sind bitte dem [http://wiki.nginx.org/Main offiziellen Wiki] zu entnehmen.<br />
<br />
=== Die wichtigsten Befehle ===<br />
Zweifelsohne die wichtigsten Befehle sind Stop, Neustart, Start und Reload. Diese lassen sich wie folgt bedienen:<br />
systemctl start nginx<br />
systemctl stop nginx<br />
systemctl restart nginx<br />
systemctl reload nginx<br />
<br />
Diese sind beispielsweise dann nützlich, wenn die Konfigurationsdatei verändert wurde, aber noch nicht geladen wurde. Hierfür reicht ein reload bereits aus.<br />
<br />
== Nginx und mod_wsgi ==<br />
Mit einem Patch ist es möglich, in Python geschriebene Webanwendungen (beispielsweise in Django oder Bottle) per Python Web Server Gateway Interface, kurz WSGI, über nginx auszuliefern. Hierzu kann die bereits {{AUR|nginx-mod_wsgi|gepatchte Version}} aus dem [[AUR]] installiert werden.<br />
Anschließend ist die Datei {{ic|/etc/nginx/wsgi_vars}} mit folgendem Inhalt anzulegen.<br />
# /etc/nginx/wsgi_vars<br />
wsgi_var REQUEST_METHOD $request_method;<br />
#wsgi_var SCRIPT_NAME $uri; # TODO<br />
#wsgi_var PATH_INFO $uri; # TODO<br />
wsgi_var QUERY_STRING $query_string;<br />
wsgi_var CONTENT_TYPE $content_type;<br />
wsgi_var CONTENT_LENGTH $content_length;<br />
wsgi_var SERVER_NAME $server_name;<br />
wsgi_var SERVER_PORT $server_port;<br />
wsgi_var SERVER_PROTOCOL $server_protocol;<br />
#<br />
# additional variables<br />
# (they will be present in the WSGI environment only if not empty)<br />
#<br />
wsgi_var REQUEST_URI $request_uri;<br />
wsgi_var DOCUMENT_URI $document_uri;<br />
wsgi_var DOCUMENT_ROOT $document_root;<br />
wsgi_var SERVER_SOFTWARE $nginx_version;<br />
wsgi_var REMOTE_ADDR $remote_addr;<br />
wsgi_var REMOTE_PORT $remote_port;<br />
wsgi_var SERVER_ADDR $server_addr;<br />
set $auth_type '';<br />
if ($remote_user) {<br />
set $auth_type Basic;<br />
}<br />
#wsgi_var REMOTE_USER $remote_user;<br />
#wsgi_var AUTH_TYPE $auth_type;<br />
<br />
Nun sollte es ausreichen, einen entsprechenden server-Eintrag in der {{ic|/etc/nginx/conf/nginx.conf}} vorzunehmen. <br />
<br />
server {<br />
server_name foo.bar.org<br />
listen 80;<br />
access_log off;<br />
location /admin_media/ {<br />
alias /var/lib/python-support/python2.6/django/contrib/admin/media/;<br />
}<br />
location /media/ {<br />
alias /home/foo/bar/media/;<br />
}<br />
location / {<br />
include /etc/nginx/wsgi_vars;<br />
wsgi_pass /home/foo/bar.wsgi;<br />
}<br />
}<br />
<br />
== Weblinks ==<br />
* [http://nginx.org/ Offizielle Webseite] {{sprache|en}}<br />
* [http://wiki.nginx.org/Main Offizielles Wiki] {{sprache|en}}<br />
<br />
[[Kategorie:HTTP-Server]]<br />
[[en:Nginx]]</div>Axman