<?xml version="1.0"?>
<oembed><version>1.0</version><provider_name>Docker-Profis</provider_name><provider_url>https://dockerpros.com/de</provider_url><title>Docker Compose Run - Dockerpros</title><type>rich</type><width>600</width><height>338</height><html>&lt;blockquote class="wp-embedded-content" data-secret="SbQCjES1Lp"&gt;&lt;a href="https://dockerpros.com/de/wiki/docker-compose-run/"&gt;Docker Compose Run

Docker Compose ist ein Tool, das es erm&#xF6;glicht, mehrere Docker-Container als Einheit zu definieren und zu verwalten. Es verwendet eine YAML-Datei, um die Konfiguration der Container zu beschreiben, einschlie&#xDF;lich der verwendeten Images, der Netzwerkeinstellungen, der Umgebungsvariablen und der Verkn&#xFC;pfungen zwischen den Containern.

Um Docker Compose zu verwenden, m&#xFC;ssen Sie zun&#xE4;chst eine YAML-Datei erstellen, die die Konfiguration Ihrer Container beschreibt. Diese Datei wird normalerweise "docker-compose.yml" genannt und sollte im Stammverzeichnis Ihres Projekts gespeichert werden.

Hier ist ein Beispiel f&#xFC;r eine einfache docker-compose.yml-Datei:

```yaml
version: '3'
services:
  web:
    image: nginx:latest
    ports:
      - "80:80"
    volumes:
      - ./html:/usr/share/nginx/html
  db:
    image: mysql:latest
    environment:
      MYSQL_ROOT_PASSWORD: example
```

In diesem Beispiel definieren wir zwei Dienste: "web" und "db". Der "web"-Dienst verwendet das neueste Nginx-Image und bindet Port 80 des Containers an Port 80 des Hosts. Au&#xDF;erdem wird ein Volume eingebunden, das den Inhalt des "html"-Verzeichnisses im Stammverzeichnis des Projekts in das Nginx-Verzeichnis f&#xFC;r statische Dateien kopiert. Der "db"-Dienst verwendet das neueste MySQL-Image und setzt das Root-Passwort auf "example".

Um die Container mit Docker Compose zu starten, navigieren Sie zum Verzeichnis, das die docker-compose.yml-Datei enth&#xE4;lt, und f&#xFC;hren Sie den folgenden Befehl aus:

```
docker-compose up
```

Dieser Befehl startet alle in der docker-compose.yml-Datei definierten Container. Wenn Sie die Container im Hintergrund starten m&#xF6;chten, k&#xF6;nnen Sie den Parameter "-d" hinzuf&#xFC;gen:

```
docker-compose up -d
```

Um die Container zu stoppen, verwenden Sie den folgenden Befehl:

```
docker-compose down
```

Docker Compose bietet auch viele weitere Befehle und Optionen, um die Container zu verwalten. Zum Beispiel k&#xF6;nnen Sie mit "docker-compose ps" eine Liste der laufenden Container anzeigen, mit "docker-compose logs" die Logs der Container anzeigen und mit "docker-compose exec" Befehle in den Containern ausf&#xFC;hren.

Zusammenfassend l&#xE4;sst sich sagen, dass Docker Compose ein leistungsstarkes Tool ist, um mehrere Docker-Container als Einheit zu verwalten. Es vereinfacht die Konfiguration und Verwaltung von Multi-Container-Anwendungen erheblich und ist ein unverzichtbares Werkzeug f&#xFC;r jeden Docker-Entwickler.&lt;/a&gt;&lt;/blockquote&gt;&lt;iframe sandbox="allow-scripts" security="restricted" src="https://dockerpros.com/de/wiki/docker-compose-run/embed/#?secret=SbQCjES1Lp" width="600" height="338" title="&#x201E;Docker-Compose-Run&#x201C; &#x2013; Docker-Profis" data-secret="SbQCjES1Lp" frameborder="0" marginwidth="0" marginheight="0" scrolling="no" class="wp-embedded-content"&gt;&lt;/iframe&gt;&lt;script&gt;
/**
 * WordPress inline HTML embed
 *
 * @since 4.4.0
 * @output wp-includes/js/wp-embed.js
 *
 * Single line comments should not be used since they will break
 * the script when inlined in get_post_embed_html(), specifically
 * when the comments are not stripped out due to SCRIPT_DEBUG
 * being turned on.
 */
