MakeMKV

Under the Advanced settings it is possible to tweak what MakeMKV is looking for when it rips a disc.

The original string is:

-sel:all,+sel:(favlang|nolang),-sel:mvcvideo,=100:all,-10:favlang

Which basically selects favourite language files and no language files, and deselects mvcvideo (3D) files. No idea what the bit on the end does but it does explain why my 3D films never worked properly.

From looking on the MakeMKV forum I’m now using:

-sel:all,+sel:(favlang|nolang|mvcvideo),=100:all,-10:favlang

which should let me rip 3D films and, now that I’ve sent falling to English, only selects the English tracks.

Plex and Subtitles – 2

Subtitle Editor seems to be the go-to program for editing subtitles. However, being on a Mac, that’s no good for me as there are only Windows and Linux versions. The thing with having a Linux version of a tool though is that there’s a very good chance that it exists in Docker and that is, indeed, the case here.

https://hub.docker.com/r/fresta/subtitleedit

docker run --name=subtitleedit -e WIDTH=1280 -e HEIGHT=720 -p 3389:3389 -p 8080:8080 -v /media:/media fresta/subtitleedit

Just set /media to be something useful.

Plex and Subtitles

I’ve spent far too much time ripping all my Blu-Rays to make sure they’ve got the full compliment of English audio and subtitle tracks. However, that might have been the wrong way of doing things. I mean, I don’t really care all that much about commentary tracks at all, I just wanted them there for the sake of completeness.

Now, the other day we were watching The Mummy, the rather excellent film with Brendan Fraser and Rachel Weisz and I was getting rather irritated because the subtitles I was expecting to see simply weren’t there. I’m pretty sure there were there before I started my “big rip” programme but they’re not there now. Well, that’s just annoying.

I started to cycle through the various subtitle tracks and not one of them was just the forced subtitles. It was everything or nothing. That was rather irritating too.

I re-ripped the disc looking for a subtitle track I might have missed but, alas, no. I’d got them all. I tried ripping just the tracks listed as “forced” but, if I took just those, then no subtitles were present in the final mkv. Selecting the subtitle track before the forced track gave me everything.

Also, The Mummy contains TextST tracks which, when ripped, completely break IINA for some reason. It turns out that The Mummy simply doesn’t have any forced subtitles at all. The Mummy Returns does, they’re easy to find, but not The Mummy.

On the MakeMKV forums I found a nice little snippet of helpful code:

mkvmerge -i <MKV File>
mkvextract tracks <MKV File> <track>:<export subtitle>

So, for The Mummy the first part looks like this:

mkvmerge -i The\ Mummy\ \(1999\).mkv 
File 'The Mummy (1999).mkv': container: Matroska
Track ID 0: video (VC-1)
Track ID 1: audio (DTS-HD Master Audio)
Track ID 2: audio (DTS)
Track ID 3: audio (AC-3)
Track ID 4: audio (AC-3)
Track ID 5: audio (AC-3)
Track ID 6: subtitles (HDMV PGS)
Track ID 7: subtitles (HDMV PGS)
Chapters: 18 entries

This shows that tracks 6 and 7 are the subtitle tracks. Now, at this point we could play the video in IINA and see which one of the two is the better extract possibility. Doing that we can see that track 6 aligns with the speech and track 7 appears to be the commentary. So, that means, we want track 6.

If we’re going to create an external subtitle file we really want our subtitles to be in an SRT format so we’ll name the file accordingly. The extract might take a while, especially if the extract is taking place over the network.

 mkvextract tracks The\ Mummy\ \(1999\).mkv 6:English_1.srt
Extracting track 6 with the CodecID 'S_HDMV/PGS' to the file 'English_1.sup'. Container format: SUP
Progress: 100%

We can see that the container format is actually SUP and not SRT so the file should be renamed to reflect that.

mv English_1.srt English_1.sup

Now, somehow, we just need to convert the SUP to SRT. Fortunately, there’s a website that can help with that:

https://subtitletools.com

