64 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # [`copyparty-fuse.py`](copyparty-fuse.py)
 | ||
| * mount a copyparty server as a local filesystem (read-only)
 | ||
| * **supports Windows!** -- expect `194 MiB/s` sequential read
 | ||
| * **supports Linux** -- expect `117 MiB/s` sequential read
 | ||
| * **supports macos** -- expect `85 MiB/s` sequential read
 | ||
| 
 | ||
| filecache is default-on for windows and macos;
 | ||
| * macos readsize is 64kB, so speed ~32 MiB/s without the cache
 | ||
| * windows readsize varies by software; explorer=1M, pv=32k
 | ||
| 
 | ||
| note that copyparty should run with `-ed` to enable dotfiles (hidden otherwise)
 | ||
| 
 | ||
| also consider using [../docs/rclone.md](../docs/rclone.md) instead for 5x performance
 | ||
| 
 | ||
| 
 | ||
| ## to run this on windows:
 | ||
| * install [winfsp](https://github.com/billziss-gh/winfsp/releases/latest) and [python 3](https://www.python.org/downloads/)
 | ||
|   * [x] add python 3.x to PATH (it asks during install)
 | ||
| * `python -m pip install --user fusepy`
 | ||
| * `python ./copyparty-fuse.py n: http://192.168.1.69:3923/`
 | ||
| 
 | ||
| 10% faster in [msys2](https://www.msys2.org/), 700% faster if debug prints are enabled:
 | ||
| * `pacman -S mingw64/mingw-w64-x86_64-python{,-pip}`
 | ||
| * `/mingw64/bin/python3 -m pip install --user fusepy`
 | ||
| * `/mingw64/bin/python3 ./copyparty-fuse.py [...]`
 | ||
| 
 | ||
| you could replace winfsp with [dokan](https://github.com/dokan-dev/dokany/releases/latest), let me know if you [figure out how](https://github.com/dokan-dev/dokany/wiki/FUSE)  
 | ||
| (winfsp's sshfs leaks, doesn't look like winfsp itself does, should be fine)
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| # [`copyparty-fuse🅱️.py`](copyparty-fuseb.py)
 | ||
| * mount a copyparty server as a local filesystem (read-only)
 | ||
| * does the same thing except more correct, `samba` approves
 | ||
| * **supports Linux** -- expect `18 MiB/s` (wait what)
 | ||
| * **supports Macos** -- probably
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| # [`copyparty-fuse-streaming.py`](copyparty-fuse-streaming.py)
 | ||
| * pretend this doesn't exist
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| # [`mtag/`](mtag/)
 | ||
| * standalone programs which perform misc. file analysis
 | ||
| * copyparty can Popen programs like these during file indexing to collect additional metadata
 | ||
| 
 | ||
| 
 | ||
| # [`dbtool.py`](dbtool.py)
 | ||
| upgrade utility which can show db info and help transfer data between databases, for example when a new version of copyparty is incompatible with the old DB and automatically rebuilds the DB from scratch, but you have some really expensive `-mtp` parsers and want to copy over the tags from the old db
 | ||
| 
 | ||
| for that example (upgrading to v0.11.20), first launch the new version of copyparty like usual, let it make a backup of the old db and rebuild the new db until the point where it starts running mtp (colored messages as it adds the mtp tags), that's when you hit CTRL-C and patch in the old mtp tags from the old db instead
 | ||
| 
 | ||
| so assuming you have `-mtp` parsers to provide the tags `key` and `.bpm`:
 | ||
| 
 | ||
| ```
 | ||
| cd /mnt/nas/music/.hist
 | ||
| ~/src/copyparty/bin/dbtool.py -ls up2k.db
 | ||
| ~/src/copyparty/bin/dbtool.py -src up2k.*.v3 up2k.db -cmp
 | ||
| ~/src/copyparty/bin/dbtool.py -src up2k.*.v3 up2k.db -rm-mtp-flag -copy key
 | ||
| ~/src/copyparty/bin/dbtool.py -src up2k.*.v3 up2k.db -rm-mtp-flag -copy .bpm -vac
 | ||
| ```
 | 