(function ( window, document ) {
	'use strict';

	/* Abort for ancient browsers. */
	if ( ! document.querySelector || ! window.addEventListener || typeof URL === 'undefined' ) {
		return;
	}

	/** @namespace wp */
	window.wp = window.wp || {};

	/* Abort if script was already executed. */
	if ( !! window.wp.receiveEmbedMessage ) {
		return;
	}

	/**
	 * Receive embed message.
	 *
	 * @param {MessageEvent} e
	 */
	window.wp.receiveEmbedMessage = function( e ) {
		var data = e.data;

		/* Verify shape of message. */
		if (
			! ( data || data.secret || data.message || data.value ) ||
			/[^a-zA-Z0-9]/.test( data.secret )
		) {
			return;
		}

		var iframes = document.querySelectorAll( 'iframe[data-secret="' + data.secret + '"]' ),
			blockquotes = document.querySelectorAll( 'blockquote[data-secret="' + data.secret + '"]' ),
			allowedProtocols = new RegExp( '^https?:$', 'i' ),
			i, source, height, sourceURL, targetURL;

		for ( i = 0; i &lt; blockquotes.length; i++ ) {
			blockquotes[ i ].style.display = 'none';
		}

		for ( i = 0; i &lt; iframes.length; i++ ) {
			source = iframes[ i ];

			if ( e.source !== source.contentWindow ) {
				continue;
			}

			source.removeAttribute( 'style' );

			if ( 'height' === data.message ) {
				/* Resize the iframe on request. */
				height = parseInt( data.value, 10 );
				if ( height &gt; 1000 ) {
					height = 1000;
				} else if ( ~~height &lt; 200 ) {
					height = 200;
				}

				source.height = height;
			} else if ( 'link' === data.message ) {
				/* Link to a specific URL on request. */
				sourceURL = new URL( source.getAttribute( 'src' ) );
				targetURL = new URL( data.value );

				if (
					allowedProtocols.test( targetURL.protocol ) &amp;&amp;
					targetURL.host === sourceURL.host &amp;&amp;
					document.activeElement === source
				) {
					window.top.location.href = data.value;
				}
			}
		}
	};

	function onLoad() {
		var iframes = document.querySelectorAll( 'iframe.wp-embedded-content' ),
			i, source, secret;

		for ( i = 0; i &lt; iframes.length; i++ ) {
			/** @var {IframeElement} */
			source = iframes[ i ];

			secret = source.getAttribute( 'data-secret' );
			if ( ! secret ) {
				/* Add secret to iframe */
				secret = Math.random().toString( 36 ).substring( 2, 12 );
				source.src += '#?secret=' + secret;
				source.setAttribute( 'data-secret', secret );
			}

			/*
			 * Let post embed window know that the parent is ready for receiving the height message, in case the iframe
			 * loaded before wp-embed.js was loaded. When the ready message is received by the post embed window, the
			 * window will then (re-)send the height message right away.
			 */
			source.contentWindow.postMessage( {
				message: 'ready',
				secret: secret
			}, '*' );
		}
	}

	window.addEventListener( 'message', window.wp.receiveEmbedMessage, false );
	document.addEventListener( 'DOMContentLoaded', onLoad, false );
})( window, document );
//# sourceURL=https://dockerpros.com/wp-includes/js/wp-embed.js
&lt;/script&gt;</html><thumbnail_url>https://dockerpros.com/wp-content/uploads/2024/07/docker-compose-run_1189.jpg</thumbnail_url><thumbnail_width>800</thumbnail_width><thumbnail_height>600</thumbnail_height><description>Docker Compose Run enables developers to define and run multi-container applications easily. By specifying services in a `docker-compose.yml` file, users can efficiently manage dependencies and configurations.</description></oembed>