The problem now is that the file just downloaded is the whole of the subtitle track which means that it is now necessary to go through the entire file and rip out all the entries that are not needed. It’s a bit of a painful process but, fortunately, in the case of The Mummy, it is possible to use “Egyptian” as a marker for where to look for the forced subtitles.

Once we have a file that looks reasonable, we just have to give it a sensible name, for Plex this looks like:

The Mummy (1999).eng.forced.srt

And, once that is done, The Mummy now has forced subtitles in all the right places. Well, not “all” the right places because the source file still appears to be missing the occasional entry but it’s a good as it’s going to get.

Hello Twonky! This is Europe calling.

I’m still looking at getting the album order correct on multi-disc albums. Only now, I’m running Twonky on my T12-423 rather than the WD NAS so I can pretty much do what I want to now.

So, first things first. The Twonky calls.

I’m using HTTPie but Postman would be equally good. First, we need to construct a post to read the available albums:

POST http://192.168.3.16:9000/dev0/srv1/control

<s:Envelope s:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
<s:Body>
<u:Browse xmlns:u="urn:schemas-upnp-org:service:ContentDirectory:1">
<ObjectID>0$1$12</ObjectID>
<BrowseFlag>BrowseDirectChildren</BrowseFlag>
<Filter>*</Filter>
<StartingIndex>233</StartingIndex>
<RequestedCount>300</RequestedCount>
<SortCriteria/>
</u:Browse>
</s:Body>
</s:Envelope>

I can’t remember where the original object ID comes from (a thing for another day) but the StartingIndex and the RequestedCount are where you want to start in your list of albums and how many albums you’d like returned. Twonky only seemed to return 232 which is why I started at 233. I deliberately kept the RequestCount High because Twonky will tell me how many entries its retuned so I’m not too fussed about being accurate.

Twonky returns coded XML which looks like this:

<DIDL-Lite xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:upnp="urn:schemas-upnp-org:metadata-1-0/upnp/" xmlns:dlna="urn:schemas-dlna-org:metadata-1-0/" xmlns:arib="urn:schemas-arib-or-jp:elements-1-0/" xmlns:dtcp="urn:schemas-dtcp-com:metadata-1-0/" xmlns:pv="http://www.pv.com/pvns/" xmlns="urn:schemas-upnp-org:metadata-1-0/DIDL-Lite/"><container id="0$1$12$4282" parentID="0$1$12" restricted="1" childCount="38" searchable="1"><dc:title>Eurovision Song Contest 2014: Copenhagen - Join Us</dc:title><upnp:genre>Pop</upnp:genre><upnp:album>Eurovision Song Contest 2014: Copenhagen - Join Us</upnp:album><dc:creator>Various Artists</dc:creator><upnp:albumArtURI dlna:profileID="JPEG_TN" >http://192.168.3.16:9000/disk/DLNA-PNJPEG_TN-OP01-CI1-FLAGS00d00000/defaa/C/O0$1$12$4282.jpg?scale=org</upnp:albumArtURI><pv:childCountContaine

Copy the body into SublimeText and find / replace the &lt; and &gt; with < and > respectively, then indent the XML to get a nicely formatted page. From this I can easily see that the object for Eurovision 2024 is:

<container childCount="37" dc:date="2024-01-01T12:00:00" id="0$1$12$5307" parentID="0$1$12" restricted="1" searchable="1">
<dc:title>Eurovision Song Contest 2024: Malmö - United By Music</dc:title>
<dc:date>2024-01-01</dc:date>
<upnp:genre>Pop</upnp:genre>
<upnp:album>Eurovision Song Contest 2024: Malmö - United By Music</upnp:album>
<dc:creator>Various Artists</dc:creator>
<upnp:albumArtURI dlna:profileID="JPEG_TN">http://192.168.3.16:9000/disk/DLNA-PNJPEG_TN-OP01-CI1-FLAGS00d00000/defaa/C/O0$1$12$5307.jpg?scale=org</upnp:albumArtURI
<pv:childCountContainer>0</pv:childCountContainer>
<upnp:artist>Various Artists</upnp:artis>
<pv:modificationTime>421989616</pv:modificationTime><pv:containerContent>object.item.audioItem.musicTrack</pv:containerContent>
<upnp:class>object.container.album.musicAlbum</upnp:class>
</container>

