As the title states I am wondering what would be a good machine to build for my piracy. I am open to buying a used machine on eBay and expanding over time.

The last time I was sailing I had a Dell R610 Server Rack but I don’t have the space for this now. So something that can sit behind a tv stand in the corner next to the router.

  • I would be running Plex / Jellyfin
  • Some kind of torrent software
  • Something for NZBs if still viable
  • then the usual SONARR, RADARR, etc

I would like to be able to let friends connect from outside my house to stream media and allow them access so they can add films and the server goes off and finds them, extracts them, and adds them to the media server.

Thanks.

  • potentiallynotfelix@lemmy.fish
    link
    fedilink
    English
    arrow-up
    53
    arrow-down
    3
    ·
    10 months ago

    I want to give you some advice: Use Jellyfin, not plex. It has far deviated to a “hub” for other streaming services and unless you want to have built-in streaming platforms on your home media server, or have plex’s own “live tv” service shoved up your rear, I would steer clear.

    Jellyfin is pretty lightweight if you’re just streaming 1-2 connections at a time, I ran it on a raspberry pi 4 for a while and it was near flawless, only recently have I made a proper VM setup for it.

    • kungen@feddit.nu
      link
      fedilink
      English
      arrow-up
      11
      ·
      10 months ago

      You can disable most of that stuff on Plex. But yeah, Jellyfin is nicer anyways as it’s free software.

            • tht@social.pwned.page
              link
              fedilink
              English
              arrow-up
              4
              arrow-down
              1
              ·
              10 months ago

              They mean free as in freedom, not free as in beer

              Free software generally refers to open source software, who’s code you can view and edit yourself

              • realitista@lemm.ee
                link
                fedilink
                English
                arrow-up
                3
                ·
                edit-2
                10 months ago

                When we talk about FOSS, we talk about Free, Open Source Software. Plex is free but not open source, and it’s free price is not enshrined in it’s license as with other FOSS software, which means that there could be a rug pull at any time. But I think that’s unlikely due to its business model.

                Jellyfin is FOSS software meaning it will stay free and open source due to its license.

    • bktheman@awful.systems
      link
      fedilink
      English
      arrow-up
      9
      arrow-down
      2
      ·
      10 months ago

      The only problem is properly exposing jellyfin to the Internet. How do you do it?

      I’m not planning on leaving Plex anytime soon. But I did plan on setting up jellyfin in parallel to play with it and learn about it. But this stopped me in my tracks.

      I don’t want my family to need to VPN into my network. Plex, for as frustrating as it is in many ways, just works. And it works on so much stuff.

        • bktheman@awful.systems
          link
          fedilink
          English
          arrow-up
          1
          ·
          6 months ago

          This is what everyone always says, and yeah, for most people this is probably the most secure and easiest option. But for me it’s too much hassle for my family, too restrictive, and not at all what I’m looking for.

          However in this thread I’ve learned that JF supports https, so if done carefully and properly, I can expose it to the Internet directly, which is what I plan to do. Eventually. Plex is still easier for now.

      • liliumstar@lemmy.dbzer0.com
        link
        fedilink
        English
        arrow-up
        13
        ·
        10 months ago

        Jellyfin offers HTTPS, you just need to specify a certificate. It’s going to be a lot easier to just setup a web server like nginx and expose that to the internet, probably via port forwarding on your gateway/router. In that case, you can get a free certificate from letsencrypt.

        So, the basic steps are:

        1. Get a domain name
        2. Setup JF server, ensure it works locally
        3. Install a web server and set it up to proxy traffic to JF
        4. Expose the web server ports 80 and 443 to the internet
        5. Setup letsencrypt with automatic renewal

        This might sound like a lot of work, but at least you own your data and service. Plex can and will block accounts, rendering servers basically useless.

        • bktheman@awful.systems
          link
          fedilink
          English
          arrow-up
          1
          ·
          6 months ago

          Thanks, you and others in this thread are the first people to ever tell me about this.

          Everyone is always saying tailscale, but that’s too complicated and restrictive for my family.

          I’m not afraid of port forwarding and dynamic DNS, I’ve played with it before. My main concern is just doing it safely, not exposing something to the Internet that wasn’t designed to be exposed. Security risk, and all that.

          Obviously a VPN is the safest way. But as long as JF is reasonably robust and designed to be exposed, I’m happy with that. I just literally didn’t know it was designed that way.

          Thanks!

        • bktheman@awful.systems
          link
          fedilink
          English
          arrow-up
          1
          ·
          6 months ago

          Thanks, you and others in this thread are the first people to ever tell me about this.

          Everyone is always saying tailscale, but that’s too complicated and restrictive for my family.

          I’m not afraid of port forwarding and dynamic DNS, I’ve played with it before. My main concern is just doing it safely, not exposing something to the Internet that wasn’t designed to be exposed. Security risk, and all that.

          Obviously a VPN is the safest way. But as long as JF is reasonably robust and designed to be exposed, I’m happy with that. I just literally didn’t know it was designed that way.

          Thanks!

          • potentiallynotfelix@lemmy.fish
            link
            fedilink
            English
            arrow-up
            1
            ·
            edit-2
            6 months ago

            Jellyfin is not designed to be exposed directly. It can be but I wouldn’t recommend it. If you are insistent on doing it, I would absolutely recommend engine X reverse proxying with a rate limit to prevent any brute force attacks as well as hiding your family’s account on the login screen so not just anyone can see them. Also remember you need an SSL certificate which you can either self-sign or get from a free CA like let’s encrypt.

            Tail scale works quite well but can be limiting in speed. Your family does not need any technical knowledge. They just sign in on the app and you can add their account to your tail scale domain. Keep in mind you may need to pay if you add more than three, I believe, users.

            The third and best option for you in my opinion would be a VPN. It doesn’t suffer from the same speed issues that tailscale does. Technical setup would be a bit more difficult than tail scale, but you can do it on your family’s device once and it should just always work. Youll need port forwarding, but that’s really easy. One thing though, your internet service provider might change your IP address periodically. So you might want a domain name and dynamic DNS, which I would suggest you get from a service called FreeDNS. Like in the name, everything is free, unless you choose to donate , of course. They have it very intuitively laid out where you can use CRON to run a script periodically that just sends a curl ping to their servers so that they know what your new IP address is if it changes. It’s a pretty simple setup.

              • potentiallynotfelix@lemmy.fish
                link
                fedilink
                English
                arrow-up
                1
                ·
                6 months ago

                cloudflare would, but you dont even need it if you are comfortable with port forwarding. a reverse proxy just forwards traffic to and from a device through a device. nginx is a popular platform for reverse proxies because it’s easy to set up and configure.

                • bktheman@awful.systems
                  link
                  fedilink
                  English
                  arrow-up
                  2
                  ·
                  6 months ago

                  Thanks! Someone else said video streaming is against their TOS, so I may have shot myself in the foot

      • ddh@lemmy.sdf.org
        link
        fedilink
        English
        arrow-up
        4
        ·
        10 months ago

        I run both and most users still choose to watch via Plex. I’d like if Jellyfin took over, but it’s not there yet.

      • themoken@startrek.website
        link
        fedilink
        English
        arrow-up
        4
        arrow-down
        1
        ·
        10 months ago

        Sorry, why would Jellyfin be different from Plex for exposing to the Internet? Dynamic DNS service / static IP and router port forwarding just like any other self hosted thing. It requires a user/pass to login as usual. VPN is nice but not required.

          • themoken@startrek.website
            link
            fedilink
            English
            arrow-up
            6
            arrow-down
            1
            ·
            10 months ago

            So it’s not fully self hosted then? I can’t see how it would do that without registering you with their own service as a middle man. Seems like that kinda defeats the purpose.

            • kungen@feddit.nu
              link
              fedilink
              English
              arrow-up
              5
              ·
              10 months ago

              Plex Inc has a central auth server, and your media server automatically creates a dynamic hostname for connecting to your server’s IP. And if the user can’t reach the server directly for some reason (NAT for example), Plex has a “relay server” that works as a proxy, but your quality gets reduced to like 320p or something.

              So if Plex Inc shut down their auth servers suddenly (or have downtime, which happened a couple years ago), you won’t be able to do much. It’s possible to bypass the central auth, but no one does it, because such auto-discovery is one of Plex’s benefits – user logs in on their app, and it shows all their possible servers. But otherwise, it’s self-hosted.

        • bktheman@awful.systems
          link
          fedilink
          English
          arrow-up
          1
          ·
          6 months ago

          Thanks, you and others in this thread are the first people to ever tell me about this.

          Everyone is always saying tailscale, but that’s too complicated and restrictive for my family.

          I’m not afraid of port forwarding and dynamic DNS, I’ve played with it before. My main concern is just doing it safely, not exposing something to the Internet that wasn’t designed to be exposed. Security risk, and all that.

          Obviously a VPN is the safest way. But as long as JF is reasonably robust and designed to be exposed, I’m happy with that. I just literally didn’t know it was designed that way.

          Thanks!

    • Y|yukichigai@lemmy.sdf.org
      link
      fedilink
      English
      arrow-up
      1
      ·
      edit-2
      10 months ago

      I keep Plex as a backup because some client devices are really tetchy about interacting with Jellyfin. Not every smart device supports the Jellyfin app (nor VLC), and if they do have a built-in media player it’s typically one that uses filesize-based progress tracking, i.e. you wind up being unable to fast-forward or rewind the video (or sometimes unable to even pause). Generally every major brand of smart device has a version of the Plex app, for better or worse.

  • FundMECFS@slrpnk.net
    link
    fedilink
    English
    arrow-up
    17
    ·
    10 months ago

    I have an ancient (10+ years old) macbook pro running with a Jellyfin server and qBitorrent and a VPN and it works great!

    No complaints. (I also have a 2 TB harddrive plugged into it).

    • yo_scottie_oh@lemmy.ml
      link
      fedilink
      English
      arrow-up
      3
      ·
      10 months ago

      Does this ancient macbook pro still receive OS updates? Separate but related for purposes of choosing hardware. Thanks!

      • FundMECFS@slrpnk.net
        link
        fedilink
        English
        arrow-up
        5
        ·
        edit-2
        10 months ago

        No it doesn’t. I run older versions of some software. I plan to switch to linux once macos gives out.

      • darcmage@lemmy.dbzer0.com
        link
        fedilink
        English
        arrow-up
        6
        ·
        10 months ago

        Something to also keep in mind is the codec support of the GPU for hardware decoding and transcoding if that’s important to you. The Optiplexes will mostly be fine in this regard but if you see yourself needing AV1 support anytime soon, Intel’s N line is an efficient and relatively cheap option. Getting HDR tone mapping working at the hardware level might also be something to look out for.

      • ocean@lemmy.selfhostcat.com
        link
        fedilink
        English
        arrow-up
        4
        ·
        10 months ago

        I think around $40 depending on the model is a fair price. I have two at home and three in the works for off site backups lol. They’re fun, frequently have surprising specs, and low energy draw

            • dependencyinjection@discuss.tchncs.deOP
              link
              fedilink
              English
              arrow-up
              6
              ·
              10 months ago

              Hey, thanks so much for looking at the listing and also providing some resources.

              This alone gets me on the right track and I really appreciate you taking the time.

              • ShepherdPie@midwest.social
                link
                fedilink
                English
                arrow-up
                6
                ·
                10 months ago

                Something else to think about is future expandability. I’m assuming you’ll start with an HDD or two, but what about after that? You’ll either need to purge out your library or have a bunch of external drives connected. The Optiplex is a great thin client but it only has 1 or 2 SATA ports and one will likely always be used for your OS drive (SSD) which leaves only one internal slot for an HDD.

                Also just some random advice, but if you want cheap drives, keep an eye out for WD Element or WD EasyStore external drives to go on sale. These are extremely easy to remove from their case and be used as an internal drive. Something else to check out would be serverpartdeals.com if you don’t mind trying some used or refurbished enterprise drives. I bought my last 14TB drive from them for something like $100 and haven’t had any issues. This is generally worth the risk since you can just download your media over again if the drive happens to crap out on you.

          • ocean@lemmy.selfhostcat.com
            link
            fedilink
            English
            arrow-up
            4
            ·
            10 months ago

            I bought one across the pond at a university used store then some at an e-recycler. I’m not surprised ebay is different. Hope you can find a fair price!

  • cmnybo@discuss.tchncs.de
    link
    fedilink
    English
    arrow-up
    11
    ·
    10 months ago

    The only things that really matter are storage space and power consumption. If you want to transcode videos, then you will need a GPU that supports encoding whatever codec you want to use.

    • dependencyinjection@discuss.tchncs.deOP
      link
      fedilink
      English
      arrow-up
      23
      ·
      10 months ago

      Thanks.

      This is useful as I didn’t really know what “transcoding videos” meant and why I might need to be concerned with it.

      I now know that it the process of converting a video from its original format, resolution, or bitrate. And that this can be important if one of my friends is using a device that say isn’t 4K compatible and all my content is 4K.

      I know you probably already know this, but I thought I would add for others that may stumble across this.

      • CCMan1701A@startrek.website
        link
        fedilink
        English
        arrow-up
        3
        ·
        10 months ago

        I avoided transcoding by making sure to only host videos compatible with all clients. Also, I will spend the time to reencode codes that are too large for my taste. Which happens after a rip of uhd disks.

        H265 with slow preset really works wonders for non-grainy film. AV1 is what you have to use when there is grain.

  • DaGeek247@fedia.io
    link
    fedilink
    arrow-up
    4
    ·
    10 months ago

    I would like to be able to let friends connect from outside my house to stream media and allow them access so they can add films and the server goes off and finds them, extracts them, and adds them to the media server.

    This is going to be the second most expensive part of this process (the first being storage). Direct streaming for one person can be done on anything that can play your chosen video quality. Streaming for other people will require at least a video card, and a processor that can handle multiple people, as well as the extra storage that other people will want to use. You can use a single pi4 for one person, but you’ll want to look at a desktop PC with a modern-ish graphics card (for the encode) if you want to share with other people.

  • freebee@sh.itjust.works
    link
    fedilink
    English
    arrow-up
    1
    ·
    10 months ago

    Depends on numbers of simultaneous streaming capability you need i think. I recently bought a 50 € used esprimo “office computer” and it runs very well. I put a 50 € 1TB nvme SSD+ ~200 € 4TB external ssd and a 30 € wifi pci card and good to go, ± 330 € total… Used an old 1TB HDD i still had for back-up. It wouldn’t suffice for dozens of simultaneous streams with transcoding, but it runs my <5 users jellyfin+deluge+nextcloud very well.