Qual è il flusso di lavoro di sviluppo corretto per il codice eseguito in un contenitore Docker?Flusso di lavoro di sviluppo Docker
Solomon Hykes said che il flusso di lavoro "ufficiale" comporta la creazione e l'esecuzione di una nuova immagine Docker per ogni commit Git. Questo ha senso, ma cosa succede se voglio testare una modifica prima di commetterlo al repo Git?
Mi vengono in mente due modi per farlo:
eseguire il codice su un server di sviluppo locale (ad esempio, il server di sviluppo Django). Modifica un file; test sul server di sviluppo; fare un commit Git; ricostruire l'immagine Docker con il nuovo codice; eseguire nuovamente il test sul contenitore Docker locale.
Non eseguire un server di sviluppo locale. Invece, crea ed esegui una nuova immagine Docker ogni volta che modifico un file, quindi testiamo la modifica sul contenitore Docker locale.
Entrambi gli approcci sono piuttosto inefficienti. C'è un modo migliore?
Grazie! '-v' sembra buono. Ma cosa succede dopo un cambiamento in '/ home/joe/tmp' è pronto per essere commesso? C'è un modo elegante per copiare il codice nell'immagine Docker in modo che io possa ricostruirlo e distribuirlo? –
Quindi esegui il commit e ricostruisci un'immagine. Dovresti anche considerare l'utilizzo di Jenkins per creare quelle immagini per te – Thomasleveil
Ma se il codice è presente sulla mia macchina di sviluppo locale, come faccio a "eseguirlo" in modo che venga incluso nell'immagine Docker? –