Vxero Neo
Vxero Neo è una CLI nativa SSH per distribuire app Docker su qualsiasi VPS: installa Docker e Caddy, HTTPS auto-SSL e swap senza downtime, senza agent o control plane.
Che cos'è Vxero Neo?
Vxero Neo (Neo) è uno strumento da linea di comando nativo SSH per distribuire applicazioni Docker su un VPS. Si connette al tuo server via SSH, configura Docker e Caddy, e distribuisce le tue app con HTTPS tramite auto-SSL—senza installare un agent o usare un control plane separato.
Neo gestisce anche le fasi del ciclo di vita dell'applicazione dallo sviluppo locale fino a staging e produzione. Legge la configurazione del tuo progetto locale (incluso docker-compose.yml, .env e .neo.yml), costruisce e trasferisce le immagini via SSH, esegue health check e swap del traffico senza downtime.
Caratteristiche Principali
- Flusso di deployment solo SSH (no agent, no dashboard): Neo gira sulla tua macchina locale e si connette al tuo VPS via SSH; oltre a Docker/Caddy per il runtime, non richiede tooling server-side aggiuntivo.
- Inizializzazione server automatizzata (Docker + Caddy): Durante il deployment, Neo configura Docker e Caddy sul server target così i tuoi container possono girare e ricevere traffico HTTPS.
- Da compose/config a switch live: Neo legge la tua config locale, costruisce l'immagine, la trasferisce via SSH, poi swap del traffico dopo health check; i container vecchi continuano a girare fino al switch.
- HTTPS domain istantaneo e opzioni certificate alternative: Neo può provisionare HTTPS usando sslip.io (no DNS necessario) con
--temp. Per domini reali, usa Let’s Encrypt via Caddy (dopo aver puntato il DNS), o accetta il tuo cert con--certe--key. - Generazione config e gestione environment:
neo config generatescansiona docker-compose.yml e genera automaticamente .neo.yml rilevando app service, sidecar, worker, variabili d'ambiente e volumi. Neo può anche sincronizzare env/state con comandi comeneo enveneo sync. - Deployment zero-downtime stile blue-green: Avvia i nuovi container, aspetta i health check, poi esegue lo swap del traffico così la versione precedente resta disponibile fino al cutover.
- Worker, sidecar e volumi persistenti: Definisci worker in background e sidecar in .neo.yml così si deployano alongside l'app principale con volumi e variabili d'ambiente condivisi. Dichiarare volumi in .neo.yml per persistere i dati tra redeploy.
- Multi-server e impostazioni per environment: Usa flag come
--to stagingper deployare su staging o production; ogni environment può avere il suo dominio, variabili d'ambiente e configurazione SSL.
Come Usare Vxero Neo
- Prepara il tuo progetto: Assicurati che la tua app sia descritta con
docker-compose.yml(e opzionale.env). - Genera la config di deployment di Neo: Nella directory del tuo progetto, esegui
neo config generate. Neo scansionadocker-compose.ymle scrive.neo.ymlcon i servizi rilevati come app, worker/sidecar (se definiti/rilevati), variabili d'ambiente e volumi. - Sviluppo locale (opzionale ma supportato): Usa
neo devper wrappare docker-compose con il caricamento environment di Neo da.neo.yml. - Deploy via SSH: Esegui
neo deploypuntando al tuo VPS. Neo costruisce l'immagine dal tuo Dockerfile (e config derivata da compose), la trasferisce via SSH, poi esegue health check e swap del traffico. - Abilita HTTPS: Usa
neo domain --tempper un URL HTTPS istantaneo basato su sslip.io, o usa un dominio reale con Let's Encrypt auto-SSL una volta puntato il DNS, o fornisci--cert/--keyper il tuo certificato.
Casi d'Uso
- Deployment app Docker single-VM: Distribuisci un'applicazione containerizzata per VPS (es. un web service) dove vuoi automazione basata su SSH invece di un orchestrator di cluster.
- Staging → production con config condivisa: Usa la stessa config tra environment (via generazione .neo.yml e caricamento env), deployando su staging e poi promuovendo su production con domini/SSL diversi.
- App con sidecar e worker in background: Deploya un'app principale alongside container worker e sidecar definiti in
.neo.yml, inclusi variabili d'ambiente e volumi condivisi. - Progetti che necessitano HTTPS rapido senza cambiamenti DNS: Usa
neo domain --tempper ottenere un URL HTTPS immediato per test con sslip.io, poi passa a un dominio reale quando il DNS è pronto. - Release zero-downtime per piccoli team: Esegui update stile blue-green con health check così la vecchia versione resta up fino a quando i nuovi container non sono pronti.
FAQ
-
Neo installa un agent sul mio server? No. Neo gira sulla tua macchina locale e si connette al tuo VPS via SSH. Sul server vengono configurati solo Docker e Caddy per il runtime della tua applicazione.
-
Uso già docker-compose. Come passo a Neo? Esegui
neo config generatenella directory del tuo progetto. Neo scansionadocker-compose.ymle genera automaticamente.neo.yml, poi puoi usareneo deployper distribuire l'app. -
Quali provider cloud sono supportati? Neo può distribuire su qualsiasi VPS con accesso SSH, come DigitalOcean, Hetzner, Linode, Vultr, AWS EC2, GCP e Azure. Neo distribuisce su una singola VM (non è un orchestratore di cluster multi-nodo come Kubernetes o Docker Swarm).
-
Come funziona HTTPS? Neo supporta
neo domain --tempper HTTPS istantaneo via sslip.io,neo domain app example.comper auto-SSL Let’s Encrypt dopo aver puntato il DNS, e--cert/--keyper usare il tuo certificato. -
Neo può eseguire worker in background e database? I worker possono essere dichiarati in
.neo.ymle distribuiti come container separati usando la stessa immagine, variabili d'ambiente e volumi. Per i database, Neo può eseguirli come sidecar/servizi Docker per progetti piccoli; per produzione con utenti reali, raccomanda database gestiti.
Alternative
- Script manuali di deploy Docker + Caddy: Se preferisci il controllo totale e hai già la tua automazione di deploy, puoi buildare e trasferire immagini, eseguire container e gestire Caddy/SSL da solo. Questo richiede tipicamente più effort di setup rispetto al workflow single-command di Neo.
- Docker Swarm o Kubernetes: Sono orchestratori di cluster per deploy multi-nodo. Differiscono da Neo perché mirano all'orchestrazione su cluster anziché su un singolo VPS accessibile via SSH.
- Altre pipeline CI/CD VPS-centriche: Puoi usare tool CI/CD generici per SSH su un server, buildare immagini e riavviare container. Rispetto a Neo, dovresti gestire da solo generazione config, logica di switch zero-downtime e integrazione HTTPS.
- Piattaforme container gestite: Piattaforme che gestiscono routing e TLS riducono i passi infrastrutturali. Di solito rinunciano al modello di deploy “SSH-first, senza agent/control plane” descritto per Neo.
Alternative
Falconer
Falconer è una piattaforma di conoscenza che si aggiorna da sola: scrivi, condividi e trova documentazione interna e contesto del codice in un unico posto.
OpenFlags
OpenFlags è un sistema di feature flag open source self-hosted per progressive delivery: valuta localmente via SDK e gestisci i rollout con un control plane semplice.
skills-janitor
skills-janitor esegue audit, traccia l’uso e confronta le tue skill per Claude Code con 9 azioni slash mirate, senza dipendenze.
Rectify
Rectify è una piattaforma operativa all-in-one per SaaS: monitoraggio, analytics, supporto, roadmap, changelog e gestione agenti in un’unica workspace visiva via conversazione.
GitBoard
GitBoard è un’app nativa per la barra dei menu di macOS per GitHub Projects: visualizza la kanban, filtra per stato, cerca issue e crea/assegna.
Studio CLI
Controlla le funzionalità di WordPress Studio dal terminale con Studio CLI: gestisci siti locali, crea/aggiorna/elimina preview WordPress.com e autentica.