Skip to content
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

Raspberry Pi Docker dev #5

Open
glynhudson opened this issue Aug 11, 2016 · 41 comments
Open

Raspberry Pi Docker dev #5

glynhudson opened this issue Aug 11, 2016 · 41 comments
Assignees

Comments

@glynhudson
Copy link
Member

glynhudson commented Aug 11, 2016

Run Emoncms docker on a Raspberry Pi

- Requirement to run root file-system in read-only for long term SD card life span as mentioned on Hypriot docker issues hypriot/image-builder-rpi#119 (comment)

Two options:

1. Start with Hypriot RasPi SD card

Either build up Emoncms in a single image using resin/rpi-raspbian/ as base

Or use docker-compose multi container setup with resin/rpi-raspbian/ or nidorpi/rpi-php as the base

2. Start with Raspbian Jessie image

  • + Already have working setup with RO FS
  • /- Not optimised for Docker like the Hypriot pre-built SD card will be

Instructions to install Docker on Raspbian Jessie :

  • with RO root FS and RW partition in /home/pi/data
In the Debian Jessie main repository there is not yet an installation package for Docker , so we will download the package docker-hypriot_1.10.3-1_armhf.deb from hypriot.com. They provide binary packages for latest version on Docker.
We will install the package with the following command :
sudo dpkg –i docker-hypriot_1.10.3-1_armhf.deb
They provide binary packages for latest version on Docker. After installation we have checked Docker daemon functionality with the command:
 sudo docker info
with the output:
Containers: 0
 Running: 0
 Paused: 0
 Stopped: 0
Images: 0
Server Version: 1.10.3
Storage Driver: overlay
 Backing Filesystem: extfs
Execution Driver: native-0.2
Logging Driver: json-file
Plugins:
 Volume: local
 Network: bridge null host
Kernel Version: 4.1.21-v7+
Operating System: Raspbian GNU/Linux 8 (jessie)
OSType: linux
Architecture: armv7l
CPUs: 4
Total Memory: 925.8 MiB
Name: raspberrypi
ID: TMKH:55WA:6KVM:SDMD:PIBU:O2YZ:KAK6:IH73:P5XT:UVCJ:HZIW:FW5Y
Debug mode (server): true
 File Descriptors: 11
 Goroutines: 20
 System Time: 2016-04-10T22:23:40.196987813+03:00
 EventsListeners: 0
 Init SHA1: 0db326fc09273474242804e87e11e1d9930fb95b
 Init Path: /usr/lib/docker/dockerinit
 Docker Root Dir: /var/lib/docker
WARNING: No memory limit support
WARNING: No swap limit support
WARNING: No oom kill disable support
WARNING: No cpu cfs quota support
WARNING: No cpu cfs period support
We will fix the warnings by adding the text  “cgroup_enable=memory swapaccount=1” to the file /boot/cmdline.txt.
and the requirement for read-only filesystem is to move the docker root dir on the writable image:  /home/pi/data/docker 
with these operations:
sudo service docker stop
next backup the original location with:
tar -zcC /var/lib/docker > /home/pi/data/docker/varlibdocker-backup-$(date +%s).tar.gz
move the folder in the new location: /home/pi/data/docker
mkdir /home/pi/data/docker
change permissions with
sudo chmod -R a+w /home/pi/data/docker
sudo chown -R pi /home/pi/data/docker
sudo chgrp -R pi /home/pi/data/docker
sudo mv /var/lib/docker /home/pi/data/docker
next make a symlink:
sudo ln -s /home/pi/data/docker /var/lib/docker   
and restart the docker engine:
sudo systemctl start docker
We will get a basic image that contained Java Docker that was adapted for ARM7 architecture. We found this Docker image on Docker Hub and we downloaded it with the following command:
docker pull sdhibit/rpi-java for a Java image
and
docker pull hypryot/rpi-node for a NodeJs image
To allow acces from Docker container to the host port 3000 (Rest Api) add the following line to iptables:
-A INPUT -i docker0 -p tcp --dport 3000 -j ACCEPT
and reload the iptables settings with : 
 sudo netfilter-persistent reload 
docker0 is the Docker bridge interface with the address 172.17.0.1. We will use this ip address instead of localhost to access the host applications. 
@beaylott
Copy link
Contributor

beaylott commented Aug 12, 2016