Now, make a call to Twonky using the same parameters as the CXN makes:

POST http://192.168.3.16:9000/dev0/srv1/control
<s:Envelope s:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
<s:Body>
<u:Browse xmlns:u="urn:schemas-upnp-org:service:ContentDirectory:1">
<ObjectID>0$1$12$5307</ObjectID>
<BrowseFlag>BrowseDirectChildren</BrowseFlag>
<Filter>dc:title,upnp:class,upnp:album,upnp:originalTrackNumber,id,res,res@protection,res@duration,upnp:searchClass,upnp:artist,upnp:genre,upnp:albumArtURI</Filter>
<StartingIndex>0</StartingIndex>
<RequestedCount>100</RequestedCount>
<SortCriteria>+upnp:originalTrackNumber,+dc:title</SortCriteria>
</u:Browse>
</s:Body>
</s:Envelope>

This returns:

<?xml version="1.0" encoding="utf-8"?>
<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/" s:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
<s:Body>
<u:BrowseResponse xmlns:u="urn:schemas-upnp-org:service:ContentDirectory:1">
<Result>
<DIDL-Lite xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:upnp="urn:schemas-upnp-org:metadata-1-0/upnp/" xmlns:dlna="urn:schemas-dlna-org:metadata-1-0/" xmlns:arib="urn:schemas-arib-or-jp:elements-1-0/" xmlns:dtcp="urn:schemas-dtcp-com:metadata-1-0/" xmlns:pv="http://www.pv.com/pvns/" xmlns="urn:schemas-upnp-org:metadata-1-0/DIDL-Lite/">
<item id="0$1$12$5307R891915" parentID="0$1$12$5307" restricted="1">
<dc:title>Hurricane [Israel]</dc:title>
<upnp:genre>Pop</upnp:genre>
<upnp:album>Eurovision Song Contest 2024: Malmö - United By Music</upnp:album>
<upnp:originalTrackNumber>1</upnp:originalTrackNumber>
<upnp:albumArtURI dlna:profileID="JPEG_TN" >http://192.168.3.16:9000/disk/DLNA-PNJPEG_TN-OP01-CI1-FLAGS00d00000/defaa/A/O0$1$8I891915.jpg?scale=org</upnp:albumArtURI>
<upnp:artist>Eden Golan</upnp:artist>
<res duration="0:03:01.440" protocolInfo="http-get:*:audio/x-aiff:*" >http://192.168.3.16:9000/disk/NON-DLNA-OP01-FLAGS01700000/O0$1$8I891915.aif</res>
<upnp:class>object.item.audioItem.musicTrack</upnp:class>
</item>
<item id="0$1$12$5307R887307" parentID="0$1$12$5307" restricted="1">
<dc:title>Titan [Albania]</dc:title>
<upnp:genre>Pop</upnp:genre>
<upnp:album>Eurovision Song Contest 2024: Malmö - United By Music</upnp:album>
<upnp:originalTrackNumber>1</upnp:originalTrackNumber>
<upnp:albumArtURI dlna:profileID="JPEG_TN" >http://192.168.3.16:9000/disk/DLNA-PNJPEG_TN-OP01-CI1-FLAGS00d00000/defaa/A/O0$1$8I887307.jpg?scale=org</upnp:albumArtURI>
<upnp:artist>BESA</upnp:artist>
<res duration="0:02:58.226" protocolInfo="http-get:*:audio/x-aiff:*" >http://192.168.3.16:9000/disk/NON-DLNA-OP01-FLAGS01700000/O0$1$8I887307.aif</res>
<upnp:class>object.item.audioItem.musicTrack</upnp:class>
</item>

Hurricane is not the first track for the album so this is obviously wrong.

As I can’t change what the CXN is asking for, I need to change the response the CXN is receiving (if that is even possible?)

What I think I need to do is to have the “upnp:originalTrackNumber” be a combination of the disc number and the actual track number so it becomes something like 101 and 201 for the first track on the first and second disks… I think I’m out of luck there.

