Supongamos que tengo un front-end que es principalmente una aplicación de una sola página escrita usando angular, gruñido y bower. Y supongamos que tengo un back-end, que es principalmente una API REST que se encuentra encima de un ORM, que almacena / recupera objetos de una base de datos, usando cosas como gruñir, expresar y secuenciar.
La aplicación angular hace todas las cosas visuales que ve el usuario, pero lo hace al ser una GUI sobre los servicios proporcionados por el back-end.
Sería deseable separarlos en dos bases de código diferentes, para permitir el desarrollo independiente, el control de versiones, la integración continua, el impulso al desarrollo, etc.
Mi pregunta es, ¿qué métodos existen para hacerlo limpiamente? ¿Hay mejores prácticas recomendadas para javascript de pila completa?
La opción n. ° 1 parece ser un monolito, es decir, "no los separe". La ventaja es que la cadena de construcción es simple y todo está en un solo lugar, pero parece que hay muchas desventajas; más difícil de versionar de forma independiente, un frente roto significa una parte posterior no desplegable, y así sucesivamente.
La opción n. ° 2 parece ser un cuasi-monolito, donde la cadena de compilación del front-end resulta en escribir un montón de archivos en el back-end. El dist
directorio en el front-end se referiría a algún directorio en el back-end, por lo que esencialmente cuando el front end minimiza, uglifica, etc., termina publicando en el back-end, que ejecuta todo.
La opción n. ° 3 parece una separación total: el front-end y el back-end ejecutan sus propios servidores en diferentes puertos, y son proyectos completamente separados. El inconveniente parece ser que deben configurarse para conocer los puertos de cada uno; el back-end debe permitir CORS desde el front-end, y el front-end necesita saber dónde se espera que estén todos esos puntos finales.
La opción n. ° 4 podría ser usar algo como docker-compose para armar todo.
Estoy seguro de que hay otras opciones. ¿Cuál es la mejor práctica recomendada?