The only modification I would suggest to this plan is using a raspbian based image (potentially with php5/apache already setup) for the emoncms container, just cause that rpi-alpine-scratch one is busybox so is going to involve more work. The hypriot project use resin/rpi-raspbian(:jessie?) for their base image where they are using raspbian so that might be a good place to start.

Im going to try and get your dockerfile for emoncms working on top of that (or a similar image). Ill fork this repo and put changes in there with the goal of achieving same setup on rpi3.

EDIT1: Also the rpi-mysql/rpi-redis images are using resin/rpi-raspbian as base image.

@glynhudson
Copy link
Member Author

Sounds good! I'll wait to hear how you get on before I get my hand in the
pie ;-)

  • sent from my mobile device

On 12 Aug 2016 17:27, "Ben Aylott" [email protected] wrote:

The only modification I would suggest to this plan is using a raspbian
based image (potentially with php5/apache already setup) for the emoncms
container, just cause that rpi-alpine-scratch one is busybox so is going to
involve more work. The hypriot project use resin/rpi-raspbian:wheezy for
their base image where they are using raspbian.

Im going to try and get your dockerfile for emoncms working on top of that
(or a similar image). Ill fork this repo and put changes in there with the
goal of achieving same setup on rpi3.


You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
#5 (comment),
or mute the thread
https://github.com/notifications/unsubscribe-auth/AAuUPDh6OQX4lR4a3TmelWzmjf4nv783ks5qfJ7tgaJpZM4JiPKO
.

@glynhudson
Copy link
Member Author

Super positive reply from @DieterReuter regarding running hypriot image with RO FS

hypriot/image-builder-rpi#119 (comment)

@beaylott
Copy link
Contributor

beaylott commented Aug 15, 2016

I now have working emoncms on the rpi3 on our Nobel Grid SMX SD image. It was almost drop in rpi replacements for the base images (with some version changes). My working configuration files can be found here:

https://github.com/beaylott/emoncms-docker/commit/9cdf2951cd30fc47afaeeaffeea6e844be67cbbc

There are some issues which now need to be addressed...

  • The hypriot/rpi-mysql will not work out the box with emoncms configuration as it needs to be tweaked to allow random root passwords. This change has already been applied to the x86 mysql official image. A separate image will need to be provided but can just use the hypriot one as base and then overide the entrypoint.sh with our own. But....
  • The hypriot/rpi-mysql and hypriot/rpi-redis images are based off wheezy. Maybe we should attempt to upgrade them by just changing base image and see if if works? Alternatively we leave it as it works and hypriot will get there eventually.
  • The base image for the emoncms container is nidorpi/rpi-php:5.6-apache. This is not a widely used image so it may be worthing rolling our own from the rpi base images (and borrowing any big change from there).
  • The next step is to produce modifications to the emonSD card image build (in a fork) to install/run docker. The SMX instructions I have used to get docker running on my rpi3 could be borrowed here given the similarities between the builds. I had to install docker-compose via pip.
  • For our (Carbon Coop/Nobel Grid) purposes a single container emoncms would be better. I could produce this by recreating the emonSD image in a docker container. This may be a useful exercise anyway.

@beaylott
Copy link
Contributor

beaylott commented Aug 15, 2016

The Dockerfile for the modified rpi-mysql is here:
https://github.com/beaylott/emoncms-docker/tree/master/rpi-mysql

I could also push my modified docker images to the public registry if that helps?

@DieterReuter
Copy link

DieterReuter commented Aug 15, 2016

We do have a new SD image with Docker v1.12.1-rc1 now which is only 252M in size. So I would be happy if you could start with this one, as we're currently fixing last bugs and hoping to get more feedback from your project too.

@beaylott
Copy link
Contributor

Ok that is certainly another possibility ... I would be quite interested in basing off of your image but both my project (an EU research project) and OEM already have SD card images which we are working off of which makes it more difficult. However, I think we are already using a lot of your work in the form of base images etc. so it may make sense to try and bring them a bit closer together ...

@beaylott
Copy link
Contributor

beaylott commented Aug 16, 2016