Expanding a RAID – Part Deux

Make sure the filesystem isn’t being used:

sudo systemctl stop plexmediaserver
sudo systemctl stop smbd

unmount the filesystem

sudo umount /storage

use parted to resize the filesystem

sudo parted
resize part 1 100%

remount

sudo mount /storage

resize the Btrfs filesystem

sudo btrfs filesystem resize max /storage

and, all being well, the system isn’t hosed.

Expanding a RAID

Quick overview more for me than anything else:

lsblk to see disks in system:

NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINTS
sda 8:0 0 9.1T 0 disk
└─md3 9:3 0 27.3T 0 raid5
└─md3p1 259:0 0 27.3T 0 part /storage
sdb 8:16 0 9.1T 0 disk
└─md3 9:3 0 27.3T 0 raid5
└─md3p1 259:0 0 27.3T 0 part /storage
sdc 8:32 0 3.6T 0 disk
├─sdc1 8:33 0 1G 0 part
├─sdc2 8:34 0 1G 0 part
│ └─md0 9:0 0 1022M 0 raid1
│ └─md0p1 259:2 0 1020M 0 part /boot
├─sdc3 8:35 0 128G 0 part
│ └─md1 9:1 0 127.9G 0 raid1
│ └─md1p1 259:1 0 127.9G 0 part [SWAP]
└─sdc4 8:36 0 3.5T 0 part
└─md2 9:2 0 3.5T 0 raid1
└─md2p1 259:3 0 3.5T 0 part /
sdd 8:48 0 3.6T 0 disk
├─sdd1 8:49 0 1G 0 part /boot/efi
├─sdd2 8:50 0 1G 0 part
│ └─md0 9:0 0 1022M 0 raid1
│ └─md0p1 259:2 0 1020M 0 part /boot
├─sdd3 8:51 0 128G 0 part
│ └─md1 9:1 0 127.9G 0 raid1
│ └─md1p1 259:1 0 127.9G 0 part [SWAP]
└─sdd4 8:52 0 3.5T 0 part
└─md2 9:2 0 3.5T 0 raid1
└─md2p1 259:3 0 3.5T 0 part /
sde 8:64 0 9.1T 0 disk
└─md3 9:3 0 27.3T 0 raid5
└─md3p1 259:0 0 27.3T 0 part /storage
sdf 8:80 0 9.1T 0 disk
└─md3 9:3 0 27.3T 0 raid5
└─md3p1 259:0 0 27.3T 0 part /storage

add in new disk and lsblk again:

NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINTS
sda 8:0 0 9.1T 0 disk
└─md3 9:3 0 27.3T 0 raid5
└─md3p1 259:0 0 27.3T 0 part /storage
sdb 8:16 0 9.1T 0 disk
└─md3 9:3 0 27.3T 0 raid5
└─md3p1 259:0 0 27.3T 0 part /storage
sdc 8:32 0 3.6T 0 disk
├─sdc1 8:33 0 1G 0 part
├─sdc2 8:34 0 1G 0 part
│ └─md0 9:0 0 1022M 0 raid1
│ └─md0p1 259:2 0 1020M 0 part /boot
├─sdc3 8:35 0 128G 0 part
│ └─md1 9:1 0 127.9G 0 raid1
│ └─md1p1 259:1 0 127.9G 0 part [SWAP]
└─sdc4 8:36 0 3.5T 0 part
└─md2 9:2 0 3.5T 0 raid1
└─md2p1 259:3 0 3.5T 0 part /
sdd 8:48 0 3.6T 0 disk
├─sdd1 8:49 0 1G 0 part /boot/efi
├─sdd2 8:50 0 1G 0 part
│ └─md0 9:0 0 1022M 0 raid1
│ └─md0p1 259:2 0 1020M 0 part /boot
├─sdd3 8:51 0 128G 0 part
│ └─md1 9:1 0 127.9G 0 raid1
│ └─md1p1 259:1 0 127.9G 0 part [SWAP]
└─sdd4 8:52 0 3.5T 0 part
└─md2 9:2 0 3.5T 0 raid1
└─md2p1 259:3 0 3.5T 0 part /
sde 8:64 0 9.1T 0 disk
└─md3 9:3 0 27.3T 0 raid5
└─md3p1 259:0 0 27.3T 0 part /storage
sdf 8:80 0 9.1T 0 disk
└─md3 9:3 0 27.3T 0 raid5
└─md3p1 259:0 0 27.3T 0 part /storage
sdg 8:96 0 9.1T 0 disk
├─sdg1 8:97 0 2G 0 part
│ └─md127 9:127 0 0B 0 md
├─sdg2 8:98 0 9.1T 0 part
│ └─md126 9:126 0 0B 0 md
├─sdg3 8:99 0 1G 0 part
└─sdg4 8:100 0 1G 0 part

