Today I decided to get an inexpensive custom domain from Namecheap and try self-hosting Lemmy. A few bucks later I was thinking, “Hey, this is going to be cake.”

I’d read some of the warnings about Oracle Cloud free tier, but figured I’d still give it a shot for hosting. I found a simple how-to for quickly getting an Ubuntu instance spun up with Docker and Portainer. A few minutes later I’m thinking, “This is so easy!”

Then I try to access Portainer using HTTPS and see my first “Your connection is not private,” warning. “No worries,” I think. “Advanced>Proceed. I’m in.”

So I run Lemmy Easy Deploy. “The lights are green, the trap is clean! Boom. Here we go!”

Nothing.

Ports seem to be open on Oracle, but no Lemmy at either 80 or 443.

“Maybe Lemmy is more particular about SSL certificates and such?” I think, for the first time getting worried.

"Err, I think that if I change my nameserver to Cloudflare I can destroy my Lemmy containers, re-run Lemmy Easy Deploy with a Cloudflare API token, and maybe fix it?

Four hours later, after repeatedly starting over, clearing my browser cache every 5 minutes, switching back and forth between nameservers, even deleting the whole Oracle Cloud VM and starting from scratch, I realize that an HTTP connection to port 443 is returning “Client sent an HTTP request to an HTTPS server.”

“Were you there before, message?” I wonder.