So ... maybe multiple lines of attack in order of priority (for me anyway):

  • Continuing development of emoncms-docker (as per todo list in To do #2). Particularly (for us at CC) MQTT support. And this reflected in rpi version.
  • Test rpi2.
  • Prepare/test additions to build instructions for emonSD for use with Docker using work from SMXcoreSD/HypriotOS. This will also help to see how development of these could be moved closer together.
  • Prepare a single container version of emoncms for installation as an 'App' on SMXcoreSD.
  • Upgrade the base images ive used to jessie and maybe higher versions of sql/node.
  • Merging any improvements from HypriotOS into emonSD/SMXcore as appropriate.

@glynhudson
Copy link
Member Author

glynhudson commented Aug 17, 2016

Nice work @beaylott , good progress. I have updated my fist post above to better present to options available.

I would like to get @DieterReuter input on what the pros / cons are of installing docker ontop of stock Jessie rather than using pre-built hypriot SD card. My feeling is that we would get better docker support and a more optimised system for docker if we used to hypriot SD card to start with.

However, whatever the outcome of the Jessie Vs Hypriot SD card image is this does not affect the building of an emoncms raspi docker container. Nice working getting emoncms up and running using nidorpi/rpi-php, its' nice how little changes is needed from the standard emoncms-docker setup. I will create a branch on this repo called raspi and give you RW access so you can push. Update: I've just merged your changes: #6

I think we are agreed that for the purpose of SMX integration a single Docker image will be best. For this we should build up emoncms in a single container based on raspi-alpine, agree?

@beaylott
Copy link
Contributor

I may be wrong (and @DieterReuter can help here) but I think by basing the images off of resin/rpi-raspbian:(wheezy/jessie) we get most of the work of Hypriot (at least on the container side rather than host OS). I guess the benefit of apline (busybox) is that it is lighter on resources compared to debian but it will probably require more work to get the stuff working compared to building something on jessie where we can use all the existing instructions without many changes?

@DieterReuter
Copy link

@glynhudson probably I should write some details about the similarities and the differences between Raspbian and HypriotOS first:

  • HypriotOS uses all the rootfs packages directly from Raspbian, but we just like to install the basic packages we'd need on a container runtime OS. Currently 2016-05-27-raspbian-jessie-lite has 419, HypriotOS 1.0.0-rc1 has 291 packages installed. As you guess, you can easily install additional Raspbian packages if you need them (on the RPi we'd like to be 100% compatible to Raspbian) !
  • we try do slim done the image size for img.zip for faster download and disk usage (I just discarded another 170M from the disk just yesterday, now we need <600M only)
  • HypriotOS has discarded the direct root access, no root user available for security reasons
  • HypriotOS has a Docker-optimised kernel, based upon the standard Raspbian Kernel but with some container related kernel settings.
  • all of our repos are 100% open-sourced, even the build scripts for Kernel and Image can be run locally on your dev machine or automatically in Travis CI/build server (maybe we'll switch to CircleCI because it's faster)
  • HypriotOS can be used on other boards as well, but then we support ARMv7 directly and using Debian packages

About 18 months ago there was just no real Docker support at all on ARM (only a few hacks exists and some outdated tutorials) and we've built everything from scratch. As we're working closer together with Docker we were able to convince them, to officially support ARMv6 and ARMv7 - so the future Docker Engine packages will be officially build and supported by Docker directly, this starts with Docker Engine v1.12.1 in a few days only. And honestly you can use them even on a standard Raspbian, but then you loose all the kernel optimisations we've done.

This were just a few details, I could talk for hours. But if you'd like to get more details please ask or we could setup a Skype call.

@DieterReuter
Copy link

@beaylott you're right. Using resin/rpi-raspbian:jessie is the best starting place if you're using some Pi related software and tools like accessing the Pi hardware etc. Alpine is extremely slim and is the best option if you'd like to get super-small Docker images and saving system resources, I would recommend this for network services and so on - but it takes more work to build. So if you want to go fast, start with resin/rpi-raspbian and optimise later for the important or larger images.

@glynhudson
Copy link
Member Author

HypriotOS has a Docker-optimised kernel, based upon the standard Raspbian Kernel but with some container related kernel settings.

I think this is the part of HypriotOS we could most be interested in. Does this mean docker containers will run 'better' (faster? stable?) on HypriotOS rather than installing Docker on Jessie?

Agree, using resin/rpi-raspbian will be better for us than alpine. Emoncms has been tested to work well on Debian. We currently use Jessie as our base image therefore docker setup with a single container resin/rpi-raspbian should not be too difficult. I have updated my initial post above to referance resin/rpi-raspiban rather than alpine