/dev/sdg has been added

However, because sdg is showing as md127 we need to stop and remove the raid:

mdadm --stop /dev/md127
mdadm --remove /dev/md127

now we can partition the disk

use parted to wipe filesystem and add a new label to the disk

parted -s -a optimal /dev/sdg mklabel gpt

Use fdisk to check the new GTP Partition tables. Don’t bother to create any partitions.

fdisk -p to check out the unpartitioned disk:

$ sudo fdisk /dev/sdg
Welcome to fdisk (util-linux 2.39.3).
Changes will remain in memory only, until you decide to write them.
Be careful before using the write command.

Command (m for help): p
Disk /dev/sdg: 9.1 TiB, 10000831348736 bytes, 19532873728 sectors
Disk model: WDC WD100EFAX-68
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 4096 bytes
I/O size (minimum/optimal): 4096 bytes / 4096 bytes
Disklabel type: gpt
Disk identifier: 56FF5A1F-FE90-4AB1-ABD6-DBB1E1D22042

Command (m for help): q

Just check to see which array you’re adding the disk to:

$ cat /prod/mdstat

Personalities : [raid6] [raid5] [raid4] [raid1] [raid0] [raid10]
md1 : active raid1 sdd3[1] sde3[0]
134085632 blocks super 1.2 [2/2] [UU]
bitmap: 0/1 pages [0KB], 65536KB chunk

md2 : active raid1 sdd4[1] sde4[0]
3770516480 blocks super 1.2 [2/2] [UU]
bitmap: 1/29 pages [4KB], 65536KB chunk

md0 : active raid1 sdd2[1] sde2[0]
1046528 blocks super 1.2 [2/2] [UU]

md3 : active raid5 sdf[2] sdb[1] sdg[4] sda[0]
29298914304 blocks super 1.2 level 5, 512k chunk, algorithm 2 [4/4] [UUUU]
bitmap: 0/73 pages [0KB], 65536KB chunk

unused devices: <none>

md3 in this case. Add the disk into the array:

mdadm --add /dev/md3 /dev/sdg

Check the array:

$ sudo mdadm --add /dev/md3 /dev/sdg
mdadm: added /dev/sdg

sysadmin@tnas:~$ cat /proc/mdstat
Personalities : [raid6] [raid5] [raid4] [raid1] [raid0] [raid10]
md1 : active raid1 sdd3[1] sde3[0]
134085632 blocks super 1.2 [2/2] [UU]
bitmap: 0/1 pages [0KB], 65536KB chunk

md2 : active raid1 sdd4[1] sde4[0]
3770516480 blocks super 1.2 [2/2] [UU]
bitmap: 2/29 pages [8KB], 65536KB chunk

md0 : active raid1 sdd2[1] sde2[0]
1046528 blocks super 1.2 [2/2] [UU]

md3 : active raid5 sdc5 sdf[2] sdb[1] sdg[4] sda[0]
29298914304 blocks super 1.2 level 5, 512k chunk, algorithm 2 [4/4] [UUUU]
bitmap: 0/73 pages [0KB], 65536KB chunk

The disk is now visible in the array: sdc5 but it’s marked as a spare disk (S).

Now we need to grow the array:

mdadm --grow /dev/md3 --raid-devices=5