Lemmy friends, can you help me? Or am I better off just deleting the VM and giving up the whole idea?

    • Gamera8ID@lemm.eeOP
      link
      fedilink
      English
      arrow-up
      5
      ·
      2 years ago

      Lemmy Easy Deploy. I didn’t know where to find any tutorials for using an Oracle Cloud VM. Did the official have that?

          • Rikudou_Sage@lemmings.world
            link
            fedilink
            English
            arrow-up
            3
            ·
            edit-2
            2 years ago

            Then it should work with this: https://join-lemmy.org/docs/administration/install_docker.html

            Here are the commands, basically:

            Installing docker

            From this doc: https://docs.docker.com/engine/install/ubuntu/

            • for pkg in docker.io docker-doc docker-compose podman-docker containerd runc; do sudo apt-get remove $pkg; done
            • apt-get update
            • apt-get install ca-certificates curl gnupg
            • install -m 0755 -d /etc/apt/keyrings
            • curl -fsSL https://download.docker.com/linux/ubuntu/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg
            • chmod a+r /etc/apt/keyrings/docker.gpg
            • echo "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu "$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null
            • apt-get update
            • apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin docker-compose

            This series of commands installed an official docker repository in your system so docker itself is always up-to-date, Ubuntu gets updates like this kinda slowly.

            Installing Lemmy

            From this doc: https://join-lemmy.org/docs/administration/install_docker.html

            • mkdir /opt/lemmy
            • cd /opt/lemmy
            • wget https://raw.githubusercontent.com/LemmyNet/lemmy-ansible/main/templates/docker-compose.yml
            • wget https://raw.githubusercontent.com/LemmyNet/lemmy-ansible/main/examples/config.hjson -O lemmy.hjson
            • wget https://raw.githubusercontent.com/LemmyNet/lemmy-ansible/main/templates/nginx_internal.conf
            • wget https://raw.githubusercontent.com/LemmyNet/lemmy-ansible/main/examples/customPostgresql.conf
            • Edit all the downloaded files (for example using nano) and change everything that starts with {{ and ends with }}
            • mkdir -p volumes/pictrs
            • chown -R 991:991 volumes/pictrs
            • docker-compose up -d

            Installing webserver

            I chose Caddy, you can choose a different one but then you’ll have to check on your own.

            From this guide: https://caddyserver.com/docs/install#debian-ubuntu-raspbian

            • apt install -y debian-keyring debian-archive-keyring apt-transport-https
            • curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/gpg.key' | gpg --dearmor -o /usr/share/keyrings/caddy-stable-archive-keyring.gpg
            • curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/debian.deb.txt' | tee /etc/apt/sources.list.d/caddy-stable.list
            • apt update
            • apt install caddy
            • Edit the file /etc/caddy/Caddyfile (for example using nano /etc/caddy/Caddyfile)
            • Paste this content (replace domain.tld with your Lemmy instance domain and the 1236 with the port you have configured in the docker-compose.yml file for {{ lemmy_port }}):
            domain.tld {
                    @http {
                            protocol http
                    }
                    redir @http https://{host}{uri}
                    reverse_proxy localhost:1236
            }
            

            Hope I haven’t forgotten anything, feel free to ask.

            Edit: After all the commands, restart caddy with service caddy restart.

  • apigban@lemmy.dbzer0.com
    link
    fedilink
    English
    arrow-up
    9
    ·
    edit-2
    2 years ago

    Edit: **this will make your oci instance less secure **and will break integrations with other oci services. Do not use this in production, but ONLY for testing if the host fw rules affect your app.

    I’m currently using oraclecloud for my bots. I work in the space (cloud/systems engg) and the first thing that got me was that the oracle ubuntu instances have custom iptables in place for security.

    I’m not sure if it still has, but last i checked a year ago I had to flush iptables before I was able to use other ports. I didint really want to deal with another layer of security to manage as I was just using the arm servers for my hobby.

    It might be something worth checking, it isn’t specific to lemmy though.

    I found it unintuitive because other major cloud providers do not have any host firewall/security in place (making it easier to manage security using SG/NACL, through the console).

    • cstine@lemmy.uncomfortable.business
      link
      fedilink
      English
      arrow-up
      4
      ·
      2 years ago

      That’s not really the right approach on OCI, unfortunately: if you just flush the rules you also break a lot of their management plane.

      You’d want to modify the /etc/iptables/rules.v4 and rules.v6 files to add any rules you want to load on boot (and, of course, if you just flush the rules without saving them, then it won’t persist and a reboot will break things, again).

      It’s an arguable benefit: I’m a fan of having the security policies AND iptables sitting between me and doing something stupid, but I also spent most of the last decade dealing with literally thousands and thousands of compromised hosts that just whoopsie oopsed redis/jenkins/their database/a ftp service in a publicly accessible state, got hacked, then had the customer come crying to us asking why we didn’t keep them from blowing their foot off - which, basically, is what the OCI defaults do.

      • apigban@lemmy.dbzer0.com
        link
        fedilink
        English
        arrow-up
        1
        ·
        2 years ago

        I agree with this, what I suggested is not a best practice, I should preface my post with that.

        And I feel your pain! I get calls that are extremes, like people putting too much security where the ticket is “P1 everything is down, fly every engineer here” for an nACL/SG they created.

        The other extreme is that deliberate exposure of services to the public internet (other service providers send us an email and ask us to do something about it, but not our monkeys, shared responsibility, etc).

        • cstine@lemmy.uncomfortable.business
          link
          fedilink
          English
          arrow-up
          1
          ·
          2 years ago

          Yeah, I just mentioned it because OCI is kinda wonky and requires some static routing stuff in the iptables on the host to have the platform work as intended (which, as far as I’m aware, no other hyperscaler does), which strikes me as really really lazy engineering, but I’m just a simple computer janitor so maybe I’m wrong there.

          The most infuriating thing at my last job was people sending in a ticket freaked out that their database was stolen and ransomed, and us going ‘Well, we sent you 15 emails over the last 3 months telling you that you had the database open and improperly secured, so what exactly are you wanting us to do now?’

    • Gamera8ID@lemm.eeOP
      link
      fedilink
      English
      arrow-up
      6
      ·
      2 years ago

      Now I feel dumb.

      That didn’t work earlier.

      I just went to copy the error message I saw before and… it’s working.

      Maybe because I switched back to Namecheap’s nameserver? Or maybe because I cleared my cache again? Or maybe because I game it some more propagation time?

      Or maybe magic?

      Each potential reason seems equally likely to me.

      Thanks

      • Mechamoto@programming.dev
        link
        fedilink
        English
        arrow-up
        8
        ·
        2 years ago

        Welcome to the world of web administration

        That was my exact experience too when I first started out.

        Things that should have worked didn’t, and things that shouldn’t have worked did

        And then eventually the things that should have worked started working, with no clear indication of why they weren’t working, or why they suddenly started working.

        All I can say is that it gets easier with time

      • Mautobu@victoriagaming.ca
        link
        fedilink
        English
        arrow-up
        2
        ·
        2 years ago

        DNS can take 4 to 24 hours to replicate out. Next time, you can adjust you hosts file temporarily to test while it does it’s thing.

          • deejay4am@lemmy.world
            link
            fedilink
            English
            arrow-up
            3
            arrow-down
            1
            ·
            2 years ago

            No, most browsers will do what they’re told. At least with nginx, you have to set up a server to listen on port 80 and send a 301 permanently redirected message with the https URL.

          • pe1uca@lemmy.pe1uca.dev
            link
            fedilink
            English
            arrow-up
            2
            ·
            2 years ago

            Ah, maybe I wasn’t clear enough, caddy doesn’t need a configuration to redirect traffic from port 80 to port 443, it does it automatically: https://caddyserver.com/docs/automatic-https

            If you want to configure an http only site you need to specifically configure it in your Caddyfile.
            Here’s an example for a reverse proxy

            # We don't specify the protocol so Caddy assumes HTTPS and redirects any HTTP to secure.  
            secure.example.com { reverse_proxy :<port> }
            
            # HTTP is specified so Caddy won't redirect to port 443 nor generate a certificate.  
            http://insecure.example.com { reverse_proxy :<port> }
            
            • SheeEttin@lemmy.world
              link
              fedilink
              English
              arrow-up
              1
              ·
              2 years ago

              Yeah, I figured that’s what you meant after rereading it. Chrome at least does automatically switch to HTTPS in some cases, like where it’s seen HSTS.