Important detail: What is important with the slashes and the path are related to the SOURCE path. It doesn't matter if the destination does or doesn't have a trailing slash. It does matter if the destination specifies a file rather than a directory, though.
On Tuesday, November 15, 2022 at 9:51:30 AM UTC-7 FIA Ranch wrote: > Okay...... Thanks all for the thoughts and comments. > > For the sake of anyone fighting this same issue somewhere in the future, > let me get this refocused, clarified, up to date. > > Baseline Info > ------ > 1) Host Machine is a hosting company > 2) The host machine is a shared Linux based machine > 3) I own the domain and rent the hosting > 4) In the absolute path... home3/fiaranch/........ - everything under and > past 'fiaranch' I have full control of > > 5) Client Machine is mine and is a private machine to be used and abused > as I see fit. :o) > > Users Question - Closed > With regards to this issue with WeeWX, all activity will be with my root > hat on. > > SSH Keys Issue - Closed > Thanks to Vince I learned that user and root keys are independant. Now > both root and user have their own keys and they have been tested. > > SSH Port Question - Closed > The hosting company states two ports as follows: > SSH - 22 > SSH Shared/Reseller Servers - 2222 > NOTE - Command line Rsync actually works with both > > > Question of "/" placement - Closed > > Thank you cric...@pobox.com for the definition of differentiation. > > File placement on the host is absolute path > /home3/fiaranch/public_html/weather/*.* > > Using command line, Rsync will accept both, which makes sense based on > what cric...@pobox.com stated. > > Command (WITH trailing '/') - root@weather:~# rsync -avhze ssh --progress > --update --stats /var/www/html/ --delete > fiar...@fiaranch.com:/home3/fiaranch/public_html/weather/ > > Result (without all the superfulous data) > sent 595.67K bytes received 17.85K bytes 31.46K bytes/sec > total size is 1.79M speedup is 2.91 > > Command (WITHOUT trailing '/') - root@weather:~# rsync -avhze ssh > --progress --update --stats /var/www/html/ --delete > fiar...@fiaranch.com:/home3/fiaranch/public_html/weather > > Result (without all the superfulous data) > sent 309.53K bytes received 12.20K bytes 71.49K bytes/sec > total size is 1.86M speedup is 5.77 > > Note - The result difference is mainly a time difference. However, based > on differentiation cric...@pobox.com stated, I am going to go forward > without the trailing '/'. > > So that brings me to WeeWX config discussion. > > The WeeWX Config is now as follows: > skin = Rsync > enable = true > server = fiaranch.com > user = fiaranch > path = /home3/fiaranch/public_html/weather > port = 2222 > log_success = true > log_failure = true > HTML_ROOT = /var/www/html > delete = 1 > > Notes: > 1) The two log entries I added from what Vince posted. Just to see if > that provides any additional information. > 2) Removed the trailing '/' from the path. > > Results > Nov 15 09:34:23 weather weewx[5274] DEBUG weewx.reportengine: Running > report 'RSYNC' > Nov 15 09:34:23 weather weewx[5274] DEBUG weewx.reportengine: Found > configuration file /etc/weewx/skins/Rsync/skin.conf for report 'RSYNC' > Nov 15 09:34:23 weather weewx[5274] DEBUG weewx.reportengine: Cannot read > localization file /etc/weewx/skins/Rsync/lang/en.conf for report 'RSYNC': > Config file not found: "/etc/weewx/skins/Rsync/lang/en.conf". > Nov 15 09:34:23 weather weewx[5274] DEBUG weewx.reportengine: **** Using > defaults instead. > Nov 15 09:34:23 weather weewx[5274] DEBUG weeutil.rsyncupload: > rsyncupload: cmd: [['rsync', '--archive', '--stats', '--delete', '-e', 'ssh > -p 2222', '/var/www/html/', > 'fiar...@fiaranch.com:/home3/fiaranch/public_html/weather']] > Nov 15 09:34:26 weather weewx[5274] INFO weeutil.rsyncupload: rsync'd 56 > files (1,093,360 bytes) in 2.42 seconds > > WHAT !!!!! > > All said and done.... the failures can be attributed to two things: > 1) SSH Keys must be paired under root, not user - Thank You Vince > 2) No trailing '/' in the path. Even though it will work in a command > line Rsync, it will not work in WeeWX. > > Discussion Closed!!!! > > Thanks to all for the comments, ideas, assistance, and sharing your > experience! > > Now going to play with Rsync options to see if I can break it again!! > LMFAO > > > > > > > > On Tuesday, November 15, 2022 at 9:17:55 AM UTC-7 jo...@johnkline.com > wrote: > >> A trailing slash means copy the contents of the directory. >> >> Note that WeeWX code will add the slash if it is a directory. See code >> snippet below. >> >> [image: weewx.png] >> >> weewx/rsyncupload.py at master · weewx/weewx >> <https://github.com/weewx/weewx/blob/master/bin/weeutil/rsyncupload.py> >> github.com >> <https://github.com/weewx/weewx/blob/master/bin/weeutil/rsyncupload.py> >> <https://github.com/weewx/weewx/blob/master/bin/weeutil/rsyncupload.py> >> >> # If the source path ends with a slash, rsync interprets >> # that as a request to copy all the directory's *contents*, >> # whereas if it doesn't, it copies the entire directory. >> # We want the former, so make it end with a slash. >> # Note: Don't add the slash if local_root isn't a directory >> if self.local_root.endswith(os.sep) or not >> os.path.isdir(self.local_root): >> rsynclocalspec = self.local_root >> else: >> rsynclocalspec = self.local_root + os.sep >> >> >> On Nov 15, 2022, at 7:33 AM, cric...@pobox.com <cric...@pobox.com> wrote: >> >> A couple of points about the trailing slashes. A trailing slash means >> copy the contents of the directory. The --archive >> >> means copy everything below the specified directory. Not including a >> trailing slash means copy this directory and with >> --archive, everything below it. It's not a matter of rsync not working >> because of the slashes, it just does two similar, but >> different things. The man pages for rsync are pretty good. >> As for the ssh keys, I'm pretty sure you can just copy the >> ~fiaranch/.ssh/id_rsa to ~root/.ssh. No need to create root-specific >> key pair and copy the public server's .ssh directory. Oh, one other >> thing that's really important: >> >> The .ssh directory permissions are critical. The directory itself must >> be chmod 0700. The files inside it should be chmod 0600. >> This is true for all the .ssh directories on both ends of the connection. >> >> My setup is a little different; I rsync to another local machine that >> runs a web server. Then I've got a separate script for >> publishing the weewx (and a few other sites) to a public host, since the >> various href's need to be updated. >> >> On Tuesday, November 15, 2022 at 5:25:11 AM UTC-7 Greg Troxel wrote: >> >>> >>> "gszla...@gmail.com" <gszla...@gmail.com> writes: >>> >>> > 1. Vince is correct. WeeWX runs as root and RSA generation must be >>> done as >>> > root. >>> >>> I was sure Vince was correct to start with :-) but I think running weewx >>> as root is the wrong thing to do. I run it as a non-root user, and >>> really there should be a dedicated weewx user that has permissions to do >>> what it needs (read the serial port, write the db, access credentials >>> for upload) and no more. >>> >>> But this is really "how best to configure weewx on operating system X", >>> which is orthogonal to "how should I made weewx on system X already >>> configured as Y work". >>> >> -- >> You received this message because you are subscribed to the Google Groups >> "weewx-user" group. >> To unsubscribe from this group and stop receiving emails from it, send an >> email to weewx-user+...@googlegroups.com. >> To view this discussion on the web visit >> https://groups.google.com/d/msgid/weewx-user/a69561f5-048a-4e2f-bc8f-e009a9cc2911n%40googlegroups.com >> >> <https://groups.google.com/d/msgid/weewx-user/a69561f5-048a-4e2f-bc8f-e009a9cc2911n%40googlegroups.com?utm_medium=email&utm_source=footer> >> . >> >> -- You received this message because you are subscribed to the Google Groups "weewx-user" group. To unsubscribe from this group and stop receiving emails from it, send an email to weewx-user+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/weewx-user/e94c6558-6d83-4f0f-8bd3-8691eaae2db5n%40googlegroups.com.