devops:vagrant
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
devops:vagrant [2022/01/19 17:39] – skipidar | devops:vagrant [2024/06/22 16:41] (current) – [Error: Authentication failure. Retrying...] skipidar | ||
---|---|---|---|
Line 2: | Line 2: | ||
By Hashicorp. | By Hashicorp. | ||
- | == WOrkflow | + | == Workflow |
{{http:// | {{http:// | ||
Line 280: | Line 280: | ||
which redirects, via the ssh-tunnel to remote server i-012412412ASF2: | which redirects, via the ssh-tunnel to remote server i-012412412ASF2: | ||
- | **localhost:4440** | + | **i-012412412ASF2:4440** |
Line 287: | Line 287: | ||
see https:// | see https:// | ||
- | Opens a tunnel from | + | |
+ | |||
+ | ===== Setting up Rsync folder-synch on Windows ===== | ||
+ | |||
+ | === Why === | ||
+ | When **developing code** in an **IDE on Windows-Host** \\ | ||
+ | I would like to have the possibility | ||
+ | of running code in the Guest-VM. In an environment as close to the deployment as possible: \\ | ||
+ | e.g. on Kubernetes, integrated with other containers. | ||
+ | |||
+ | **File-system watcher: | ||
+ | |||
+ | Requirement: | ||
+ | |||
+ | On the Guest - the changes of " | ||
+ | and the code-project rebuilt. \\ | ||
+ | |||
+ | Also changes in the **IDE on Windows-Host** \\ | ||
+ | must trigger changes on the file-system in " | ||
+ | |||
+ | Problem: | ||
+ | |||
+ | When sharing | ||
+ | and files where changed on **IDE on Windows-Host** \\ | ||
+ | unfortunately, | ||
+ | |||
+ | When sharing a code-project via **Rsync** | ||
+ | |||
+ | |||
+ | === How === | ||
+ | An example of setting up the environment | ||
+ | |||
+ | * On Guest. Install Cygwin, to get Rsync on Windows | ||
+ | * On Guest. Add the " | ||
+ | * | ||
+ | * On Guest. Run automatic sync command in one cmd-shell | ||
+ | * Ssh into Vagrant. Run continuos build in one shell | ||
+ | * | ||
+ | * Ssh into Vagrant. Run application like Spring Boot application | ||
+ | |||
+ | |||
+ | == On Guest. Install Cygwin, to get Rsync on Windows == | ||
+ | |||
+ | < | ||
+ | winget install -e --id Cygwin.Cygwin | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==On Guest. Add the " | ||
+ | |||
+ | < | ||
+ | cd " | ||
+ | mkdir " | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==Configure Vagrantfile to sync " | ||
+ | Sync folder `spring-boot-code-project-folder`. | ||
+ | Based on `checksum`, not timestamp. | ||
+ | |||
+ | Vagrantfile | ||
+ | <sxh ruby> | ||
+ | ... | ||
+ | config.vm.synced_folder " | ||
+ | type: " | ||
+ | rsync__auto: | ||
+ | rsync__args: | ||
+ | id: " | ||
+ | |||
+ | .. | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==On Guest. Run automatic sync command in one cmd-shell== | ||
+ | |||
+ | Open a new [[https:// | ||
+ | <sxh shell> | ||
+ | vagrant rsync-auto | ||
+ | </ | ||
+ | |||
+ | {{https:// | ||
+ | |||
+ | |||
+ | ==Ssh into Vagrant. Run continuos build in one shell== | ||
+ | |||
+ | See https:// | ||
+ | |||
+ | Skip the tests.\\ | ||
+ | Dont use the daemon. | ||
+ | |||
+ | <sxh shell> | ||
+ | vagrant ssh | ||
+ | cd "/ | ||
+ | ./gradlew build -xtest --no-daemon --continuous | ||
+ | </ | ||
+ | |||
+ | |||
+ | == Configure the Spring Boot application to hot-deploy changes == | ||
+ | |||
+ | The Spring boot applications needs to be advised, \\ | ||
+ | to take up any rebuilt app and hot-deploy it. | ||
+ | |||
+ | Add dependency to " | ||
+ | |||
+ | build.gradle | ||
+ | < | ||
+ | dependencies { | ||
+ | |||
+ | // makes Spring boot hot swap rebuilt jar to tomcat | ||
+ | developmentOnly ' | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==Ssh into Vagrant. Run application like Spring Boot application== | ||
+ | |||
+ | |||
+ | <sxh shell> | ||
+ | vagrant ssh | ||
+ | cd "/ | ||
+ | ./gradlew bootRun --args=' | ||
+ | </ | ||
+ | |||
+ | {{https:// | ||
+ | |||
+ | |||
+ | ===== Error: Authentication failure. Retrying... ===== | ||
+ | |||
+ | Thats also the reason for disk /mnt/d not being mounted correctly | ||
+ | |||
+ | <sxh shell> | ||
+ | |||
+ | # give the home permissions back to vagrant | ||
+ | # without that - / | ||
+ | # and also / | ||
+ | # so that no ssh connection works and | ||
+ | # vagrant ssh - failes with " | ||
+ | sudo chown -R vagrant: | ||
+ | </ |
devops/vagrant.1642613954.txt.gz · Last modified: by skipidar