where the number of raid devices is the number of disks we want in the raid.

Watch /proc/mdstat to see the progress:

$ cat /proc/mdstat
Personalities : [raid6] [raid5] [raid4] [raid1] [raid0] [raid10]
md1 : active raid1 sdd3[1] sde3[0]
134085632 blocks super 1.2 [2/2] [UU]
bitmap: 0/1 pages [0KB], 65536KB chunk

md2 : active raid1 sdd4[1] sde4[0]
3770516480 blocks super 1.2 [2/2] [UU]
bitmap: 1/29 pages [4KB], 65536KB chunk

md0 : active raid1 sdd2[1] sde2[0]
1046528 blocks super 1.2 [2/2] [UU]

md3 : active raid5 sdc[5] sdf[2] sdb[1] sdg[4] sda[0]
29298914304 blocks super 1.2 level 5, 512k chunk, algorithm 2 [5/5] [UUUUU]
[>………………..] reshape = 0.0% (337408/9766304768) finish=3376.6min speed=48201K/sec
bitmap: 0/73 pages [0KB], 65536KB chunk

unused devices: <none>

Yep, this is going to take a while. Time to put the kettle on.

Helpful guides:

https://wpguru.co.uk/2021/01/expand-software-raid-mdadm/
https://www.itsfullofstars.de/2019/03/how-to-add-a-new-disk-to-raid5/
https://tomlankhorst.nl/setup-lvm-raid-array-mdadm-linux

MTU Sizing

Edit /etc/netplan/50-cloud-init.yaml

network:
ethernets:
enp3s0:
dhcp4: true
dhcp6: true
mtu: 1472
version: 2

Then do:

sudo netplan try

and accept the change if it seems to work.

  • the default frame size is 1500.

Ubuntu 24.04 on a Terra-Master T12-423

My reasons for putting Ubuntu are explained here: Confession Time and I’m using Ubuntu because that’s what Terra-Master use themselves so it should work just fine and it’s the distribution I’m slightly more familiar with at the moment. Debian would be my alternative choice.

First things first. Open up the case and remove the small SanDisk USB stick. This contains the TOS boot loader and we don’t want that anymore. Go and put it in a marked envelope in a drawer somewhere just in case you ever want to put it back.

Step 2 – not for the faint of heart. Update the BIOS. The full thread is here: https://forum.terra-master.com/en/viewtopic.php?t=4238 and with that done the rest is pretty straightforward.

Next we need to change the boot order. With the TOS USB stick removed that’s an awful lot easier. For some reason, for me at least, the TOS USB stick always took priority no matter what I did so with that out of the way it’s a lot easier to do things now.

I actually burned Ubuntu to DVD rather than a flash drive simply because I don’t think the flash drives I have are very reliable. They are incredibly slow for some reason too. So, I opted for DVD.

Slap the DVD in and run through the basic setup until the drive configuration page presents itself. Here choose the custom layout option. I have two Seagate IronWolf disks as my boot disks so I wanted a mirrored raid boot setup. Not having done that before I found a very easy to follow video (and I really hate having to follow videos) here:

Installing Ubuntu 24.04 With RAID

and a really useful page here:

Ubuntu 24.04 with software RAID1 and UEFI

The only changes to the process I made was to include in my four 10TB raid disks into the process. That means that at the end of the video I have a filesystem that looks something like:

md0 RAID1 /boot
md1 RAID1 SWAP
md2 RAID1 /root
md3 RAID5 /storage

It also means that as the storage is built at installation time I can just sit back and let the RAID configure itself for a few hours.

Because I always choose a minimised installation I need to add a few things in to make the environment usable so this is what I do:

sudo apt update
sudo apt install htop
sudo apt install avahi-daemon
sudo apt install vim
sudo apt install cron
sudo apt upgrade

Once cron and vim are installed I set up my lazy mdstat rebuild page.

I have a little web server with a basic html page of:

<!DOCTYPE html>
<html>
<head>
<title>
RAID Rebuild Status
</title>
<meta http-equiv="refresh" content="60" >
</head>
<body>
<embed src="raid.txt" width="100%" height="1000">
</body>
</html>

