Les clés API et les délais d'attente codés en dur fonctionnent pour les prototypes. La production nécessite une configuration spécifique à l'environnement, une gestion des secrets et la possibilité de modifier les paramètres sans redéployer.
Hiérarchie de configuration
Priority (highest → lowest):
1. Environment variables ← deployment-specific overrides
2. Config file (YAML/JSON) ← version-controlled defaults
3. Application defaults ← fallback values in code
Référence de configuration complète
| Paramètre | Variable d'environnement | Par défaut | Descriptif |
|---|---|---|---|
| Clé API | CAPTCHAAI_API_KEY |
— | Obligatoire. Votre clé API CaptchaAI |
| Soumettre l'URL | CAPTCHAAI_SUBMIT_URL |
https://ocr.captchaai.com/in.php |
Point de terminaison de soumission de tâche |
| URL du sondage | CAPTCHAAI_POLL_URL |
https://ocr.captchaai.com/res.php |
Point de terminaison de l’interrogation des résultats |
| Intervalle d'interrogation | CAPTCHAAI_POLL_INTERVAL |
5 |
Secondes entre les tentatives d'interrogation |
| Nombre maximal de tentatives de sondage | CAPTCHAAI_MAX_POLLS |
60 |
Nombre maximal de tentatives d'interrogation avant expiration du délai |
| Concurrence | CAPTCHAAI_CONCURRENCY |
10 |
Nombre maximal de tâches CAPTCHA parallèles |
| Délai d'attente | CAPTCHAAI_TIMEOUT |
300 |
Délai d'expiration global en secondes |
| Procuration | CAPTCHAAI_PROXY |
— | URL proxy pour la résolution de CAPTCHA |
| URL de rappel | CAPTCHAAI_CALLBACK_URL |
— | URL du webhook pour les résultats asynchrones |
| Nouvelles tentatives | CAPTCHAAI_RETRIES |
3 |
Nouvelles tentatives sur des échecs transitoires |
| Niveau de journalisation | CAPTCHAAI_LOG_LEVEL |
info |
Verbosité de la journalisation |
Chargeur de configuration
Python
import os
import yaml
from dataclasses import dataclass, field
from pathlib import Path
@dataclass
class CaptchaAIConfig:
api_key: str = ""
submit_url: str = "https://ocr.captchaai.com/in.php"
poll_url: str = "https://ocr.captchaai.com/res.php"
poll_interval: int = 5
max_polls: int = 60
concurrency: int = 10
timeout: int = 300
proxy: str = ""
callback_url: str = ""
retries: int = 3
log_level: str = "info"
@classmethod
def load(cls, config_path=None):
"""Load config: env vars override file, which overrides defaults."""
config = cls()
# Layer 2: Config file
if config_path and Path(config_path).exists():
with open(config_path) as f:
file_config = yaml.safe_load(f) or {}
for key, value in file_config.items():
if hasattr(config, key):
setattr(config, key, value)
# Layer 1: Environment variables (highest priority)
env_map = {
"CAPTCHAAI_API_KEY": "api_key",
"CAPTCHAAI_SUBMIT_URL": "submit_url",
"CAPTCHAAI_POLL_URL": "poll_url",
"CAPTCHAAI_POLL_INTERVAL": "poll_interval",
"CAPTCHAAI_MAX_POLLS": "max_polls",
"CAPTCHAAI_CONCURRENCY": "concurrency",
"CAPTCHAAI_TIMEOUT": "timeout",
"CAPTCHAAI_PROXY": "proxy",
"CAPTCHAAI_CALLBACK_URL": "callback_url",
"CAPTCHAAI_RETRIES": "retries",
"CAPTCHAAI_LOG_LEVEL": "log_level",
}
for env_key, attr_name in env_map.items():
value = os.environ.get(env_key)
if value is not None:
# Cast to correct type
current = getattr(config, attr_name)
if isinstance(current, int):
value = int(value)
setattr(config, attr_name, value)
config.validate()
return config
def validate(self):
if not self.api_key:
raise ValueError("CAPTCHAAI_API_KEY is required")
if self.poll_interval < 1:
raise ValueError("poll_interval must be >= 1")
if self.concurrency < 1:
raise ValueError("concurrency must be >= 1")
# Usage
config = CaptchaAIConfig.load("config/captchaai.yaml")
print(f"Concurrency: {config.concurrency}, Timeout: {config.timeout}s")
Javascript
const fs = require("fs");
const yaml = require("js-yaml");
const path = require("path");
class CaptchaAIConfig {
static defaults = {
apiKey: "",
submitUrl: "https://ocr.captchaai.com/in.php",
pollUrl: "https://ocr.captchaai.com/res.php",
pollInterval: 5,
maxPolls: 60,
concurrency: 10,
timeout: 300,
proxy: "",
callbackUrl: "",
retries: 3,
logLevel: "info",
};
static envMap = {
CAPTCHAAI_API_KEY: "apiKey",
CAPTCHAAI_SUBMIT_URL: "submitUrl",
CAPTCHAAI_POLL_URL: "pollUrl",
CAPTCHAAI_POLL_INTERVAL: { key: "pollInterval", type: "int" },
CAPTCHAAI_MAX_POLLS: { key: "maxPolls", type: "int" },
CAPTCHAAI_CONCURRENCY: { key: "concurrency", type: "int" },
CAPTCHAAI_TIMEOUT: { key: "timeout", type: "int" },
CAPTCHAAI_PROXY: "proxy",
CAPTCHAAI_CALLBACK_URL: "callbackUrl",
CAPTCHAAI_RETRIES: { key: "retries", type: "int" },
CAPTCHAAI_LOG_LEVEL: "logLevel",
};
static load(configPath = null) {
let config = { ...CaptchaAIConfig.defaults };
// Layer 2: Config file
if (configPath && fs.existsSync(configPath)) {
const ext = path.extname(configPath);
const raw = fs.readFileSync(configPath, "utf8");
const fileConfig = ext === ".json" ? JSON.parse(raw) : yaml.load(raw);
config = { ...config, ...fileConfig };
}
// Layer 1: Environment variables
for (const [envKey, mapping] of Object.entries(CaptchaAIConfig.envMap)) {
const value = process.env[envKey];
if (value !== undefined) {
const attrKey = typeof mapping === "string" ? mapping : mapping.key;
const type = typeof mapping === "string" ? "string" : mapping.type;
config[attrKey] = type === "int" ? parseInt(value, 10) : value;
}
}
CaptchaAIConfig.validate(config);
return config;
}
static validate(config) {
if (!config.apiKey) throw new Error("CAPTCHAAI_API_KEY is required");
if (config.pollInterval < 1) throw new Error("pollInterval must be >= 1");
if (config.concurrency < 1) throw new Error("concurrency must be >= 1");
}
}
// Usage
const config = CaptchaAIConfig.load("config/captchaai.yaml");
console.log(`Concurrency: ${config.concurrency}, Timeout: ${config.timeout}s`);
Fichiers de configuration par environnement
# config/captchaai.yaml — base
api_key: "" # Always set via env var
concurrency: 5
poll_interval: 5
retries: 3
log_level: info
# config/captchaai.production.yaml
concurrency: 20
poll_interval: 3
timeout: 180
log_level: warning
# config/captchaai.staging.yaml
concurrency: 3
poll_interval: 5
timeout: 300
log_level: debug
Gestion des secrets
Ne stockez jamais les clés API dans les fichiers de configuration ou le contrôle de source.
| Méthode | Idéal pour | Exemple |
|---|---|---|
| Variables d'environnement | Conteneurs, CI/CD | export CAPTCHAAI_API_KEY=abc123 |
| Gestionnaire de secrets AWS | Infrastructure AWS | Récupérer au démarrage ; rotation automatique |
| Coffre HashiCorp | Multi-cloud, sur site | Secrets dynamiques avec TTL |
| Secrets des Dockers | Docker Swarm / Composer | Monté à /run/secrets/ |
Fichier .env (développement uniquement) |
Développement local | Bibliothèque dotenv ; .gitignore il |
Exemple de composition Docker
services:
captcha-worker:
image: captcha-worker:latest
environment:
- CAPTCHAAI_API_KEY=${CAPTCHAAI_API_KEY}
- CAPTCHAAI_CONCURRENCY=15
- CAPTCHAAI_LOG_LEVEL=warning
env_file:
- .env.production
Indicateurs de fonctionnalités
Basculez les fonctionnalités sans redéployer :
class FeatureFlags:
def __init__(self):
self.flags = {
"use_callback": os.environ.get("FF_USE_CALLBACK", "false") == "true",
"enable_proxy": os.environ.get("FF_ENABLE_PROXY", "true") == "true",
"max_concurrent": int(os.environ.get("FF_MAX_CONCURRENT", "10")),
}
def is_enabled(self, flag):
return self.flags.get(flag, False)
def get(self, flag, default=None):
return self.flags.get(flag, default)
Dépannage
| Problème | Parce que | Corriger |
|---|---|---|
| La clé API ne se charge pas | Var d'environnement manquant ; mauvais nom de variable | Vérifiez echo $CAPTCHAAI_API_KEY ; vérifier l'orthographe |
| Fichier de configuration ignoré | Mauvais chemin ou bibliothèque YAML manquante | Vérifiez que le fichier existe ; installer pyyaml / js-yaml |
| Produire en utilisant les paramètres de développement | Remplacement spécifique à l'environnement non appliqué | Vérifiez la priorité de la variable d'environnement ; vérifier NODE_ENV / APP_ENV |
| Secrets visibles dans les journaux | Le vidage de configuration inclut la clé API | Masquer les champs sensibles dans la sortie du journal |
FAQ
Dois-je utiliser YAML ou JSON pour les fichiers de configuration ?
YAML pour les fichiers édités par l'homme (prend en charge les commentaires). JSON pour les configurations générées par la machine ou lorsque vous souhaitez une analyse stricte.
À quelle fréquence dois-je alterner les clés API ?
Faites pivoter immédiatement en cas de compromission. Planifiez une rotation tous les 90 jours pour assurer la conformité. Utilisez des gestionnaires de secrets prenant en charge la rotation automatique.
Puis-je modifier la simultanéité sans redémarrer ?
Oui : lisez les paramètres des variables d'environnement ou d'un service de configuration sur chaque lot de tâches, pas seulement au démarrage. Cela vous permet d'ajuster la concurrence en mettant à jour la variable d'environnement et en envoyant un signal de rechargement.
Articles connexes
- Configuration de l'installation du proxy Captchaai de Socks5
- Captchaai Teams Gestion des clés API multi-utilisateurs
- Guide de configuration du proxy Captchaai
Prochaines étapes
Préparez votre configuration pour la production :commencez avec une clé API CaptchaAIet construisez à partir des modèles de configuration ci-dessus.
Guides associés :
- Sécurité des clés API et liste blanche IP
- Résolution conteneurisée Docker
- Architecture multi-régions