-
Notifications
You must be signed in to change notification settings - Fork 417
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Docker for Windows #168
Comments
There are installers available for Windows (https://www.rabbitmq.com/install-windows.html), so I'm not opposed, but configuration is going to be tricky. On Linux, we use an entrypoint script which sets up the configuration and then execs For images like MongoDB, we've "solved" that by making the Windows images strictly bring-your-own for configuration, initialization, etc. If an approach like that is acceptable here, then we should definitely play around with making this happen! (and possibly whether it can work in Nano Server too) |
I think having RabbitMQ running in docker on window server core and/or nanoserver would be a great for the inner developer loop; at present I've not been able to see how/if this could be installed given the packaged installer, this may have to be a manual install process of RabbitMQ as opposed to the provide package installers? IMHO bring you own configuration for would be an acceptable starting point. |
FYI, found this spring2/rabbitmq |
it'd still be good if there was a rabbitmq that is under the official channel. |
@tianon IMO "bring your own configuration" is a valid approach for any OS. There are binary releases for Windows distributed by our team as well, I'm not qualified to say which one is more suitable for the current state of provisioning and automation tooling on Windows. |
I created a docker nanoserver-insider image, it's very basic and need work to really be production ready. Not to mention it needs nanoserver-insider right now because erlang does not work on the current version of nanoserver. The same dockerfile would work as well for windowsservercore. |
Also if the architectural limitations you speak of are not having bash then you could use windows server core insider and still run your bash script for windows because it can support bash now :) https://msdn.microsoft.com/en-us/commandline/wsl/install-on-server |
Are there any plans of having rabbitMQ for windows? We were getting the below error: |
@KencyK my comment from above still applies... #168 (comment) We're not opposed to the idea, since it does seem to be something upstream actively supports, but the nature of native Windows containers makes the usage of such a creation less intuitive. |
Here is a working Dockerfile that can be a good start. At the moment Nano Server images have to deal with Erlang issue 477. I really prefer not to create an unofficial image: can I contribute/help in some way? |
Rmq Windows based on multi stage builds to startt from windowsservercore to get powershell feature and then switch to nanoservercore:1709 Need to update to 1803. https://blog.drylm.org/posts/rabbitmq_windows_container.html @luigiberrettini the issue you mention is not valid anymore since 1709. |
The solution you published on your blog and referenced both on the Erlang issue and here is sort of a hack otherwise you could have used a single stage build based on microsoft/nanoserver:1709 (I tried it and it did not work) That's the reason why the Erlang issue is still open Anyway it is a better approach than using Windows Server core because it reduces image size |
Not so sure. I only use multi stage builds to have powershell to download and run msiexec stuff. |
If you look at the Dockerfile I referenced above and try to do the same with 1709 and PowerShell Core as I did it won't work |
The referenced issue is not related to run erlang installer. The attached docker file already use a multi stage build.
Indeed the installer does not run as-is in the nanoserver:1709 container |
Before installing Erlang, it could be helpful to install Microsoft Visual C++ Redistributable for Visual Studio 2017 with Unfortunately MSI is not supported on Nano Server |
@luigiberrettini MSI isn't supported for good reasons; as the packages have calls to APIs that are part of the UI layer and given the large majority of security issues related to the UI layers, the aim for nano server was be as secure and small as possible, some but not all MSIs follow the /quiet /passive rules and still try to access UI api; thank fully vc_redist isn't one of them ;) and good spot btw as I've been battling with an issue where VC libraries where missing and was getting odd messages (unrelated) but your tip made the penny drop :D |
Multistage builds are not supported for Official Images: docker-library/official-images#3383. |
Indeed. w/o multi stage, nanoserver:{1709,1803} cannot be really supported, no Powershell. |
I do not understand why there is this focus on PowerShell:
|
Yes indeed. That's not totally correct. the nanoservercore container instance has no tools other than batch-tools (cd, file, type, xcopy, ...) support. So basically, with batch-tools only, you dont have such a tools like:
That's why maybe I mentionned too much PowerShell. |
You are right, now I remember that I used the PowerShell Core image: This is perfectly doable without having a multistage build, but the Erlang installation problem still exist |
yes indeed. i did not had a look at the powershell core image yet. |
Being a "Linux program" probably the installer does not do more than unpacking and setting something in the path... even if it sets registry keys, this could be done via shell |
Indeed. I am pretty sure this is definitely overkill to have such an installer. |
Here is it It seems that it is strongly tied to having a UI experience, but luckily this mostly means writing a lot of values in the registry (install folder, shell extension and so on) |
yeah and indeed useless stuff. |
Opened ERL-635 please vote it |
The following link to a Dockerfile can build an image running rabbitmq on nanoserver It in itself depends on the following image which is using multistage build to install erlang on windows servercore but then copy resulting files into an nanoserver image https://github.com/sixeyed/dockerfiles-windows/blob/master/erlang/nanoserver/sac2016/Dockerfile |
I hope the Erlang team will start putting some effort also on Windows related issues instead of simply deprioritizing them and flagging as up-for-grabs or help wanted: it would be great to build and run RabbitMQ with a single stage build on microsoft/nanoserver I just discovered that 7-Zip can unpack NSIS files
|
As I have already commented there in the https://bugs.erlang.org/browse/ERL-477 |
This comment has been minimized.
This comment has been minimized.
I've done a little bit of testing with this, and was able to get something preliminary running with the following
FROM mcr.microsoft.com/windows/servercore:1803
# $ProgressPreference: https://github.com/PowerShell/PowerShell/issues/2138#issuecomment-251261324
SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"]
ENV RABBITMQ_HOME C:\RabbitMQ
# PATH isn't actually set in the Docker image, so we have to set it from within the container
RUN $newPath = ('C:\erl\bin;{0}\sbin;{1}' -f $env:RABBITMQ_HOME, $env:PATH); \
Write-Host ('Updating PATH: {0}' -f $newPath); \
setx /M PATH $newPath
# doing this first to share cache across versions more aggressively
# no minor updates for Windows -- infeasible to rebuild from source
ENV OTP_VERSION 21.2
# pulling from erlang-solutions.com instead of erlang.org because it's a lot faster download and includes https
RUN $url = 'https://packages.erlang-solutions.com/erlang/esl-erlang/FLAVOUR_1_general/esl-erlang_{0}~windows_amd64.exe' -f $env:OTP_VERSION; \
Write-Host ('Downloading {0} ...' -f $url); \
Invoke-WebRequest -Uri $url -OutFile otp-setup.exe; \
\
Write-Host 'Installing ...'; \
Start-Process otp-setup.exe -Wait \
-ArgumentList @( \
# https://nsis.sourceforge.io/Which_command_line_parameters_can_be_used_to_configure_installers
'/S', \
'/D=C:\erl' \
); \
\
Write-Host 'Removing ...'; \
Remove-Item otp-setup.exe -Force; \
\
Write-Host 'Validating ...'; \
Start-Process erl -NoNewWindow -Wait \
-ArgumentList @( \
'-version' \
); \
\
Write-Host 'Complete.'
ENV RABBITMQ_VERSION 3.7.10
# https://www.rabbitmq.com/install-windows-manual.html
RUN $url = 'https://github.com/rabbitmq/rabbitmq-server/releases/download/v{0}/rabbitmq-server-windows-{0}.zip' -f $env:RABBITMQ_VERSION; \
Write-Host ('Downloading {0} ...' -f $url); \
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; \
Invoke-WebRequest -Uri $url -OutFile rabbit.zip; \
\
Write-Host 'Expanding ...'; \
Expand-Archive -Path rabbit.zip -DestinationPath C:\; \
\
Write-Host 'Renaming ...'; \
Move-Item -LiteralPath ('rabbitmq_server-{0}' -f $env:RABBITMQ_VERSION) -Destination $env:RABBITMQ_HOME; \
\
Write-Host 'Removing ...'; \
Remove-Item rabbit.zip -Force; \
\
# TODO verification
\
Write-Host 'Complete.'
# send all logs to TTY
ENV RABBITMQ_LOGS=- RABBITMQ_SASL_LOGS=-
# TODO RABBITMQ_DATA_DIR
# TODO CMD ["rabbitmq-server"]
CMD ["powershell"] |
Based on tianon's work above (which is great, btw, thank you so much) was able to get rabbit running with CMD directive like this: CMD "cmd /k rabbitmq-server.bat" |
Wow - here I am a noob to Docker ... setting up some microservices - several dotnet 5 APIs, IdentityServer, a few mongodb... all on Windows containers. Then I spend 2 days trying to get rabbitmq to work in docker. Little did I realize that isn't supported! Didn't even know it wasn't until I stumble across this. Should I process or just try to get it all running on Linux/WSL instead? |
@johnkwaters If you are able, running on Linux-based containers is going to make your life a heck of a lot easier IMHO |
I hear you @ericjmooney ! I just switched - trying to iron out all the kinks, but seems way faster. |
This comment has been minimized.
This comment has been minimized.
Coming back to this, I wonder how many of the limitations I noted in #168 (comment) are things we can actually reasonably overcome vs insurmountable. 🙈 To put that another way: I realize lots of folks want a Windows-based RabbitMQ container image, but I'm not sure it really makes sense as part of what's maintained in this repository given that it will not be a comfortable or more importantly a well-supported experience. 🤔 😞 For example, not having a clean way to |
At some point I plan on migrating all of the scripts we use to manage RabbitMQ on Windows to Powershell, which will fix the But, I fail to see the benefit to a Windows-based RabbitMQ docker image. What would that provide to someone developing on Windows that the Linux-based one does not? |
The ability to run it in combination with other Windows-only containers without messing about with multiple Docker (or other runtime) instances or exploiting oddities in Docker Desktop for Windows's implementation. Outside development, running Linux-based containers on Windows Server in production is a non-supported setup, so you'd need to fire up a Linux VM to host the RabbitMQ container on a Linux container runtime. And all of the above workarounds are non-starters if you're trying to include a RabbitMQ instance in the same k8s Pod (or similar shared sandbox setup) as some Windows-only container, as such shared container sandboxes share the same platform/kernel. |
Thanks @TBBle, that is very informative. |
Please consider creating an official docker RabbitMQ for Windows image using Windows Server Core;
As a group of developers we use docker to create a local development environment; sharing images with others so the 'works on my machine' is a thing of the past; at present we use a number of images including including asp.net, redis, ms-sql-server, documentdb etc
The text was updated successfully, but these errors were encountered: