Service API turbo GPT-3.5 gratuit et illimité.
À propos de l'auteur »
Fonctionnalités · Exemples · Référence · Licence
mkdir freegpt35 && cd freegpt35
curl -O https://raw.githubusercontent.com/hominsu/freegpt35/main/deploy/docker-compose.yml
Ajoutez ensuite l'environnement si vous en avez besoin, pour plus de détails, consultez la partie Personnaliser suivante.
docker compose up -d
Une fois déployé, utilisez la commande suivante pour confirmer que tout fonctionne bien.
curl -X POST " http://localhost:3000/v1/chat/completions "
-H " Authorization: Bearer anything_or_your_key "
-H " Content-Type: application/json "
-d ' {
"model": "gpt-3.5-turbo",
"messages": [{"role": "user", "content": "Hello"}],
} '
{ "id" : " chatcmpl-********* " , "created" : 9999999999 , "model" : " gpt-3.5-turbo " , "object" : " chat.completion " , "choices" :[{ "finish_reason" : " stop " , "index" : 0 , "message" :{ "content" : " Hi there! How can I assist you today? " , "role" : " assistant " }}], "usage" :{ "prompt_tokens" : 1 , "completion_tokens" : 10 , "total_tokens" : 11 }}
Voici un modèle de configuration Nginx auquel vous pouvez vous référer. Pour plus d'informations sur la configuration de NGINX Docker, vous pouvez consulter cet article : 优雅地在 Docker 中使用 NGINX
upstream freegpt35 {
server 127.0.0.1:3000
}
server {
listen 80 ;
listen [::]:80;
server_name your.domain.name;
return 301 https:// $server_name$request_uri ;
}
server {
listen 443 ssl;
listen [::]:443 ssl;
server_name your.domain.name;
ssl_certificate /etc/nginx/ssl/your.domain.name/full.pem;
ssl_certificate_key /etc/nginx/ssl/your.domain.name/key.pem;
ssl_session_timeout 5m ;
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_ciphers TLS13_AES_128_GCM_SHA256:TLS13_AES_256_GCM_SHA384:TLS13_CHACHA20_POLY1305_SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305;
ssl_prefer_server_ciphers on ;
location /v1/chat/completions {
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://freegpt35;
proxy_buffering off ;
proxy_cache off ;
send_timeout 600 ;
proxy_connect_timeout 600 ;
proxy_send_timeout 600 ;
proxy_read_timeout 600 ;
chunked_transfer_encoding on ;
}
error_page 500 502 503 504 /50x.html;
}
Si vous vous abonnez à Vercel, vous pouvez essayer cette méthode de déploiement, sinon ne perdez pas votre temps, car avec le plan Hobby
, vos routes API sans serveur ne peuvent être traitées que pendant 5 secondes, et la route répond par une erreur FUNCTION_INVOCATION_TIMEOUT
.
Une fois déployé, vous pouvez tester à nouveau avec curl
curl -X POST " https://freegpt35.vercel.app/v1/chat/completions "
-H " Authorization: Bearer anything_or_your_key "
-H " Content-Type: application/json "
-d ' {
"model": "gpt-3.5-turbo",
"messages": [{"role": "user", "content": "Hello"}]
} '
{ "id" : " chatcmpl-********** " , "created" : 9999999999 , "model" : " gpt-3.5-turbo " , "object" : " chat.completion " , "choices" :[{ "finish_reason" : " stop " , "index" : 0 , "message" :{ "content" : " Hey there! How's it going? " , "role" : " assistant " }}], "usage" :{ "prompt_tokens" : 1 , "completion_tokens" : 8 , "total_tokens" : 9 }}
Vous pouvez également définir vos variables d'environnement pour certains cas spécifiques.
Variable d'environnement | Description |
---|---|
NEXT_BASE_URL | URL de base pour ChatGPT, modifiée si vous utilisez un site miroir |
NEXT_API_URL | NE LE MODIFIEZ PAS , sauf si vous savez vraiment ce que vous faites |
NEXT_API_KEY | Clé API utilisée pour l'authentification pour accéder à l'API. |
NEXT_MAX_RETRIES | Nombre maximum de tentatives pour les requêtes API en cas d'échec. |
NEXT_USER_AGENT | Chaîne de l'agent utilisateur utilisée dans les en-têtes des requêtes envoyées depuis le serveur. |
NEXT_PROXY | Activez le proxy http(s), par exemple http://127.0.0.1:7890 . Si plusieurs proxys sont nécessaires, séparez chaque proxy par , par exemple https://user:password@proxy-1:10000,https://user:password@proxy-2:10001 |
Distribué sous licence AGPL 3.0. Voir LICENSE
pour plus d’informations.