2022-03-22 21:11:09 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p  align = center > < img  src = img/prind-logo.png  height = 400px > < / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# prind
  
						 
					
						
							
								
									
										
										
										
											2021-10-28 21:09:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[](https://github.com/mkuf/prind/actions/workflows/klipper.yaml)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[](https://github.com/mkuf/prind/actions/workflows/moonraker.yaml)
							 
						 
					
						
							
								
									
										
										
										
											2022-03-17 19:43:56 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[](https://github.com/mkuf/prind/actions/workflows/klipperscreen.yaml)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-28 21:09:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[](https://github.com/mkuf/prind/actions/workflows/ustreamer.yaml)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-26 09:19:36 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								prind allows you to run the Software for your 3D Printer in Docker containers.  
							 
						 
					
						
							
								
									
										
										
										
											2022-04-01 13:54:36 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								With a single Command, you can start up klipper and choose between multiple Frontends. 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Currently supported Frontends:
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:54:31 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  Octoprint (via [Dockerhub ](https://hub.docker.com/r/octoprint/octoprint ))
							 
						 
					
						
							
								
									
										
										
										
											2023-05-14 15:46:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  Fluidd (via [GHCR ](https://github.com/fluidd-core/fluidd/pkgs/container/fluidd ))
							 
						 
					
						
							
								
									
										
										
										
											2022-07-08 09:44:13 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  Mainsail (via [GHCR ](https://github.com/mainsail-crew/mainsail/pkgs/container/mainsail ))
							 
						 
					
						
							
								
									
										
										
										
											2022-04-01 13:54:36 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  KlipperScreen
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Depending on which Frontend you've chosen, moonraker will also be deployed.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Getting started
  
						 
					
						
							
								
									
										
										
										
											2022-03-17 19:43:56 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The following Guide requires ``docker`` and ``docker compose` ` on your machine.  
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Follow the official Guides on how to get them up and running. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  https://docs.docker.com/engine/install/ubuntu/ 
						 
					
						
							
								
									
										
										
										
											2022-01-31 19:19:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  https://docs.docker.com/compose/cli-command/#installing -compose-v2 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-06-18 21:18:39 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Build the MCU Code
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Before using Klipper, you'll have to build and flash the microcontroller-code for your printers mainboard.  
							 
						 
					
						
							
								
									
										
										
										
											2022-07-08 15:32:03 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								As this can be accomplished via docker, we can create an alias that replaces `make`  with the appropriate docker compose command. After setting this alias, follow the Instructions on finding your printer, building and flashing the microcontroller found in the [Klipper Docs ](https://www.klipper3d.org/Installation.html#building-and-flashing-the-micro-controller ).  
							 
						 
					
						
							
								
									
										
										
										
											2022-06-18 21:18:39 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Adapted from the official Docs, a generic Build would look like this.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2022-07-09 10:26:44 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								alias make="docker compose -f docker-compose.extra.make.yaml run --rm make"
							 
						 
					
						
							
								
									
										
										
										
											2022-06-18 21:18:39 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								make menuconfig
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								make
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								make flash FLASH_DEVICE=/dev/serial/by-id/< my  printer > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If your Board can be flashed via SD-Card, you may want to omit `make flash`  and retrieve the `klipper.bin`  from the `out`  directory that is created by `make` . Follow your boards instructions on how to proceed with flashing via SD-Card.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-03-09 22:36:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Add your Configuration to docker-compose.override.yaml
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Locate the ``klipper`` Service within ``docker-compose.override.yaml`` and update the ``device` ` Section with the Serial Port of your Printer.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In this example, the Printer is using device ``/dev/ttymxc3` `.
							 
						 
					
						
							
								
									
										
										
										
											2022-02-15 19:50:13 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  klipper:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    devices:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  /dev/ttymxc3:/dev/ttymxc3
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-18 22:12:59 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Locate the ``webcam`` Service within ``docker-compose.override.yaml`` and update the ``device` ` Section with the Device Name of your Webcam.  
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								In this example, the Webcam is using device ``/dev/video0` `. Do not edit any other lines.
							 
						 
					
						
							
								
									
										
										
										
											2022-02-15 19:50:13 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2022-04-18 22:12:59 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  webcam:
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    < < :  * ustreamer-svc 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    devices:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  /dev/video0:/dev/webcam
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    labels:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  "traefik.enable=true"
							 
						 
					
						
							
								
									
										
										
										
											2022-04-18 22:12:59 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      -  "traefik.http.services.webcam.loadbalancer.server.port=8080"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  "traefik.http.routers.webcam.rule=PathPrefix(`/webcam` )"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  "traefik.http.routers.webcam.entrypoints=web"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  "traefik.http.middlewares.webcam.stripprefix.prefixes=/webcam"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  "traefik.http.routers.webcam.middlewares=webcam"
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-26 07:37:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Configuring Klipper/Moonraker
  
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								All Runtime Configs are stored within ``config` ` of this Repo.  
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:54:31 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  Update config/printer.cfg with your Klipper config, make sure to not remove the existing Macros as they are required by fluidd/mainsail. See [Klipper3d Docs ](https://www.klipper3d.org/Config_Reference.html ) for Reference 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Make sure to update ``cors_domains`` and ``trusted_clients`` within ``moonraker.cfg` ` to secure your moonraker api from unwanted access. See [Moonraker Docs ](https://moonraker.readthedocs.io/en/latest/configuration/ ) for Reference 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Starting the stack
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Currently, there are 3 Profiles to choose from, depending on the Web Frontend you'd like to use.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  fluidd 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  mainsail 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  octoprint 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Starting the stack comes down to:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose --profile < profile >  up -d
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								e.g.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose --profile fluidd up -d
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Switching between profiles requires the whole stack to be torn down before starting another Frontend.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Running two Frontends at the same time is currently not supported.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Switching from fluidd to mainsail would look like this: 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose --profile fluidd down
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose --profile mainsail up -d
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-12-12 18:20:39 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Additional Profiles
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### KlipperScreen
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[KlipperScreen by jordanruthe ](https://github.com/jordanruthe/KlipperScreen ) can be enabled via the `klipperscreen`  Profile.  
							 
						 
					
						
							
								
									
										
										
										
											2022-03-17 19:43:56 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-12-12 18:20:39 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								It requires a X11 Server on your machine that the Container can connect to.  
							 
						 
					
						
							
								
									
										
										
										
											2022-03-22 23:28:42 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Locate the setup Script for X11 within `scripts/`  and run it from the root directory of this repository as user root.
							 
						 
					
						
							
								
									
										
										
										
											2022-03-17 19:43:56 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								It creates a User, installs and configures X11 and creates a Systemd Service for xinit.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2022-03-22 23:28:42 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								cd prind/
							 
						 
					
						
							
								
									
										
										
										
											2022-03-17 19:43:56 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								./scripts/setup-X11.sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-06-18 21:18:39 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The Prind Logo should now be displayed on your screen.  
							 
						 
					
						
							
								
									
										
										
										
											2022-03-17 19:43:56 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If this is not the case, check the scripts output for errors.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Otherwise, proceed to start/update the Stack.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose --profile fluidd --profile klipperscreen up -d
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-12-12 18:20:39 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#### Moonraker-Telegram-Bot
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[moonraker-telegram-bot by nlef ](https://github.com/nlef/moonraker-telegram-bot ) can be enabled via the `moonraker-telegram-bot`  Profile  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Add your `bot_token`  and `chat_id`  to `config/telegram.conf` .  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								See the [configuration reference ](https://github.com/nlef/moonraker-telegram-bot/wiki/Sample-config ) for further configuration Options.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose --profile mainsail --profile moonraker-telegram-bot up -d
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Updating
  
						 
					
						
							
								
									
										
										
										
											2022-07-07 21:50:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Images are built daily and tagged with latest and the first seven chars of the commit-sha of the remote repo. 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Example: 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-07 21:50:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  ``mkuf/klipper:latest` ` 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  ``mkuf/klipper:a33d069` ` 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-07 21:50:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The ``latest` ` Tag will point to a new Image within 24h.  
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:54:31 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The SHA-Tag ``a33d069` ` will remain and refers to [Klipper3d/klipper:a33d069 ](https://github.com/Klipper3d/klipper/commit/a33d0697b6438e362f0cf9d25e1e8358d331bf53 )
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Updating can be handled via docker-compose.  
							 
						 
					
						
							
								
									
										
										
										
											2022-07-07 21:50:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								docker-compose.yaml uses latest tags for all Images contained in this Repository.  
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Compose will download all current Images and replace them when starting the stack again. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose pull
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose --profile < profile >  up -d
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								``` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Advanced Topics
  
						 
					
						
							
								
									
										
										
										
											2023-04-08 00:35:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Serial device permissions
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								It may be necessary to change the permissions of your printers serial device.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This is usually the case when you're on a non debian based distro which uses a different numerical groupid for the `dialout`  group.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Serial devices passed into the klipper container should be assigned to groupid `20`  for the permissions to work within it.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This may be done by creating a udev rule on your host machine for your specific device, read up on how to do this on your specific OS.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Usually you'll have to create a `*.rules`  file in `/etc/udev/rules.d`  and add a single line like this to it.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Be sure to use your devices specific `idVendor`  and `idProduct` , which can be found via `lsusb` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ACTION=="add",SUBSYSTEM=="tty",ATTRS{idVendor}=="0000",ATTRS{idProduct}=="0000",GROUP="20"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-08 16:30:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Input Shaper Calibration
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Note:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>Running a host_mcu process on a RaspberryPi to access its GPIO pins is currently not possible when running in Docker.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Feel free to contribute if you have a Solution for this.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Using input shaper requires an accelerometer that is directly connected to your printers mainboard. Follow the Docs on [Measuring Resonances ](https://www.klipper3d.org/Measuring_Resonances.html ), to set up your Printer accordingly.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								After running `TEST_RESONANCES`  or `SHAPER_CALIBRATE` , Klipper generates csv output in /tmp. To further analyze this data, it has to be extracted from the running klipper container.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								mkdir ./resonances
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose exec klipper ls /tmp
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  resonances_x_20220708_124515.csv  resonances_y_20220708_125150.csv
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose cp klipper:/tmp/resonances_x_20220708_124515.csv ./resonances/
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose cp klipper:/tmp/resonances_y_20220708_125150.csv ./resonances/
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-08 23:54:04 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								`docker-compose.extra.calibrate-shaper.yaml`  is set up to run `calibrate_shaper.py` , so any options supported by the script can also be used with the container.  
						 
					
						
							
								
									
										
										
										
											2022-07-08 16:30:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Set an alias to save yourself from typing the the docker compose command multiple times. The generated Images are located besides the csv files in `./resonances` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2022-07-08 23:54:04 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								alias calibrate_shaper="docker compose -f docker-compose.extra.calibrate-shaper.yaml run --rm calibrate_shaper"
							 
						 
					
						
							
								
									
										
										
										
											2022-07-08 16:30:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								calibrate_shaper resonances_x_20220708_124515.csv -o cal_x.png
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  [...]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  Recommended shaper is ei @ 90.2 Hz
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								calibrate_shaper resonances_y_20220708_125150.csv -o cal_y.png
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  [...]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  Recommended shaper is mzv @ 48.2 Hz
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Change Execution Options
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The Entrypoint for all Docker Images within this Repo are the actual Applications, which are run at container execution time.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This makes it possible to set command line Arguments for the Apps as Docker Command.  
							 
						 
					
						
							
								
									
										
										
										
											2022-03-09 22:36:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Within docker-compose.yaml commands are already set, you may override them within `docker-compose.override.yaml`  to fit your needs. 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Example from service Klipper:
							 
						 
					
						
							
								
									
										
										
										
											2022-02-15 19:50:13 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  command:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  "-I"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  "run/klipper.tty"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  "-a"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  "run/klipper.sock"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  "cfg/printer.cfg"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Multiple Webcams
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The Ustreamer Service is already templated to be easily reused for multi-webcam Setups.  
							 
						 
					
						
							
								
									
										
										
										
											2022-03-09 22:36:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								To add a new Ustreamer Service, simply add the following snippet to ``docker-compose.override.yaml` `.  
							 
						 
					
						
							
								
									
										
										
										
											2022-04-18 21:05:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Notice, that all service names, container names and traefik labels need to be unique while the right side of the passed Device (`:/dev/webcam` ) always stays the same.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Hence replace webcam2 with webcam3 and so on for every webcam you add and update the physical device that gets passed to the container.
							 
						 
					
						
							
								
									
										
										
										
											2022-02-15 19:50:13 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  webcam2:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < < :  * ustreamer-svc 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    devices:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  /dev/video1:/dev/webcam
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    labels:
							 
						 
					
						
							
								
									
										
										
										
											2022-12-18 13:58:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      org.prind.service: webcam2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      traefik.enable: true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      traefik.http.services.webcam2.loadbalancer.server.port: 8080
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      traefik.http.routers.webcam2.rule: PathPrefix(`/webcam2` )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      traefik.http.routers.webcam2.entrypoints: web
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      traefik.http.middlewares.webcam2.stripprefix.prefixes: /webcam2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      traefik.http.routers.webcam2.middlewares: webcam2
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Building Docker images locally
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you'd like to customize the provided Docker Images, you may edit the Dockerfiles within the ``docker/<service>` ` Directory.  
							 
						 
					
						
							
								
									
										
										
										
											2022-03-09 22:36:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Images are build in multiple stages, the final stage is called ``run``. Based on this, you can update Service definitions within ``docker-compose.override.yaml` ` to build Images locally.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Example: Build Moonraker  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Update the ``image:`` name and add a ``build` ` config:
							 
						 
					
						
							
								
									
										
										
										
											2022-02-15 19:50:13 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2021-10-25 21:47:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  moonraker:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    image: moonraker:latest
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    build:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      context: docker/moonraker
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      target: run
							 
						 
					
						
							
								
									
										
										
										
											2021-10-17 01:13:41 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-15 19:50:13 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Enable Mainsail remoteMode
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In case Moonraker is not situated on the same Host as Mainsail, you'll have to enable remoteMode in Mainsail to set up a remote Printer. This mirrors the behaviour of https://my.mainsail.xyz.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.  Create `config/mainsail.json`  with the following Contents 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```json
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    "remoteMode":true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  Add the newly created File as a Volume to the mainsail Service 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  mainsail:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    volumes:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  ./config/mainsail.json:/usr/share/nginx/html/config.json
							 
						 
					
						
							
								
									
										
										
										
											2022-02-15 23:13:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2022-03-09 22:36:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Debugging the Stack
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Debugging the Stack without printer hardware is challenging, as klipper requires a mcu to operate.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For this purpose, you can build a service that emulates a mcu with simulavr, as suggested by the [Klipper Docs ](https://github.com/Klipper3d/klipper/blob/master/docs/Debugging.md ).  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The simulavr Image is part of the Dockerfile for Klipper but is not pushed to any registry, so it needs to be built when needed.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-08 23:54:04 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Locate the `docker-compose.extra.simulavr.yaml`  in the repository and set the `VERSION`  Build-Arg to any Git Reference from [Klipper3d/klipper ](https://github.com/Klipper3d ) that you would like the mcu code to be compatible with. 
							 
						 
					
						
							
								
									
										
										
										
											2022-03-09 22:36:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-08 00:29:49 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								This example builds the mcu code from [Klipper3d/klipper:d75154d ](https://github.com/Klipper3d/klipper/commit/d75154d695efb1338cbfff061d226c4f384d127b )
							 
						 
					
						
							
								
									
										
										
										
											2022-03-09 22:36:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    build:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      context: docker/klipper
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      target: build-simulavr
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      args: 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        VERSION: d75154d695efb1338cbfff061d226c4f384d127b
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Then start the Stack
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								docker compose \
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  --profile mainsail \
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -f docker-compose.yaml \
							 
						 
					
						
							
								
									
										
										
										
											2022-07-08 23:54:04 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  -f docker-compose.extra.simulavr.yaml \
							 
						 
					
						
							
								
									
										
										
										
											2022-03-09 22:36:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  up -d
							 
						 
					
						
							
								
									
										
										
										
											2022-04-18 22:12:59 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```