Much of my frustration and wasted time at the moment can be attributed to setting up Docker. It’s probably worth noting that probably not all of it can be attributed to the Docker and M1 chip. But some of it certainly is.
Like with many of my issues I tend to blame myself and my own knowledge, but sometimes it’s not all my fault !! and if you have a M1 chip Mac it’d probably be worth looking into the potential pit falls first be commencing or purchasing one. As well as docker there has also been problems with Homebrew and Visual Studio Code. Of which VSC seems to be resolved now.
The first thing to note is that Docker have released an Apple Silicon Chip version, downloading this is the first thing that will save some time. Docker Desktop for Apple silicon And make sure you have the latest version.
Even with that there are also some on going ‘Known Issues’
Not all images are available for ARM64 architecture. You can add
--platform linux/amd64
to run an Intel image under emulation. In particular, the mysql image is not available for ARM64. You can work around this issue by using a mariadb image.However, attempts to run Intel-based containers on Apple Silicon machines under emulation can crash as qemu sometimes fails to run the container. In addition, filesystem change notification APIs (
inotify
) do not work under qemu emulation. Even when the containers do run correctly under emulation, they will be slower and use more memory than the native equivalent.In summary, running Intel-based containers on Arm-based machines should be regarded as “best effort” only. We recommend running arm64 containers on Apple Silicon machines whenever possible, and encouraging container authors to produce arm64, or multi-arch, versions of their containers. We expect this issue to become less common over time, as more and more images are rebuilt supporting multiple architectures.
Pulling db (mysql:5.7)...
5.7: Pulling from library/mysql
ERROR: no matching manifest for linux/arm64/v8 in the manifest list entries
Meaning that in my Docker-compose file I had to add the following for the DB
1 db:
2 platform: linux/x86_64
3 image: mysql:5.7
At which point I can get to the database through Sequel Ace, however there’s no database ( this used to be maintained but now I seem to have to import when ever the site is fully torn down )
At this point I have my first site working at http://site1:8000/ and we can also use the Postman collection that comes with it. I say first site because for this project I need to get 2 sites working ( 2 independent github projects with their own docker-compose.yml files ). That second site will be using the endpoints that I just mentioned in the Postman collection.
Again I received an error on the ‘mysql’ image.
failed to solve with frontend dockerfile.v0: failed to create LLB definition: no match for platform in manifest sha256:5064###: not found
ERROR: Service 'mysql' failed to build : Build failed
davidmillward@Davids-MacBook-Air siaf %
So again we need to add this code to the DB image. In fact this time it’s ‘mysql’
1 mysql:
2 platform: linux/x86_64
And once again we’ll need to connect to the Mysql, and again it’s empty and we need to import the Database.
takes a bit of time this one . On this occasion so long it took me into the evening. Meaning that for the next step I would be restarting the Docker Daemon.
TIME SO FAR TAKEN 2h 30m
On the restart first thing the next day I’ve click play on all the images. However the site on http://site1:8000/ is no longer working, so I’ll need to investigate that.
The database is working though, so let’s shut down the other containers and see if that works.
That didn’t work, so lets ‘docker-compose down’ on all the containers and just concentrate on getting Site1 running again.
So I ‘docker-compose down’ , purged it in the debugging section of Docker UI and run the ‘docker-compose up -d’ . The database need doing again ( not too long this one. ) And now the first site works again , yay!
Only trouble is I’ll need to the DB on the second site again ( because of the purge ), but at least it’s first thing in the morning, so I won’t have to restart my laptop.
… see you in a bit ….!
TIME SO FAR TAKEN 4h 30m
So now we get to my issue which is that I can’t get the 2 sites to talk to each other internally.
This is the URL I used previously which worked fine.
http://host.docker.internal:8000/
If you want to find out why this method is needed and used then this blog explains this How to connect to the Docker host from inside a Docker container?
What do we know about this issue
It is mentioned on this page Docker Desktop for Apple silicon
Fixes since the Apple Silicon preview 7
The
host.docker.internal
andvm.docker.internal
DNS entries now resolve.
The issue is mentioned here with no resolution Tunnel access is not working in docker container M1
Not supported according to this post https://betterprogramming.pub/macbook-m1-breaks-docker-development-14566ab6fa2e
Other things that you may ask me.
What comes back in the response ? It comes back empty but with no error.
Can you ping the FafeApi Container from the Drupal one ? Yes
Here’s the process to check that.
1exec into the drupal container and do a ping host.docker.internal
Although I needed to
1apt-get update
2apt-get install iputils-ping
This shows that I can ping the site ok. So this issue remains unresolved. If anyone knows how to fix it then I'd really like to know. Much appreciated. :)
No comments:
Post a Comment