구성
환경 변수
사용법
Logto는 환경 변수를 다음 순서로 처리합니다:
- 시스템 환경 변수
- 프로젝트 루트의
.env
파일 (dotenv 형식 준수)
따라서 시스템 환경 변수가 .env
의 값을 덮어씁니다.
변수
주의:
프로젝트 루트에서 npm start
로 Logto를 실행하면, NODE_ENV
는 항상 production
입니다.
기본값에서 protocol
은 HTTPS 설정에 따라 http
또는 https
가 됩니다.
Key | Default Value | Type | Description |
---|---|---|---|
NODE_ENV | undefined | 'production' | 'test' | undefined | Logto가 실행되는 환경 유형입니다. |
PORT | 3001 | number | Logto가 수신 대기하는 로컬 포트입니다. |
ADMIN_PORT | 3002 | number | Logto Admin Console이 수신 대기하는 로컬 포트입니다. |
ADMIN_DISABLE_LOCALHOST | N/A | string | boolean | number | Admin Console의 포트를 비활성화하려면 1 또는 true 로 설정하세요. ADMIN_ENDPOINT 가 설정되지 않은 경우, Admin Console이 완전히 비활성화됩니다. |
DB_URL | N/A | string | Logto 데이터베이스를 위한 Postgres DSN입니다. |
HTTPS_CERT_PATH | undefined | string | undefined | 자세한 내용은 HTTPS 활성화를 참조하세요. |
HTTPS_KEY_PATH | undefined | string | undefined | 위와 동일합니다. |
TRUST_PROXY_HEADER | false | boolean | 위와 동일합니다. |
ENDPOINT | 'protocol://localhost:$PORT' | string | 온라인 테스트 또는 프로덕션을 위해 사용자 지정 도메인으로 URL을 지정할 수 있습니다. 이는 OIDC 발급자 식별자의 값에도 영향을 줍니다. |
ADMIN_ENDPOINT | 'protocol://localhost:$ADMIN_PORT' | string | 프로덕션을 위해 사용자 지정 도메인으로 URL을 지정할 수 있습니다 (예: ADMIN_ENDPOINT=https://admin.domain.com ). 이는 Admin Console 리디렉션 URI의 값에도 영향을 줍니다. |
CASE_SENSITIVE_USERNAME | true | boolean | 사용자 이름의 대소문자 구분 여부를 지정합니다. 이 값을 변경할 때는 주의하세요. 기존 데이터베이스 데이터가 자동으로 조정되지 않으므로 수동으로 관리해야 합니다. |
SECRET_VAULT_KEK | undefined | string | Secret Vault에서 데이터 암호화 키 (DEK)를 암호화하는 데 사용되는 키 암호화 키 (KEK)입니다. Secret Vault가 제대로 작동하려면 필수입니다. base64로 인코딩된 문자열이어야 하며, AES-256 (32바이트)을 권장합니다. 예시: crypto.randomBytes(32).toString('base64') |
HTTPS 활성화
Node 사용 시
Node는 HTTPS를 기본적으로 지원합니다. Node를 통해 HTTPS를 활성화하려면 반드시 HTTPS_CERT_PATH
와 HTTPS_KEY_PATH
를 모두 제공해야 합니다.
HTTPS_CERT_PATH
는 HTTPS 인증서의 경로를, HTTPS_KEY_PATH
는 HTTPS 키의 경로를 의미합니다.
HTTPS 프록시 사용 시
또 다른 일반적인 방법은 Node 앞에 HTTPS 프록시(Nginx 등)를 두는 것입니다.
이 경우, 프록시 헤더 필드를 신뢰할지 여부를 나타내는 TRUST_PROXY_HEADER
를 true
로 설정하는 것이 좋습니다. Logto는 이 값을 Koa 앱 설정에 전달합니다.
이 필드를 언제 구성해야 하는지에 대해서는 TLS 오프로딩 프록시 신뢰하기를 참조하세요.
데이터베이스 설정
너무 많은 환경 변수를 관리하는 것은 비효율적이고 유연하지 않으므로, 대부분의 일반 설정은 데이터베이스 테이블 logto_configs
에 저장됩니다.
이 테이블은 간단한 키-값 저장소이며, 키는 다음과 같이 열거할 수 있습니다:
Key | Type | Description |
---|---|---|
oidc.cookieKeys | string[] | 서명 쿠키 키의 문자열 배열입니다. |
oidc.privateKeys | string[] | OIDC JWT 서명을 위한 개인 키 내용의 문자열 배열입니다. |
지원되는 개인 키 유형
- EC (P-256, secp256k1, P-384, P-521 곡선)
- RSA
- OKP (Ed25519, Ed448, X25519, X448 하위 유형)