Deployment and configuration
In the previous article, we covered the basics of getting started with Logto quickly. This article delves deeper, focusing on best practices and detailed configuration steps for deploying Logto in a production environment.
Environment variables
We use a generated preset of environment variables in our demo (docker-compose.yml), which you should replace with your own and maintain consistency across multiple Logto instances.
You can set env directly or put a .env file inside the Logto project root. If you are testing with Docker, check out the image's generated .env in /etc/logto.
Essentials
- DB_URLThe Postgres DSN for Logto database.
- PORTThe port that Logto listens to. Default- 3001.
- ENDPOINTYou may specify a URL with your custom domain for production (E.g.- ENDPOINT=https://logto.domain.com). This will also affect the value of the OIDC issuer identifier.
Enable Admin Console
- ADMIN_PORTThe port that Logto Admin Console listens to. Default- 3002.
- ADMIN_ENDPOINTYou may specify a URL with your custom domain for production (E.g.- ADMIN_ENDPOINT=https://admin.domain.com). This will also affect the value of Admin Console Redirect URIs.
Disable Admin Console
- ADMIN_DISABLE_LOCALHOSTSet it to- 1or- trueto close the port for Admin Console. With- ADMIN_ENDPOINTunset, it'll completely disable the Admin Console.
For more details about environment variables, see Configuration.
Enable Secret Vault
- To use the Secret Vault, you need to set SECRET_VAULT_KEKto a base64-encoded string of your Key Encryption Key (KEK). This is used to encrypt Data Encryption Keys (DEK) in the Secret Vault. AES-256 (32 bytes) is recommended. Example:crypto.randomBytes(32).toString('base64').
HTTPS
You may use Node.js to serve HTTPS directly or set up an HTTPS proxy / balancer in front of Node.js. See Enabling HTTPS for details.
Reverse proxy
If you want to use reverse proxy on your server, for example Nginx or Apache, you need to map 3001 and 3002 ports separately in your proxy pass settings. Assuming you are using Nginx, your Logto auth endpoint is running on port 3001, and your Logto admin console is running on 3002, put the following config in nginx.conf:
server {
  listen 443 ssl;
  server_name <your_endpoint_url>; // e.g. auth.your-domain.com
  ...
  location / {
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Proto https;
    proxy_pass http://127.0.0.1:3001;
  }
  ssl_certificate <path-to-your-certificate-for-auth-endpoint>;
  ssl_certificate_key <path-to-your-certificate-key-for-auth-endpoint>
  ...
}
Then add the similar config for your admin console:
server {
  listen 443 ssl;
  server_name <your_admin_endpoint_url>; // e.g. admin.your-domain.com
  ...
  location / {
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Proto https;
    proxy_pass http://127.0.0.1:3002;
  }
  ssl_certificate <path-to-your-certificate-for-admin-endpoint>;
  ssl_certificate_key <path-to-your-certificate-key-for-admin-endpoint>
  ...
}
Reload Nginx config to pick up the latest changes:
nginx -s reload
You are all set. Open the browser and visit https://admin.your-domain.com, you should be able to see Logto welcome page.
Containerization
For production, you may use Docker to containerize Logto. You can find the Dockerfile in the root directory of the project. If you want to run multiple instances of Logto, for instance, deploy Logto in a Kubernetes cluster, There are some additional steps you need to take.
Database setup
Prepare a Postgres database for Logto. It is strongly recommended to use Logto CLI to initialize the database.
npm run cli db seed -- --swe
Refer to the Logto CLI for more details.
Shared connectors folder
By default, Logto will create a connectors folder in the root directory of the core folder. We recommend sharing the folder between multiple instances of Logto, you need to mount the packages/core/connectors folder to the container and run npm run cli connector add -- --official to deploy the connectors.
There is a minimum example deployment for Kubernetes:
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: logto
  namespace: default
spec:
  template:
    spec:
      volumes:
        - name: connectors
          emptyDir: {}
      initContainers:
        - image: ghcr.io/logto-io/logto
          command:
            - /bin/sh
          args:
            - '-c'
            - 'npm run cli connector add -- --official'
          name: init
          volumeMounts:
            - name: connectors
              mountPath: /etc/logto/packages/core/connectors
      containers:
        - image: ghcr.io/logto-io/logto
          name: logto
          volumeMounts:
            - name: connectors
              mountPath: /etc/logto/packages/core/connectors
In this example, we create an empty directory as a volume and mount it to containers. Then we run npm run cli connector add -- --official in the init container to download the connectors. Finally, every container will share the same connectors folder with our official connectors already inside.
This is an example yaml, in order to run Logto, you need to set envs properly.
For production, you can replace the "empty dir" volume with a persistent volume, and do the "init" job by your own way, you know what you are doing!
Database alteration
Similar to connectors, the database alteration need to run in a single instance. You can use a job to run the alteration script.
CI=true environment variable is necessary when alteration is ran non-interactive.
apiVersion: batch/v1
kind: Job
metadata:
  name: alteration
specHjälpte svaret dig?
            
            
        
    
