mirror of
				https://github.com/miaowware/qrm2.git
				synced 2025-10-25 01:10:21 -04:00 
			
		
		
		
	Docker: We have docs, Doc!
- Added documentation on running the bot
    with docker-compose and docker.
			
			
This commit is contained in:
		
							parent
							
								
									6cbf975593
								
							
						
					
					
						commit
						90738d81de
					
				
							
								
								
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -7,6 +7,8 @@ cty.zip | ||||
| /devenv/ | ||||
| /data/ | ||||
| 
 | ||||
| /docker-compose.yml | ||||
| 
 | ||||
| 
 | ||||
| ######################################################### | ||||
| # Byte-compiled / optimized / DLL files | ||||
|  | ||||
							
								
								
									
										119
									
								
								README-DOCKER.md
									
									
									
									
									
								
							
							
						
						
									
										119
									
								
								README-DOCKER.md
									
									
									
									
									
								
							| @ -1,11 +1,114 @@ | ||||
| A sample `docker-compose.yml` file: | ||||
| # Docker help for qrm2 | ||||
| 
 | ||||
| ```yaml | ||||
| version: '3' | ||||
| services: | ||||
|     bot: | ||||
| You have multiple ways to use docker to run an instance of qrm2 | ||||
| 
 | ||||
| - [Docker help for qrm2](#docker-help-for-qrm2) | ||||
|   - [Using docker-compose and the prebuilt-image (recommended)](#using-docker-compose-and-the-prebuilt-image-recommended) | ||||
|   - [Using docker-compose and building the image](#using-docker-compose-and-building-the-image) | ||||
|   - [Using pure docker](#using-pure-docker) | ||||
|     - [[Optional] Building the image](#optional-building-the-image) | ||||
|     - [Creating the container](#creating-the-container) | ||||
| 
 | ||||
| 
 | ||||
| ## Using docker-compose and the prebuilt-image (recommended) | ||||
| 
 | ||||
| This is the easiest method for running the bot without any modifications.   | ||||
| **Do not clone the repository when using this method!** | ||||
| 
 | ||||
| 1. Create a new directory and `cd` into it. | ||||
| 
 | ||||
| 2. Create the `docker-compose.yml` file: | ||||
| 
 | ||||
|     ```yaml | ||||
|     version: '3' | ||||
|     services: | ||||
|       qrm2: | ||||
|         image: "classabbyamp/discord-qrm2:latest" | ||||
|         container_name: "discord-qrm2" | ||||
|         restart: on-failure | ||||
|         volumes: | ||||
|             - "./data:/app/data:rw" | ||||
| ``` | ||||
|           - "./data:/app/data:rw" | ||||
|         environment: | ||||
|           - PYTHONUNBUFFERED=1 | ||||
|     ``` | ||||
| 
 | ||||
| 3. Create a subdirectory named `data`. | ||||
| 
 | ||||
| 4. Copy the templates for `options.py` and `keys.py` to `data/`, and edit them. | ||||
| 
 | ||||
| 5. Run `docker-compose`: | ||||
| 
 | ||||
|     ```none | ||||
|     $ docker-compose pull | ||||
|     $ docker-compose up -d | ||||
|     ``` | ||||
| 
 | ||||
|     > Run without "-d" to test the bot. (run in foreground) | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| ## Using docker-compose and building the image | ||||
| 
 | ||||
| This is the easiest method to run the bot with modifications. | ||||
| 
 | ||||
| 1. `cd` into the repository. | ||||
| 
 | ||||
| 2. Create the `docker-compose.yml` file: | ||||
| 
 | ||||
|     ```yaml | ||||
|     version: '3' | ||||
|     services: | ||||
|       qrm2: | ||||
|         build: . | ||||
|         image: "discord-qrm2:local-latest" | ||||
|         restart: on-failure | ||||
|         volumes: | ||||
|           - "./data:/app/data:rw" | ||||
|         environment: | ||||
|           - PYTHONUNBUFFERED=1 | ||||
|     ``` | ||||
| 
 | ||||
| 3. Create a subdirectory named `data`. | ||||
| 
 | ||||
| 4. Copy the templates for `options.py` and `keys.py` to `data/`, and edit them. | ||||
| 
 | ||||
| 5. Run `docker-compose`: | ||||
| 
 | ||||
|     ```none | ||||
|     $ docker-compose build --pull | ||||
|     $ docker-compose -d | ||||
|     ``` | ||||
| 
 | ||||
|     > Run without "-d" to test the bot. (run in foreground) | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| ## Using pure docker | ||||
| 
 | ||||
| This methods is not very nice to use.   | ||||
| *I just wanna run the darn thing, not do gymnastics!* | ||||
| 
 | ||||
| 
 | ||||
| ### [Optional] Building the image | ||||
| 
 | ||||
| 1. `cd` into the repository. | ||||
| 
 | ||||
| 2. Run docker build: | ||||
| 
 | ||||
|     ```none | ||||
|     $ docker build -t discord-qrm2:local-latest . | ||||
|     ``` | ||||
| 
 | ||||
| 
 | ||||
| ### Creating the container | ||||
| 
 | ||||
| 1. Be in a directory with a `data/` subdirectory, which should contain valid `options.py` and `keys.py` files (copy and edit the templates). | ||||
| 
 | ||||
| 2. Run the container: | ||||
| 
 | ||||
|     ```none | ||||
|     $ docker run -d --rm --mount type=bind,src=$(pwd)/data,dst=/app/data --name qrm2 [image] | ||||
|     ``` | ||||
| 
 | ||||
|     Whereas `[image]` is either of: | ||||
|     - `discord-qrm2:local-latest` if you are building your own. | ||||
|     - `classabbyamp/discord-qrm2:latest` if you want to use the prebuilt image. | ||||
|  | ||||
| @ -6,7 +6,7 @@ An independent rewrite of qrmbot-discord. | ||||
| 
 | ||||
| ## Running | ||||
| 
 | ||||
| ### Docker | ||||
| ### With Docker | ||||
| 
 | ||||
| See [README-DOCKER.md](./README-DOCKER.md) | ||||
| 
 | ||||
| @ -30,4 +30,3 @@ Copyright (C) 2019 Abigail Gold, 0x5c | ||||
| 
 | ||||
| This program is released under the terms of the GNU General Public License, | ||||
| version 2. See `COPYING` for full license text. | ||||
| 
 | ||||
|  | ||||
| @ -1,7 +0,0 @@ | ||||
| version: '3' | ||||
| services: | ||||
|     bot: | ||||
|         build: . | ||||
|         container_name: "discord-qrm2" | ||||
|         volumes: | ||||
|             - "./data:/app/data:rw" | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user