Amazon S3
Bu belge, Amazon S3'ü LibreChat için bir dosya depolama arka ucu olarak ayarlamaya yönelik talimatları sağlar.
Amazon S3, LibreChat için bir dosya depolama arka ucu olarak kullanılabilen ölçeklenebilir ve güvenli bir nesne depolama hizmetidir. S3 bucket'ınızı yapılandırmak için şu adımları izleyin.
1. Bir AWS Hesabı Oluşturun ve Bir IAM Kullanıcısı Yapılandırın (veya IRSA Kullanın)
Seçenek A: Açık Kimlik Bilgileri ile bir IAM Kullanıcısı Kullanma
-
AWS'de oturum açın:
- AWS Management Console sayfasını açın ve hesabınızla giriş yapın.
-
Bir IAM Kullanıcısı Oluşturun veya Mevcut Birini Kullanın:
- IAM (Identity and Access Management) bölümüne gidin.
- Programmatic Access (Programatik Erişim) ile yeni bir IAM kullanıcısı oluşturun veya mevcut olanı seçin.
- Uygun bir politika ekleyin (örneğin,
AmazonS3FullAccessveya sınırlı S3 izinlerine sahip özel bir politika). - Kullanıcıyı oluşturduktan sonra bir AWS_ACCESS_KEY_ID ve AWS_SECRET_ACCESS_KEY alacaksınız. Bunları güvenli bir şekilde saklayın.
Seçenek B: Kubernetes'te IRSA (IAM Roles for Service Accounts) Kullanımı
LibreChat'i Kubernetes üzerinde (örneğin EKS'de) dağıtıyorsanız, açık kimlik bilgileri sağlamanıza gerek kalmadan pod'larınıza AWS izinleri atamak için IRSA kullanabilirsiniz. IRSA kullanmak için:
- Bir Güven İlkesi (Trust Policy) Oluşturun EKS hizmet hesabınız için (aşağıdaki örnek):
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "Federated": "arn:aws:iam::{AWS_ACCOUNT}:oidc-provider/oidc.eks.us-east-1.amazonaws.com/id/{EKS_OIDC}" }, "Action": "sts:AssumeRoleWithWebIdentity", "Condition": { "StringEquals": { "oidc.eks.us-east-1.amazonaws.com/id/{EKS_OIDC}:sub": "system:serviceaccount:librechat:librechat", "oidc.eks.us-east-1.amazonaws.com/id/{EKS_OIDC}:aud": "sts.amazonaws.com" } } } ] } - Bir Politika Oluşturun ve gerekli S3 izinlerini tanımlayın (aşağıdaki örnekte olduğu gibi):
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "VisualEditor0",
"Effect": "Allow",
"Action": [
"s3:PutObject",
"s3:GetObjectAcl",
"s3:GetObject",
"s3:ListBucket",
"s3:DeleteObject"
],
"Resource": [
"arn:aws:s3:::my-example-librechat-bucket/*",
"arn:aws:s3:::my-example-librechat-bucket"
]
}
]
}- Kubernetes ServiceAccount'ınızı notlandırın:
LibreChat pod'larınızın IRSA için notlandırılmış bir hizmet hesabı kullandığından emin olun. Bu sayede, uygulamanızdaki AWS SDK (güncellenmiş S3 başlatma kodumuzu kullanarak), AWS kimlik bilgileri için ortam değişkenlerine ihtiyaç duymadan IRSA tarafından sağlanan geçici kimlik bilgilerini otomatik olarak kullanacaktır.
2. Bir S3 Kovası (Bucket) Oluşturun
- S3 Konsolunu açın:
- Amazon S3 konsoluna gidin.
- Yeni Bir Bucket Oluşturun:
- "Create bucket" öğesine tıklayın.
- Bucket Name: Benzersiz bir ad girin (örneğin,
mylibrechatbucket). - Bölge: Kullanıcılarınıza en yakın AWS bölgesini seçin (örneğin,
us-east-1veyaeu-west-1). - Yapılandırma Seçenekleri: Gerektiğinde diğer seçenekleri ayarlayın, ardından "Create bucket" düğmesine tıklayın.
3. Ortam Değişkenlerinizi Güncelleyin
Eğer IRSA kullanmıyorsanız, projenizin kök dizinindeki .env dosyanızı oluşturun veya aşağıdaki yapılandırma ile güncelleyin:
AWS_ACCESS_KEY_ID=your_access_key_id
AWS_SECRET_ACCESS_KEY=your_secret_access_key
AWS_REGION=your_selected_region
AWS_BUCKET_NAME=your_bucket_name
AWS_ENDPOINT_URL=https://your_endpoint_url
# AWS_FORCE_PATH_STYLE=false- AWS_ACCESS_KEY_ID: IAM kullanıcınızın erişim anahtarı.
- AWS_SECRET_ACCESS_KEY: IAM kullanıcınızın gizli anahtarı.
- AWS_REGION: S3 paketinizin bulunduğu AWS bölgesi.
- AWS_BUCKET_NAME: Oluşturduğunuz S3 bucket'ının adı.
- AWS_ENDPOINT_URL: (İsteğe bağlı) Özel AWS endpoint URL'si. MinIO, Cloudflare R2, Hetzner Object Storage, Backblaze B2 ve IDrive e2 gibi S3 uyumlu hizmetler için gereklidir.
https://a7g8.da.idrivee2-32.comgibi URL şemasını dahil edin;http://veyahttps://içermeyen değerler, dosyalar akış halindeykenInvalid URLhatasına neden olabilir. - AWS_FORCE_PATH_STYLE: (İsteğe bağlı) Sanal barındırma stili (
bucket.endpoint/key) yerine yol stili (endpoint/bucket/key) URL'leri gerektiren sağlayıcılar içintrueolarak ayarlayın. Hetzner Object Storage, MinIO ve SSL sertifikaları bucket alt alan adlarını kapsamayan benzer sağlayıcılar için gereklidir. AWS S3 veya Cloudflare R2 için gerekli değildir. Varsayılan:false.
Kubernetes üzerinde IRSA kullanıyorsanız, ortamınızda AWS_ACCESS_KEY_ID ve AWS_SECRET_ACCESS_KEY değerlerini ayarlamanıza gerek yoktur. AWS SDK, geçici kimlik bilgilerini pod'unuza atanan hizmet hesabı (service account) aracılığıyla otomatik olarak alacaktır. AWS_REGION ve AWS_BUCKET_NAME değerlerinin hala sağlandığından emin olun.
4. LibreChat'i Amazon S3 Kullanacak Şekilde Yapılandırın
Uygulamanın dosya yönetimi için Amazon S3 kullanması gerektiğini belirtmek üzere LibreChat yapılandırma dosyanızı (librechat.yaml) güncelleyin:
version: 1.3.11
cache: true
fileStrategy: 's3'Görsel varlıklar için S3 önceden imzalanmış URL'lerin süresi dolar
S3, dosyaları bir CDN üzerinden sunmaz. LibreChat, S3 dosyalarına, yapılandırılabilir bir sona erme süresine (S3_URL_EXPIRY_SECONDS) sahip geçici imzalı belirteçler olan presigned URL'ler aracılığıyla erişir. AWS, IAM kullanıcı kimlik bilgileri için presigned URL ömrünü 7 günle, geçici kimlik bilgileri (IRSA gibi STS/IAM rolleri) kullanıldığında ise sadece birkaç saatle sınırlar. Bir URL'nin süresi dolduğunda, referans verdiği görsel veya avatar, sayfa yenilenip yeni bir URL oluşturulana kadar arayüzde bozuk görünecektir.
LibreChat'teki yenileme mantığı her görsel yüzey için tutarlı bir şekilde uygulanmamaktadır. Örneğin, liste tarzı endpoint'ler depolanmış URL'leri döndürebilirken, detay endpoint'leri bunları yeniler. Bu durum, model seçicide ve sohbet arayüzünde bozuk avatar görsellerinin görünmesine neden olabilir. Tam bağlam için ilgili tartışmaya göz atın.
S3, kısa ömürlü önceden imzalanmış indirme URL'lerinin uygun olduğu belge depolama (PDF'ler, metin dosyaları, kod) için oldukça uygundur. Arayüz genelinde kalıcı olarak görüntülenmesi gereken görseller ve avatarlar için CloudFront with S3 veya Firebase kullanın ya da yalnızca bu türleri CDN destekli bir stratejiye yönlendirmek için fileStrategies yapılandırmasını yapın:
fileStrategies:
avatar: 'cloudfront'
image: 'cloudfront'
document: 's3'Özet
- Bir AWS Hesabı ve IAM Kullanıcısı Oluşturun (veya IRSA yapılandırın):
- Geleneksel dağıtımlar için programatik erişime sahip bir IAM kullanıcısı oluşturun ve erişim anahtarlarınızı edinin.
- Kubernetes dağıtımları için (örneğin EKS üzerinde), pod'larınızın geçici kimlik bilgilerini otomatik olarak alabilmesi için IRSA'yı yapılandırın.
- S3 Kovası Oluşturun:
- Bir kova (bucket) oluşturmak için Amazon S3 konsolunu kullanın ve benzersiz bir ad ile bölge seçin.
- Ortam Değişkenlerini Güncelleyin:
- IRSA kullanmıyorsanız:
.envdosyanızdaAWS_ACCESS_KEY_ID,AWS_SECRET_ACCESS_KEY,AWS_REGIONveAWS_BUCKET_NAMEdeğerlerini ayarlayın. - IRSA için: yalnızca
AWS_REGIONveAWS_BUCKET_NAMEdeğerlerini ayarlayın; pod'unuzun hizmet hesabının doğru şekilde etiketlendiğinden (annotated) emin olun.
- LibreChat'i yapılandırın:
librechat.yamlyapılandırma dosyanızdafileStrategydeğerini"s3"olarak ayarlayın veya belgeleri S3'te tutarken görselleri ve avatarları CloudFront üzerinden göndermek içinfileStrategieskullanın.
Bu adımlarla, LibreChat uygulamanız dosya yükleme, indirme ve silme işlemlerini yönetmek için Amazon S3'ü kullanacaktır. Ayrıca, IRSA desteği sayesinde uygulamanız, uzun süreli AWS kimlik bilgilerini gömmeye gerek kalmadan Kubernetes üzerinde güvenli bir şekilde çalışabilir.
Not
AWS kimlik bilgilerinizin her zaman güvende kaldığından emin olun. Bunları herkese açık bir depoya (repository) işlemeyin (commit). IAM politikalarını gerektiği şekilde en az yetki ilkesine (principle of least privilege) uyacak şekilde ayarlayın.
Bu rehber nasıl?