Highly opinionated server setup to cater to my needs
NOTE: If things dont work for some reason, try restarting and seeing if that fixes it.
Probably get a VM from Oracle Always Free Tier stuff.
Use your own server
-
https://linuxize.com/post/how-to-enable-ssh-on-ubuntu-18-04/
sudo apt update sudo apt install openssh-server sudo systemctl enable ssh sudo systemctl start ssh sudo ufw enable sudo ufw allow ssh
-
This is to make sure it doesnt turn off mid install or when idle. If its a laptop, make sure power off when lid is closed is also turned off.
You can do this via the UI or refer to this stackoverflow post.
-
ssh-keygen -t ed25519 -C "primary-key" file ~/.ssh/id_ed25519.pub ssh-copy-id -p <ssh-port> <remote-user>@<server-ip>
If youre using a machine that only allows for publickey auth, then you can upload your key that you just generated with the following command
ssh-copy-id -i ~/.ssh/id_ed25519.pub -o 'IdentityFile ~/.ssh/<your-existing-private-key-for-access>.key' -p <ssh-port> <remote-user>@<server-ip>
-
sudo apt update sudo apt install software-properties-common sudo add-apt-repository --yes --update ppa:ansible/ansible sudo apt install ansible ansible-galaxy collection install kubernetes.core
-
At the very least, search for the items with tags
# FILL OUT
-
- This is if you use CloudFlare for your domain name and want the public IP updated automatically every set amount of time incase it is changed on the server.
- NOTE: Make sure the services installed in this dont overlap with any existing implied DNS entries you may have (keep this in mind if you see any weird behaviour, im not an expert here and im too tired to think about this at the moment)
- Register your domain name on CloudFlare
- Go to the main CloudFlare page
- Then
Websites
- Then select the relevant
Zone
(basically the website you used in thegroup_vals/all
file) - Go to the
Overview
page- On the right side you can see the
Zone ID
- Put this in the
group_vars/all
file - Here you can also see the link to the API token page
- On the right side you can see the
- Go to the
DNS
page-
Put in the following records (REQUIRED)
Type Name Content Proxy Status TTL A
<YOUR_DOMAIN_NAME>
<YOUR_PUBLIC_IP>
DNS only
Auto
A
*.<YOUR_DOMAIN_NAME>
<YOUR_PUBLIC_IP>
DNS only
Auto
-
Now you can also use
<YOUR_DOMAIN_NAME>
in thegroup_vars/all
file instead of the server's IP address
-
- Create a Custom API token from the api-tokens page with the following permissions and include the specific
Zone
(or website) fromZone Resources
section- To edit DNS entries
Zone:DNS:Edit
- To read
Zone
informationZone:Zone:Read
- Put this token/key in the
group_vars/all
file
- To edit DNS entries
- If not needed, remove the line below line from
setup.yaml
- import_playbook: install-and-configure-cloudflare-dns-updater-service.yaml
-
-
- Expose (port forward on your router) ports for the services you wish to have available externally based on the list here.
-
./run.sh
- You can add
-vvvv
to get more verbose output
-
-
- Add the recommended dashboards (Make sure you select the correct job in the variables section, you can default to
kubernetes-service-scraper
) - Would recommend adding a panel with the following query as it is useful to monitor pods as well
- For average
avg(irate(container_cpu_usage_seconds_total[2m])) by (pod,container)
- For average
- You can find information on how to use Loki in Grafana here
- Add the recommended dashboards (Make sure you select the correct job in the variables section, you can default to
-
- Initial setup is just following on-screen instructions.
- If asked to select server, delete it and refresh the page.
- Point Jellyfin to use the directories mentioned in the playbooks for shows, movies, music and books.
- By default, on the Jellyfin pod, the directories it will be:
/media/data/shows /media/data/movies /media/data/music /media/data/books
- By default, on the Jellyfin pod, the directories it will be:
- Add any other config required.
- Recommend setting up the Open Subtitles plugin which requires creating an account on their website.
- For Hardware acceleration go to
Admin > Dashboard > Playback
- Enable
Hardware acceleration
- Select
Video Acceleration API (VAAPI)
which is setup already to use the integrated Intel GPU. Not tested with anything else (like a dedicated AMD/Nvidea GPU)- You should see CPU usage drop and GPU usage go up, disable it if you dont or troubleshoot.
- You can use the
intel-gpu-tools
package to monitor (notice GPU usage when hardware encoding is enabled, and no GPU usage when it is disabled) at least the intel GPU by running the command below on the host:sudo intel_gpu_top
- Select the formats for which hardware acceleration should be enabled
- Recommend not selecting
HEVC 10bit
because for some reason that breaks it
- Recommend not selecting
- Defaults to CPU/software encoding if hardware acceleration does not work for a file, I think.
- More infomarmation on their Jellyfin's page for Hardware Acceleration
- Enable
- Add any plugins you may want
- Trackt
- To track the shows you watch
- Create a Trackt account
- Go to
Admin > Dashboard > Plugins > Catalogue
- Enable Trackt
- Restart Jellyfin (Shutdown server from the
Dashboard
and k8s will restart, or delete the pod)
- Go to
Admin > Dashboard > Plugins > Trackt
- Select the user
Authorize Device
- Follow onscreen instructions
- Go to
Admin > Dashboard > Scheduled Tasks > Trackt
- Create a daily scheduled task for importing data from and exporting data to tract.tv
- Trackt
- Initial setup is just following on-screen instructions.
-
- Default login credentials are randomly generated, you need to look at ansible logs to get the default login credentials.
- Look for the substring
You can log into qBittorrent
in the logs to find the creds in the formadmin/<RANDOM_PASSWORD>
- If
<RANDOM_PASSWORD>
is not seen, that means that a password was found to be set already and that a randomly generated password was not used. Please try to remeber the password or reinstall to override configuration to use default passwords again.
- If
- Look for the substring
- Change the default login details
- Go to
Tools > Options > Web UI > Authentication
- Go to
- Set default download location to one the mentioned directories (or make sure to put it in the right directory when downloading for ease)
- Go to
Tools > Options > Downloads > Default Save Path
- Recommend using
/media/data/downloads
- Go to
- Set seeding limits
- Recommend seeding limits for when seeding ratio hits "0". It is under
Tools > Options > BitTorrent > Seeding Limits
- Recommend seeding limits for when seeding ratio hits "0". It is under
- Set torrent download/upload limits
- Recommended to keep 6 active torrents/downloads and 0 uploads. It is under
Tools > Options > BitTorrent > Torrent Queueing
- Recommended to keep 6 active torrents/downloads and 0 uploads. It is under
- Default login credentials are randomly generated, you need to look at ansible logs to get the default login credentials.
-
- Do base setup
- Set folder to be
/media/data/books
and selectYes
for it to rebuild the library if asked.
- Set folder to be
- Go to
Preferences > Sharing over the net
- Check the box for
Require username and password to access the Content server
- Check the box for
Run the server automatically when calibre starts
- Click on
Start server
- Go to the
User accounts tab
and create a user- Make a note of the credentials for use in
Readarr
setup
- Make a note of the credentials for use in
- Restart the app/pod
- You can do so by also pressing
CTRL + R
on the main screen
- You can do so by also pressing
- Check the box for
- Do base setup
-
- Default login is
admin/admin123
- Set folder to be
/media/data/books
- To enable web reading, click on
Admin
(case sensitive) on the top right- Click on the user, default is
admin
- Enable
Allow ebook viewer
- Change password to something more secure
- Save settings
- Click on the user, default is
- Default login is
-
-
Service function
Service Purpose Readarr Books Sonarr TV Shows Radarr Movies Lidarr Music -
Go to
Settings
and click onShow Advanced
-
Enable authentication
- Go to
Settings > General
- Set
Authentication
toForms (Login Page)
- Set
Authentication Required
toEnabled
- Set username and password for access
- Go to
-
Add torrent client
- Go to
Settings > Download Clients > Add > qBittorent > Custom
- Add the host:
qbittorrent
- Add the port:
10095
- Add the username:
<qBittorrent_username>
- Add the password:
<qBittorrent_password>
- Uncheck the
Remove Completed
option.- When enabled, this seems to delete the downloaded files sometimes. Not sure why.
- Go to
-
Set the root directories to be the following
-
Go to
Settings > Media Management
Service Root Directory Readarr /media/data/books/
Sonarr /media/data/shows/
Radarr /media/data/movies/
Lidarr /media/data/music/
-
Enable renaming
-
-
Adjust quality definitions
- Go to
Settings > Quality
- Set the
Size Limit
orMegabytes Per Minute
(or equivalent) to appropriate numbers- This will ensure your downloads are not "too big"
- For movies and shows,
2-3GiB/h
would usually be sufficient as thePreferred
value, and you can leave theMax
value a bit higher to ensure a better chance of download grabs
- Go to
-
Radarr/Sonarr specific config
- [EXPERIMENTAL] Enforce downloads of original language media only
- Go to
Settings > Custom Formats
- Add a new Custom Format with
Language
Condition- Set
Language: Original
- Set
Required: True
- Set
- Add a new Custom Format with
- Go to
Settings > Profiles
- Select all [relevant] profiles and set the following
Minimum Custom Format Score
to0
(sum of the custom formats scores)- Your new Custom Format's score to be
-1000
(something crazy low)
- Select all [relevant] profiles and set the following
- Go to
Settings > Media Management
- Make sure
Use Hardlinks instead of Copy
is enabled
- Make sure
- Go to
- [EXPERIMENTAL] Enforce downloads of original language media only
-
Readarr specific config
- Go to
Settings > Media Management
- Add root folder (you cannot edit an existing one)
- Set the path to be
/media/data/books/
- Enable
Use Calibre
options the the following defaults- Calibre host:
calibre-webserver
- Calibre port:
8081
- Calibre Username:
<calibre_username>
- Calibre Password:
<calibre_password>
- Calibre host:
- Set the path to be
- Enabled
Rename Books
and use the defaults
- Add root folder (you cannot edit an existing one)
- Go to
-
-
- Enable authentication
- Go to
Settings > General
- Set
Authentication
toForms (Login Page)
- Set
Authentication Required
toEnabled
- Set username and password for access
- Go to
- Add
FlareSolverr
service as a proxy, refer to this guide for help- Go to
Settings > Indexers
- Add a new proxy for
FlareSolverr
- Add a tag to it, for example
flaresolverr
- NOTE: This tag needs to be used for any indexer that needs to bypass CloudFlare and DDoS-Gaurd protection
- The default host will be
http://flaresolverr:8191/
- Add a tag to it, for example
- Go to
- Follow the official Quick Start Guide
- Add all the indexers you wish to use, some good ones listed below. Find more indexers on Prowlarr's Supported Indexers page.
- Standard
1337x Add "flaresolverr" tag LimeTorrents The Pirate Bay EZTV
- Anime
Anidex Add with higher priority, example "1", since it has good english subtitled content Add "flaresolverr" tag Bangumi Moe AniRena Nyaa.si Tokyo Toshokan
- It is recommended to use private indexers for books and music as they are harder to find otherwise
- Standard
- Add all the indexers you wish to use, some good ones listed below. Find more indexers on Prowlarr's Supported Indexers page.
- Add Sonarr, Radarr, Lidarr and Readarr to the
Settings > Apps > Application
section using the correct API token and kubernetes service names- By default prowlarr server will be:
http://prowlarr:9696
- By default the services will be:
http://sonarr:8989 http://radarr:7878 http://lidarr:8686 http://readarr:8787
- Select extra
Sync Catagories
for each application if required- I would recommend keeping the default categories for the most part
- For the apps
Sonarr
andRadarr
, it might be worthwhile using bothTV
andMovies
categories - NOTE: If you dont know what to do, add all of them for every app (comes at the cost of slower searches). But this may also result in some weird behaviour which would need troubleshooting.
- By default prowlarr server will be:
- Enable authentication
-
- Enable authentication
- Go to
Settings > General
- Under
Security
selectForm
as the form ofAuthentication
- Set username and password for access
- Go to
- Follow the official Setup Guide
- Go to
Settings > Radarr
andSettings > Sonarr
- Click on
Enable
- Fill out the details and save
-
Use the API tokens from the respective services, found under
Settings > General > Security > API Key
-
Use the kubernetes service name and port
Service Name Port radarr 7878 sonarr 8989 -
Set a suitable minimum score, probabl
70
is fine
-
- Fill out the path mappings if the directories in which data is stored is different for both services (by default both services will use the same directory to access data, so you dont need to change anything for a default install)
- Click on
- Go to
Settings > Languages
- Add a language profile and set defaults for movies and series'
- Go to
Settings > Provider
and add providers for subtitles- Decent options are:
- Opensubtitles.com
- TVSubtitles
- YIFY Subtitles
- Supersubtitles
- Decent options are:
- Go to
Settings > Subtitles
and make changes if needed - Manually add the language profile to all the scanned media after first installation
- Go to
- NOTE:
- If it doesnt work, manually restart the pod few times. It just works, not sure why. If that doesnt work, try reinstalling.
- Enable authentication
-
- One stop shop for Sonarr/Radarr requests
- Run the first time setup for Jellyfin
Choose Server Type
- Select
Jellyfin
- Select
Account sign in
- Jellyfin URL:
http://jellfin:8096
- Email Address:
<YOUR_EMAIL>
- Username:
<JELLYFIN_USERNAME>
- Password:
<JELLYFIN_PASSWORD>
- You can then login using your Jellyfin credentials
- If you do not wish to do so, set a local user password by editing your account under
Users
to login with your email ID instead
- If you do not wish to do so, set a local user password by editing your account under
- Jellyfin URL:
Configure Media Server
- Click on
Sync Libraries
- Enable all Libraries that get listed
- Also run a manual scan
- Click on
Configure Services
- Setup all the services
- Use the correct API keys, hostnames and ports for the services
Service Name Port jellyfin 8096 sonarr 8989 radarr 7878 - Quality profile can be
HD-1080p
orHD - 720/1080p
- Select the applicable root folders
- Check relevant options that suit your needs
- Use the correct API keys, hostnames and ports for the services
- Setup all the services
- Go to
Users
and either add new users or import from Jellyfin directly- Give them
Auto approve
andRequest
permissions for ease where applicable
- Give them
-
- One stop shop for Sonarr/Radarr/Lidarr requests
- Get the API keys for Jellyfin, Sonarr and Radarr
- Jellyfin
- Go to
Admin > Dashboard > API Keys
- Generate a new API key with an appropriate name
- Go to
- Sonarr/Radarr/Lidarr
- Use the API tokens from the respective services, found under
Settings > General > Security > API Key
- Use the API tokens from the respective services, found under
- Jellyfin
- Set credentials for login
- Go to
Settings
- Use the correct API keys, hostnames and ports for the services
Service Name Port jellyfin 8096 sonarr 8989 radarr 7878 lidarr 8686 - Click on the
Load Profiles
andLoad Root Folders
buttons and use the appropriate defaults as used in the services seen here. - Setup
Movies
usingRadarr
- Setup
TV
usingSonarr
- Enable the
Enable season folders
option - Enable the
V3
option
- Enable the
- Setup
Music
usingLidarr
- Setup
Media Server
usingJellyfin
- Dont forget to click on
Enable
for each of those setups as well
- Use the correct API keys, hostnames and ports for the services
- Go to
Users
- Setup additional users
- Give the following roles to trusted users for convinience
Request Tv Request Movie Request Music Auto Approve Tv Auto Approve Movie Auto Approve Music
-
- Use the kubeconfig file copied over to the current working directory by exporting it
export KUBECONFIG=<KUBECONFIG_LOCATION>
- Optionally, edit your local
~/.kube/config
and incorporate the information from the copied over kubeconfig into it - NOTE:
- The port on which kube-apiserver is forwarded to, 3001 by default, should not be exposed to the internet (i.e., should be LAN access only) because anyone will be able to access it.
- The way it is set up at the moment, the certs dont really do anything. The apiserver itself is directly accessible without any authentication.
- See issue #12).
- By default,
ansible_host
from thehosts.yaml
file is used as the IP in the kubeconfig file. It is strongly recommended that you change that to the LAN IP of the server (to not have to port forward this on your router to access it)
- Use the kubeconfig file copied over to the current working directory by exporting it
-
- Use the username and password from the
group_vars/all
file to use this as a proxy server - The address would be
<PUBLIC_IP>:<GROUP_VARS_PORT>
or<DOMAIN_NAME>:<GROUP_VARS_PORT>
or<LAN_IP>:<GROUP_VARS_PORT>
- Use the username and password from the
-
- For external access:
- The following info was retrieved by running
sudo ufw status verbose | grep -i samba
on the server which lists what ports were exposed as part ofsudo ufw allow samba
- Expose the following ports for TCP
139 445
- Expose the following ports for UDP
137 138
- The following info was retrieved by running
- To authenticate
- Thee username will be the
<ANSIBLE_USER>
you used in thehosts.yaml
file - The password will be in the
group_vars/all
file (smb.password
section).
- Thee username will be the
- In Windows, connect to it using
\\<LAN_IP>\<SHARE_NAME_FROM_GROUP_VARS_ALL>
- More information here
- For external access:
-
-
You need to create DNS entries to access the Ingress services. The following entries are recommended:
*.<DOMAIN_NAME>
<DOMAIN_NAME>
-
You can port forward the following ports on your router to gain external access. On your router:
- Set a static IP for your server (if applicable) so the router doesnt assign a different IP to the machine breaking your port-forwarding setup
- Following are some sample rules based on the
all
file defaults for port forwarding, feel free to tweak to your needs.
Service Default access Where Server port Public facing port ssh ssh <LAN_IP>
or<DOMAIN_NAME>
22 <IN_LINE_WITH_HOSTS_FILE_OR_22>
samba proxy \\<LAN_IP>\<SHARE_NAME>
or\\<DOMAIN_NAME>\<SHARE_NAME>
TCP: 139,445
, UDP:137,138
<BEST_NOT_TO_EXPOSE_THIS>
squid proxy <LAN_IP>:<GROUP_VARS_PORT>
or<DOMAIN_NAME>:<GROUP_VARS_PORT>
<IN_LINE_WITH_ALL_FILE>
<YOU_DECIDE>
grafana Ingress grafana.<DOMAIN_NAME>
8080 80 jellyfin Ingress jellyin.<DOMAIN_NAME>
8080 80 ombi Ingress ombi.<DOMAIN_NAME>
8080 80 prowlarr Ingress prowlarr.<DOMAIN_NAME>
8080 80 bazarr Ingress bazarr.<DOMAIN_NAME>
8080 80 radarr Ingress radarr.<DOMAIN_NAME>
8080 80 sonarr Ingress sonarr.<DOMAIN_NAME>
8080 80 readarr Ingress readarr.<DOMAIN_NAME>
8080 80 lidarr Ingress lidarr.<DOMAIN_NAME>
8080 80 librespeed Ingress librespeed.<DOMAIN_NAME>
8080 80 calibre-web Ingress calibre-web.<DOMAIN_NAME>
8080 80 calibre LAN <LAN_IP>:3002
(No ingress rules defined)3002 <YOU_DECIDE>
minikube LAN api-access <LAN_IP>:3001
3001 <YOU_DECIDE>
NOTE: Security is an unkown when exposing a service to the internet.
-
-