It’s really not much of a page. Then on the T12 I add in a cron job:

* * * * * cat /proc/mdstat | ssh ricardo@server.local 'cat - > /home/ricardo/docker/dumkid/html/raid.txt'

This means that I can point my phone / laptop / work computer to my little webpage and see how the rebuild is going without having to log in to the T12 itself.

Confession Time

My WD PR4100 has been pretty stable over the years but, despite having 40TB of disks in there, I’ve run out of space. I *could* have tried to iSCSI some storage but I really just wanted something bigger. My primary requirement is Plex but I’d also quite like to put Twonky on there too.

I quite like the look of the Terra-Master T12-423 because it has lots of expansion space, would easily let me do RAID 6 and it looks like nice too. However, reading around on various forums there was a general consensus of opinion that the OS was pretty poor and it would be better to run UnRaid or TrueNAS on the thing. Well, I’ve always been a sucker for the underdog and quite like a challenge so that’s the device I went for.

What can I say? Well, it was packaged very nicely and in a way that appeals to my aesthetics. The tin itself is very nice too. No complaints there. They even give you a nice little screwdriver for the disks and the case. Almost everybody has a screwdriver so it’s really not necessary but it’s a really nice touch that means you have one immediately to hand.

The rest of it… well, let’s just say the comments on the forums weren’t even close. With the PR4100 you just have to slap some disks in and it’s ready to go. There’s some small configuration that can be done to personalise the device but, out of the box, it just works. The T12-423 is not like there. There’s a small USB boot loader that prompts for a disk but it doesn’t tell you what for. After giving it a disk for storage it installed the OS. That’s not quite what I wanted. Fine. Slap a couple of more disks in there and see what it does. After a good twelve hours of synchronising the test disks are ready. Great! Let’s play.

First off, basic public shared access. I want this to be a media server so I just want to be able to drop files into the shares without having to authenticate first. It did not work. Guest user enabled, read / write permission given to both the user and the group. Nothing but NTLM authentication issues. Thing is, it’s not even possible to hack around with the Samba config because the TOS constantly reverts it to what it thinks it should be.

While trying to hack around with the Samba config I found that it isn’t possible to copy files off the device using SCP because there appears to be some security program running in the background that just kills the process. It’s not even possible to use SFTP because that just segfaults. SFTP has also been configured to run on a non-standard port for “security” reasons and it’s not possible to change back.

The security limitations and alerts are so annoying. It’s not possible to have a user with a name containing “super” or “admin”. This admin account is the only account that can SSH into the box which means that it could effectively become a shared account which is even worse from a security point of view. The security alerting is just dumb. It raises alerts for things like not isolating the box on the network, using the non-standard default ports for SSH, HTTP, HTTPS and such like. It allows the easy use of both Telnet and FTP though which is just insane in today’s world.

Notifications and email are tied together so every time you change a notification setting you need to give it the email password. That makes no sense, they are distinct items and should be treated as such.

Adding disks into the array is really painful. Each disk has to be added one at a time and the array has to completely rebuild before the next one can be added in. When you’re building the initial array that’s just painful. It took a week to build an array using four 10TB disks.

Support is not very good either. When posting on the forum about the Samba issue on the public share I described the issue and everything I’d done up to that point only to get a response telling me I needed to enable the Guest user. Once I’d found out how to enable logging and posted the relevant log lines support stopped responding.

The support files the system generates are too big, or contain too many folders, to be sent through most mail servers. There is no FTP server when the files can be dropped either. Apparently it is possible to remove some of the folders from the file but if they’re not important why collect them anyway? The other issue is that the support team are based in Hong Kong so, given the time difference, it usually takes a day to get a response. If you get one at all.

All-in-all I’ve had the hardware for a week now and still not managed to move any of my media over from the PR4100. TOS really is poor and some very, very strange design choices have been made that make it really hard to work with. Support is practically non-existent and the software just isn’t fit for purpose. Still, the good thing is that it is generic x86 hardware so it’s not too hard to install something else…