This were just a few details, I could talk for hours. But if you'd like to get more details please ask or we could setup a Skype call.

Good idea, however I am tied up for the next few days with other work then going away next week for a couple of weeks so I can't really get stuck into this right now. However would @beaylott be interested in a skype with @DieterReuter ?

@DieterReuter
Copy link

Just a side note: developing Docker images directly on a Pi could be somewhat slow, this is the reason we're doing almost all of our work on Scaleway cloud servers (C1 instance, 4x ARMv7 core, 2GByte memory, approx. 3Euro/month!) with super-fast internet access, which is great for build jobs.

@glynhudson
Copy link
Member Author

Great idea, a simulated raspi build environment sounds awesome 👍

@beaylott
Copy link
Contributor

I have made a lot of progress on some of the above... I updated all the base images to jessie and got MQTT working. Required some small modifications to emoncms setup. Unfortunately I forgot to push and dont have access to the machine as Im not in the office. On Monday ill sort it out. I think I will also do as Dieter suggested and get one of those build machines as doing it on an rpi3 is a PITA!

@glynhudson
Copy link
Member Author

Nice work! Have a good weekend :-)

@beaylott beaylott self-assigned this Aug 22, 2016
@beaylott
Copy link
Contributor

I pushed the jessie updates on monday. Couldnt quite get everything I wanted (cant bump MySQL version).

I have MQTT working on the container and talking to the host MQTT broker that we have ...just trying to get the emoncms MQTT daemon to play nice and then hopefully it will be done.

I have been slowed down by having to prepare for my thesis exam tomorrow and the raspberry pi grinding to a halt under the builds (Im currently migrating the builds to the Scaleway servers).

