• Recent
  • Tags
  • Unsolved
  • Solved
  • MagicMirror² Repository
  • Documentation
  • 3rd-Party-Modules
  • Donate
  • Discord
  • Register
  • Login
MagicMirror Forum
  • Recent
  • Tags
  • Unsolved
  • Solved
  • MagicMirror² Repository
  • Documentation
  • 3rd-Party-Modules
  • Donate
  • Discord
  • Register
  • Login
A New Chapter for MagicMirror: The Community Takes the Lead
Read the statement by Michael Teeuw here.

MM docker container problem with mac and linux

Scheduled Pinned Locked Moved Troubleshooting
14 Posts 3 Posters 6.5k Views 3 Watching
Loading More Posts
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • R Offline
    raywo Module Developer @tomasz2101
    last edited by raywo Feb 25, 2018, 12:17 AM Feb 25, 2018, 12:14 AM

    @tomasz2101 Try to set ipWhitelist to [ "127.0.0.1", "::ffff:127.0.0.1", "::1" ]. If you want to access the mirror from your Linux or Mac machine add their respective IPs too.

    1 Reply Last reply Reply Quote 0
    • T Offline
      tomasz2101
      last edited by Feb 25, 2018, 11:46 AM

      @raywo I know that this is strange behaviour of MM and your fix is not according to documentation. I tried that but that fix doesn’t work at all. Additional think is that I’am running container on my mac and i cannot access MM from mac. 192.168.1.176 is my mac local ip. I want to develop new module but i don’t want to do this on rpi.

      var config = {
      	address: "localhost",
      	port: 8080,
      	ipWhitelist: [ "127.0.0.1", "::ffff:127.0.0.1", "::1", "192.168.1.176"],
      	language: "en",
      	timeFormat: 24,
      	units: "metric",
      
      	modules: [
      		{
      			module: "alert",
      		},
      		{
      			module: "updatenotification",
      			position: "top_bar"
      		},
      		{
      			module: "clock",
      			position: "top_left"
      		},
      	]
      
      };
      
      /*************** DO NOT EDIT THE LINE BELOW ***************/
      if (typeof module !== "undefined") {module.exports = config;}
      
      R 1 Reply Last reply Feb 25, 2018, 12:28 PM Reply Quote 0
      • R Offline
        raywo Module Developer @tomasz2101
        last edited by Feb 25, 2018, 12:28 PM

        @tomasz2101 Why is that not according to documentation?
        I have a simliar setup like you. I run docker on my mac and access the mirror instance via my mac it works just fine.

        Maybe you should try it without creating your own docker image. Try the solution as described in the MagicMirror documentation.

        1 Reply Last reply Reply Quote 0
        • T Offline
          tomasz2101
          last edited by Feb 25, 2018, 1:23 PM

          @raywo i tried

          docker run  -d \
                                  --publish 8080:8080 \
                                  --restart always \
                                  --volume ~/magic_mirror/config:/opt/magic_mirror/config \
                                  --volume ~/magic_mirror/modules:/opt/magic_mirror/modules \
                                  --name magic_mirror \
                                  bastilimbach/docker-magicmirror
          

          docker ps

          CONTAINER ID        IMAGE                             COMMAND                  CREATED                  STATUS              PORTS                    NAMES
          69efe710da85        bastilimbach/docker-magicmirror   "/opt/magic_mirror/d…"   Less than a second ago   Up 2 seconds        0.0.0.0:8080->8080/tcp   magic_mirror
          

          docker logs -f magic_mirror

          Starting MagicMirror: v2.1.3
          Loading config ...
          WARNING! Could not find config file. Please create one. Starting with default configuration.
          Loading module helpers ...
          Initializing new module helper ...
          Module helper loaded: updatenotification
          No helper found for module: helloworld.
          All module helpers loaded.
          Starting server on port 8080 ...
          Server started ...
          Connecting socket for: updatenotification
          Sockets connected & modules started ...
          
          Ready to go! Please point your browser to: http://localhost:8080
          

          cat config.js

          var config = {
          	address: "localhost", // Address to listen on, can be:
          	port: 8080,
          	ipWhitelist: ["127.0.0.1", "::ffff:127.0.0.1", "::1", "192.168.1.176"],
          	language: "en",
          	timeFormat: 24,
          	units: "metric",
          
          	modules: [
          		{
          			module: "clock",
          			position: "top_left"
          		},
          	]
          
          };
          

          When im trying to access url http://localhost:8080/ in incognito i got always “localhost didn’t send any data” and there is no information in container about trying to access pare.

          R 1 Reply Last reply Feb 25, 2018, 1:29 PM Reply Quote 0
          • R Offline
            raywo Module Developer @tomasz2101
            last edited by Feb 25, 2018, 1:29 PM

            @tomasz2101 This looks okay to me. Although the log states "WARNING! Could not find config file. Please create one. Starting with default configuration.".
            Where did you put your config.js file? Is it in ~/magic_mirror/config on your mac?

            T 1 Reply Last reply Feb 25, 2018, 1:36 PM Reply Quote 0
            • T Offline
              tomasz2101 @raywo
              last edited by Feb 25, 2018, 1:36 PM

              @raywo The config.js.sample was created automatically. After that i copy it to config.js and restarted container but logs show:

              Ready to go! Please point your browser to: http://localhost:8080
              Starting MagicMirror: v2.1.3
              Loading config ...
              Loading module helpers ...
              No helper found for module: clock.
              All module helpers loaded.
              Starting server on port 8080 ...
              Server started ...
              Sockets connected & modules started ...
              
              Ready to go! Please point your browser to: http://localhost:8080
              

              0_1519565803412_Screen Shot 2018-02-25 at 14.31.44.png

              R 1 Reply Last reply Feb 25, 2018, 1:38 PM Reply Quote 0
              • R Offline
                raywo Module Developer @tomasz2101
                last edited by Feb 25, 2018, 1:38 PM

                @tomasz2101 And? Does it work?

                T 1 Reply Last reply Feb 25, 2018, 1:48 PM Reply Quote 0
                • T Offline
                  tomasz2101 @raywo
                  last edited by Feb 25, 2018, 1:48 PM

                  @raywo no

                  R 1 Reply Last reply Feb 25, 2018, 1:56 PM Reply Quote 0
                  • R Offline
                    raywo Module Developer @tomasz2101
                    last edited by raywo Feb 25, 2018, 2:00 PM Feb 25, 2018, 1:56 PM

                    @tomasz2101 In my config.js I put "" in the address setting. I also have "::ffff:192.168.2.1/120" included in my ipWhitelist. My home network is 192.168.2.0.

                    my config.js

                    var config = {
                    	address: "", // - "", "0.0.0.0", "::" to listen on any interface
                    	             // Default, when address config is left out, is "localhost"
                    	port: 8080,
                    	ipWhitelist: ["127.0.0.1", "::ffff:127.0.0.1", "::1", "::ffff:192.168.2.1/120", "192.168.2.110", "172.17.0.1"]
                    
                      /* module config */
                    }
                    
                    T 1 Reply Last reply Feb 25, 2018, 2:42 PM Reply Quote 0
                    • T Offline
                      tomasz2101 @raywo
                      last edited by Feb 25, 2018, 2:42 PM

                      @raywo thx a lot now it is working.
                      Also i had to do docker binding to localhost
                      my config:

                      var config = {
                      	address: "",
                      	port: 8080,
                      	ipWhitelist: [],
                      	language: "en",
                      	timeFormat: 24,
                      	units: "metric",
                      
                      	modules: [
                      		{
                      			module: "clock",
                      			position: "top_left"
                      		}
                      	]
                      
                      };
                      
                      1 Reply Last reply Reply Quote 1
                      • 1
                      • 2
                      • 1 / 2
                      1 / 2
                      • First post
                        6/14
                        Last post
                      Enjoying MagicMirror? Please consider a donation!
                      MagicMirror created by Michael Teeuw.
                      Forum managed by Sam, technical setup by Karsten.
                      This forum is using NodeBB as its core | Contributors
                      Contact | Privacy Policy