Sorry John, not sure I am picking up what you mean or in relation to which comment. The idea is that the install script will enable you to select the components you need so if you just want emonhub, then that is what will get installed. This bit about the services files is slightly aside to that.
Again, not really understanding your point. Trystan has largely written the scripts themselves. If you’ve got a specific point in the code, go into github and, where the line number is, click on that and copy a permalink to paste here.
Thanks @borpin, happy to do it this way, I guess it means we loose the ability to symlink straight, we’d need to include a mechanism to update overwrite the service file on update if applicable.
Can you load a configuration file from a systemd service file? I guess that would still rely on a fixed path e.g /etc/emonhub/default or other, perhaps modifying the service file during install is cleaner overall?
/usr is the second major section of the filesystem. /usr is shareable, read-only data
…
Large software packages must not use a direct subdirectory under the /usr hierarchy.
It looks like /usr/local is best suited for applications that fit the /usr/local/bin, /usr/local/src /usr/local/etc hierarchy.
/opt/ looks like a better install location /opt/emon/
/opt is reserved for the installation of add-on application software packages.
A package to be installed in /opt must locate its static files in a separate /opt/<package> or /opt/<provider> directory tree, where <package> is a name that describes the software package and <provider> is the provider’s LANANA registered name.
The structure of the directories below /opt/<provider> is left up to the packager of the software, though it is recommended that packages are installed in /opt/<provider>/<package> and follow a similar structure to the guidelines for /opt/package.
any views?
we should be able to make this flexible, set in the installation configuration file, so its not an urgent question.
Sort of, but it still ends up with a hard coded path.
The install/update script I have seen (and cannot remember what now), simply wrote the required text to a new file (having checked and deleted any existing file) direct to the required systemd folder (/lib/systemd/system) - no symlink required. Any paths can then be generated in the script before writing the text.
Thanks @borpin I like the ‘paths can be generated in the script’ approach. I have this now working for both the emonhub and demandshaper services, e.g: https://github.com/emoncms/demandshaper/blob/master/install.sh#L20 - the install.sh script in the demandshaper module is called from emoncms_modules.sh
Thanks for the link, that discussion did cross my mind when thinking about the /var/lib/phpfina etc locations. I will have a good read through again.
I’ve moved much of the emonhub installation process to the emonhub repo itself, replacing the existing install scripts that where emonpi specific. emonhub/install.sh at emon-pi · openenergymonitor/emonhub · GitHub
This script is then called from a much shorter script in the original installer directory.
FWIW, that’s an obsolete version of the spec - fifteen years old. The current version is Filesystem Hierarchy Standard
/opt/package-name for code and move data directories to /var/opt/package-name for data after installation are reasonable places for external products to be placed. If a distro packages a product and releases it, then it will typically put it under /usr with data under /var/lib
So the package should make sure it uses relative, and configurable paths to enable such changes. Ditto for its dependencies on other packages, which may live in different places on different systems. That also allows for multiple versions if the version number is in the path somewhere.
Thanks @djh that is useful to know, looks like we are on the right track then moving to /opt. I will also move the data directories to /var/opt/emon/phpfina etc (configurable of course) thanks for the tip on that. Any objections?
I still need to look the idea of supporting multiple emoncms installations on one machine as suggested by @pb66 as part of this.
It’s annoying that after you split the topic, I no longer get notification emails to tell me there’s been any activity. Short of changing discourse to also split the notifications, can I suggest that as a courtesy whenever anybody splits a topic, they post a message to the original topic stating that that is what they have done?
I’m not sure if you are using the latest Raspbian Lite image, but the readme for expanding the file system does not seem to match this image after first boot. I suspect the file system has already been expanded.
Disk /dev/mmcblk0: 14.5 GiB, 15552479232 bytes, 30375936 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0x8b1df36f
Device Boot Start End Sectors Size Id Type
/dev/mmcblk0p1 8192 96042 87851 42.9M c W95 FAT32 (LBA)
/dev/mmcblk0p2 98304 30375935 30277632 14.4G 83 Linux
Trying to run the install and I fell at the first hurdle.
[edit] decided to run it anyway. Ran fine until here where it wanted some input.