I put the MQTT stuff so far in a repo on my account (https://github.com/beaylott/emoncms-docker) and ill create a pull request when its done.

@glynhudson
Copy link
Member Author

Awesome!

What was the issue with bumping MYSQL version? Are you limited by the base
image version? What version would you like to use? What improvements does
the newer version have?

Good effort getting MQTT up and running. Emoncms uses mqtt_input script
https://github.com/emoncms/emoncms/blob/master/scripts/phpmqtt_input.php

Getting PHP MQTT working was a bit of a pain, there does not seem to be a
super well supported PHP MQTT library. We used
https://github.com/mgdm/Mosquitto-PHP. Setup guide here,
https://github.com/emoncms/emoncms/blob/master/docs/RaspberryPi/MQTT.md.
Keen to hear if you find any improvements. As I mentioned I would like to
use PHP composer to install dependencies.

Let me know how you get on. I'm abroad in Switzerland at the moment so
can't do much testing I'm afraid. Excited to get stuck in when I'm home.

On Wednesday, 24 August 2016, Ben Aylott [email protected] wrote:

I pushed the jessie updates on monday. Couldnt quite get everything I
wanted (cant bump MySQL version).

I have MQTT working on the container and talking to the host MQTT broker
that we have ...just trying to get the emoncms MQTT daemon to play nice and
then hopefully it will be done.

I have been slowed down by having to prepare for my thesis exam tomorrow
and the raspberry pi grinding to a halt under the builds (Im currently
migrating the builds to the Scaleway servers).

I put the MQTT stuff so far in a repo on my account (
https://github.com/beaylott/emoncms-docker) and ill create a pull request
when its done.


You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
#5 (comment),
or mute the thread
https://github.com/notifications/unsubscribe-auth/AAuUPO5gKEVz-5kC-oKCofxdq__gX4YNks5qjH1ogaJpZM4JiPKO
.

Glyn Hudson

http://megni.co.uk
http://adventuresplusnorthwales.blogspot.com

@beaylott
Copy link
Contributor

Well one issue is that there isnt a MySQL 5.7 package readily available for ARM. It looks like there used to be on Oracle's website judging by what is in some Dockerfile's I have seen, but not anymore. There are also differences in the configuration which I am not familiar with.

The PHP MQTT library is working, I wrote a test script which was producing output from the broker on the host. It is the running of the mqtt_input script as a service I am having trouble with but I think this is a Docker thing which I need to work out for myself. I may need to write a systemctl service file for it as well (which may be useful elsewhere in emoncms anyway).

@beaylott
Copy link
Contributor

Oh ...and just generally on the version stuff... im not that bothered about the version, I was mainly taking my cue from the emoncms requirements and your expressed desire to bump versions of things (but maybe you just meant php?). 5.5 works fine for me!

@glynhudson
Copy link
Member Author

Nice,a systemctl mqtt_input service would be great. I'm not fully up to
speed with the advantages over /etc/init.d but it seems to be the way
forward i.e everyone is using it a init.d replacement.

Thanks,

On Thursday, 25 August 2016, Ben Aylott [email protected] wrote:

Well one issue is that there isnt a MySQL 5.7 package readily available
for ARM. It looks like there used to be on Oracle's website judging by what
is in some Dockerfile's I have seen, but not anymore. There are also
differences in the configuration which I am not familiar with.

The PHP MQTT library is working, I wrote a test script which was producing
output from the broker on the host. It is the running of the mqtt_input
script as a service I am having trouble with but I think this is a Docker
thing which I need to work out for myself. I may need to write a systemctl
service file for it as well (which may be useful elsewhere in emoncms
anyway).


You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
#5 (comment),
or mute the thread
https://github.com/notifications/unsubscribe-auth/AAuUPN3zaARfBOBumcyHLmdZwtgdCOvrks5qjVZJgaJpZM4JiPKO
.

Glyn Hudson

http://megni.co.uk
http://adventuresplusnorthwales.blogspot.com

@beaylott
Copy link
Contributor

beaylott commented Sep 8, 2016

Sorry this has been slow, have been side tracked a lot in past few weeks. I am just replicating the environment on the Scaleway servers as I got fed up with the rpi3 grinding to a halt.

@beaylott
Copy link
Contributor

@glynhudson : Okey dokes I have got MQTT working in the container (or at least showing up in the logger with my smart meter readings). I have pushed this to my own branch and will create a pull request. There are several things you will want to review there.

I have a question now about how emoncms parses the output. I understand your format for MQTT as published by emonhub is something like

[base topic]/[node]/[key?] [value]

I have a topic I want to subscribe to with the following format:

G3M40000001/SMX/LD01/[OBIS Code 1]/[OBIS Code 2] [value]

Despite the fact I put G3M40000001/SMX/LD01 as the base topic it is showing the Node as 'SMX' and the Key as 'LD01' in the Input view.... my expectation is it would take [OBIS Code 1] as the Node and [OBIS Code 2] as the Key and then pull in all the values (it is about 48 values at a time). Any ideas what might be going on?

@beaylott
Copy link
Contributor

I guess I am asking what happens here https://github.com/emoncms/emoncms/blob/master/scripts/phpmqtt_input.php#L170-L216 ....

@beaylott
Copy link
Contributor

beaylott commented Sep 13, 2016

I dont really know PHP ....but by the looks of it if the top level topic is not equal to the base topic that you set then it will just return an empty array and hence only one input without a value (which is what I am getting)? So in other words the base topic cannot include any sub-topics as is...

EDIT: I have realised the above description is almost gibberish... to illustrate what I mean with an example ... I think you should be able to have a base topic which is made up of sub-topics ...sort of like a file path. At the moment if you specify the base topic as
head/sub1/sub2/sub3
and the inputs have the topic
head_/sub1_/sub2_/sub3_/sub4_/tail
then ecomcms will only check if
head/sub1/sub2/sub3 == head_
so that even if head=head_ , sub1=sub1_, sub2=sub2_ , sub3=sub3_ ...it will not pass and you will get an empty array. Whereas in this case I would expect it to match and pass sub4 as the Node and tail as the key (along with associated values)... is this desirable behaviour?

If so I would be happy to produce a patch.

@glynhudson
Copy link
Member Author

Hi Ben,

That's awesome! Nice work :+1

Emoncms currently uses the mqtt_input script to process MQTT input.
Correct, MQTT inputs are passed:

[base topic]/[node]/[key?] [value]

Where the base topic is set in setting.php (default emon). e.g. mqtt
input emon/emontx/power1 will result in an Emoncms input from
node=emontx and key=power1.

I'm not sure the 'basetopiccan be a sub topic e.g. we useemonas the default base topic. I have not tested using something likeemon/nobelas the basetopic. I see no reason why it it could not be made to work but since we have not designed or tested with this in mind there might well be an issue. In your case mqtt_input is only looking acceptingG3M40000001 as the base topic rather than the wholeG3M40000001/SMX/LD01/`

An easy hack could be just to re-publish the data as emon/[OBIS Code
1]/[OBIS Code 2] [value].

Or alternatively we could try and investigate what is stopping mqtt_input
from accepting multiple base-subtopics.

IMO mqtt_input script needs some work, very occationally it stops for no
reason we can detect. It could be the PHP mqtt library we are using or it
could be how the script is being ran (currently as /etc/init.d), a
community remember did port the script over the run as a systemd. I need to
look into this and try and add some better logging...

On Tuesday, 13 September 2016, Ben Aylott <[email protected]
javascript:_e(%7B%7D,'cvml','[email protected]');> wrote:

@glynhudson https://github.com/glynhudson : Okey dokes I have got MQTT
working in the container (or at least showing up in the logger with my
smart meter readings). I have pushed this to my own branch and will create
a pull request. There are several things you will want to review there.

I have a question now about how emoncms parses the output. I understand
your format for MQTT as published by emonhub is something like

[base topic]/[node]/[key?] [value]

I have a topic I want to subscribe to with the following format:

G3M40000001/SMX/LD01/[OBIS Code 1]/[OBIS Code 2] [value]

Despite the fact I put G3M40000001/SMX/LD01 as the base topic it is
showing the Node as 'SMX' and the Key as 'LD01' in the Input view.... my
expectation is it would take [OBIS Code 1] as the Node and [OBIS Code 2] as
the Key and then pull in all the values (it is about 48 values at a time).
Any ideas what might be going on?


You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
#5 (comment),
or mute the thread
https://github.com/notifications/unsubscribe-auth/AAuUPGYGR4270b-FJXbjQEBBNxkdfNMEks5qpsElgaJpZM4JiPKO
.

Glyn Hudson

http://megni.co.uk
http://adventuresplusnorthwales.blogspot.com

@beaylott
Copy link
Contributor

Hi yes I was digging around in all this. mqtt_input is the init script. I am not actually using this anymore as it isnt really right to use the init system or systemctl in the container to determine runtime behaviour (as I have discovered!). Instead I am calling the PHP script which does the MQTT for emoncms (phpmqtt_input.php) directly under supervisord running in PID1. This works pretty well. I havent seen any stops of phpmqtt_input.php under supervisord yet (at least after the database has been initialised).

If the behaviour I want is ok with you (i.e. it wont break something) then I will try and patch phpmqtt_input.php so it can deal with multiple base-topics.

The alternative is to re-publish as you suggest and I was looking into this, although this then requires some logic to be implemented somewhere. Ideally I dont want to make changes in our 'Trusted Zone' on the host (which is where the MQTT is posting from). The alternative is to run another daemon which re-publishes etc.

@glynhudson
Copy link
Member Author

Awesome. Yes running phpmqtt_input.php is fine. Sorry, I slowly learning
how things work differently in a container based system.

Yes, I'm happy for you to patch phpmqtt_input.php to allow base subtopics,
obviously as long as standard operation with a single base topic is not
effected. Happy to review and test a pull request. I'm still away from home
(in Germany!) therefore it might take me a day or two to review and test.

@TrystanLea wrote phpmqtt_input.php, please direct any specific questions
regarding the scrip to him.

  • sent from my mobile device

On 14 Sep 2016 16:34, "Ben Aylott" [email protected] wrote:

Hi yes I was digging around in all this. mqtt_input is the init script. I
am not actually using this anymore as it isnt really right to use the init
system or systemctl in the container to determine runtime behaviour (as I
have discovered!). Instead I am calling the PHP script which does the MQTT
for emoncms (phpmqtt_input.php) directly under supervisord running in PID1.
This works pretty well. I havent seen any stops of phpmqtt_input.php under
supervisord yet (at least after the database has been initialised).

If the behaviour I want is ok with you (i.e. it wont break something) then
I will try and patch phpmqtt_input.php so it can deal with multiple
base-topics.

The alternative is to re-publish as you suggest and I was looking into
this, although this then requires some logic to be implemented somewhere.
Ideally I dont want to make changes in our 'Trusted Zone' on the host
(which is where the MQTT is posting from). The alternative is to run
another daemon which re-publishes etc.


You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
#5 (comment),
or mute the thread
https://github.com/notifications/unsubscribe-auth/AAuUPAhceRD-0vMrPDb9JN0jhjepTRAcks5qqAXngaJpZM4JiPKO
.

@beaylott
Copy link
Contributor

Sure thing will do! Sorry about my stream of consciousness!

@beaylott
Copy link
Contributor

beaylott commented Oct 3, 2016

We have decided to post our data into emoncms using the API now using a custom script for various reasons so wont be going down the MQTT route now. This has the advantage of decoupling our needs from emoncms, although I have posted the patch for multiple base topics there in case it is considered useful.

Aside from the custom script, I am currently creating a single container application which merges the work on the composed application and should be more suitable for running on the pi. Ill post back here once it is done.

@glynhudson
Copy link
Member Author

Hi Ben, Sounds great. I've see your pr for the mqtt input script. I'll test
and review later tonight.

Thanks a lot.

  • sent from my mobile device

On 3 Oct 2016 15:48, "Ben Aylott" [email protected] wrote:

We have decided to post our data into emoncms using the API now using a
custom script for various reasons so wont be going down the MQTT route now.
This has the advantage of decoupling our needs from emoncms, although I
have posted the patch for multiple base topics there in case it is
considered useful.

Aside from the custom script, I am currently creating a single container
application which merges the work on the composed application and should be
more suitable for running on the pi. Ill post back here once it is done.


You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
#5 (comment),
or mute the thread
https://github.com/notifications/unsubscribe-auth/AAuUPIgNb2Dr0HLaI7dw_qYLm3lmLQMYks5qwRXUgaJpZM4JiPKO
.

@glynhudson
Copy link
Member Author

Hi Ben,

I've shown the work you have been doing on the raspi docker to my friend @spikeheap who helped me origionally setup emoncms-docker. His thoughts are:

The work on the raspberry pi docker image looks promising. A couple of things I’d consider early on to prevent fragmentation are:

  • extract the common lines from Dockerfile into a script, so you can have debian and raspian versions sharing the build steps.
  • remove the duplicate smx… env files and have a single environmental config wherever possible.

It would be great to merge this raspi into master after we make the suggested changes to managed the two platforms. It's an interesting challange managing cross-platform docker.

Will the 'single container application' be based on a fork of this repo or are you starting again from scratch? Does this mean that you don't be doing any more work on this branch? If we did choose to run docker on our pre-build raspi SD card images to run our enviroment it may well be better to use a single container application as your suggest for simplicity. Let me know how you get on.

@beaylott
Copy link
Contributor

Hey I basically just smushed all the Dockerfiles together and stuck all the services needed under supervisord! Ideally it wouldnt be a fork but it is sort of hard to chain Dockerfiles together in this way and there are differences between rpi and normal server versions reflected in these. Most of it is common though as you say so there must be a way to have a single build system. Its almost working as well just having some bash scripting issues which should be resolved soon!

That SMX env is just me iterating, i agree it shouldnt be there!

Sorry its coming along in fits and starts, lots of other things going on at work. Hopefully I can set some time aside for this later in the week

@beaylott
Copy link
Contributor

I mean you could even just have a makefile which generates either one Dockerfile or three depending on arch.

@beaylott
Copy link
Contributor

Ill try and push what I have got as it has changed quite a bit so at least the branch isnt stale .

@glynhudson
Copy link
Member Author

Hey Ben, sorry for resurrecting an old thread. I'm keen to kickstart RasPi docker Emoncms, emonhub etc implementation. What's the current status of docker raspi Emoncms? Have you got a working image I could use as a starting point? I'm keen to explore moving to using docker on our pre-built emonSD RasPi SD card images

@beaylott
Copy link
Contributor

yes me too.. i have actually produced (in last few months for nobel grid project) a docker image for both emonhub and emonpi-emoncms stack for alpine linux (which is now much more popular than when we first started looking at this).

@glynhudson
Copy link
Member Author

glynhudson commented Jul 24, 2018 via email

@glynhudson
Copy link
Member Author

Do you run Alpine OS on the Pi, I see alpine is now available for the Pi. Or are you still running raspbian on the Pi with docker running alpine inside docker? Do you have a link to your docker files?

@mbico72
Copy link

mbico72 commented Aug 25, 2021

I have a problem using docker and emoncms:
WARNING: The requested image's platform (linux/amd64) does not match the detected host platform (linux/arm/v7) and no specific platform was requested

Where can i find arm/v7 platform for emoncms?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants