Nel mio lavoro ho bisogno di spostare alcune applicazioni Enterprise Java esistenti in AWS. Ho esaminato molte pagine su aws.amazon.com e anche su Google. Inoltre, ho cercato di passare attraverso tutte le domande relative a StackOverflow. Tutte queste cose hanno chiarito molte cose, tuttavia, sto ancora avendo una certa confusione. Ecco la nostra struttura applicativa:Configurazione Amazon Cloud per l'app Web Java EE con MySQL
- Si tratta di un'applicazione basata su Spring che utilizza Spring MVC come livello di presentazione e semplici interfacce e classi Java per la gestione della logica aziendale e dei dati.
- MySQL viene utilizzato per la persistenza.
Quindi, l'architettura dell'applicazione è abbastanza semplice. Tuttavia, il problema è che abbiamo bisogno di distribuire molte istanze di questa applicazione. Questo conteggio è attualmente 15 e può andare oltre 30. Un altro punto è che tutte queste istanze condividono un database comune.
Ora qui è quello che abbiamo bisogno di ottenere spostando a AWS:
tolleranza ai guasti- Superiore per l'applicazione. Recentemente abbiamo affrontato un problema di server/alimentazione in hosting dedicato causando alcune ore di inattività.
- Prestazioni più elevate per tutte le istanze dell'applicazione in termini di tempo di risposta e velocità effettiva.
- Tolleranza di errore superiore per MySQL. Recentemente, le istanze dell'applicazione sono cadute su uno dei nostri server a causa di alcuni componenti hardware (Hard Drive) che hanno praticamente causato l'arresto imprevisto di MySQL. L'intero file system sul disco rigido è andato in sola lettura causando il malfunzionamento delle istanze dell'applicazione ospitate su quel server.
- Ovviamente riducendo il costo totale e il sovraccarico della gestione dell'infrastruttura.
Per quanto io sono in grado di capire l'infrastruttura AWS fino ad ora, ecco quello che ci sarebbe bisogno di AWS per la nostra messa a punto:
- 4 casi, ciascuno di hosting circa 10 casi di applicazione, di alcuni EBS LINUX AMI basato su Tomcat e MySQL.
- Sto supponendo che avremmo anche bisogno di 1 istanza per tolleranza di errore per ognuna delle 4 istanze per un totale di 8 istanze in tutto.
- Tutte le istanze del server hanno circa 160 GB di EBS.
- 4 Elastic IP
- 4 Elastic Load Balancer
- altre cose come un'istantanea ecc
Ora qui sono le mie domande:
ne ho veramente bisogno di avere tale istanza del server in più (per tolleranza di errore) per ogni istanza del server principale, considerando che EBS viene automaticamente sottoposto a backup da AWS e fornirebbe nuovi EBS con gli stessi dati in caso di errore hardware?
Come posso condividere il database tra tutte le istanze del server (4x2) nello scenario sopra? Un'opzione che sto vedendo è quella di implementare il clustering MySQL tra quelle istanze del server. Diciamo che il cluster MySQL dovrebbe contenere 1 nodo di gestione, 3 nodi SQL e 4 nodi dati.Tuttavia, in questo caso la manutenzione del cluster rappresenterebbe un ulteriore sovraccarico per noi e questo potrebbe non essere accettato poiché vorremmo sbarazzarci della gestione dell'infrastruttura.
Devo avere RDS invece per il database e rimuovere istanze MySQL da tutte le estensioni del server (4x2)? In caso affermativo, avrei bisogno di acquistare istanze RDS oltre alle istanze EC2 (penso che, se devo acquistare istanze separate per RDS, il costo dell'infrastruttura totale aumenterebbe almeno del 75%.) Oppure le istanze RDS forniscono anche unità di calcolo per lo sviluppo di applicazioni riducendo così il numero totale di istanze per l'implementazione dell'applicazione?
In caso di implementazione RDS, è davvero necessario disporre di istanze EC2 basate su EBS? Se riusciamo a rimuovere il requisito EBS dalle istanze EC2 con istanze RDS, possiamo ridurre il costo totale.
Qualsiasi aiuto sarebbe apprezzato e per favore fatemi sapere se non mi è chiaro per specificare il mio problema e bisogno di maggiori chiarimenti per ogni punto.
Avrei bisogno di almeno 4 server per la tolleranza d'errore perché avremmo 4 IP diversi per 4 server principali in quanto ospitano istanze diverse di applicazione e quindi ogni server avrebbe bisogno di almeno un'istanza per la tolleranza d'errore o nessun errore tolleranza a tutti. E per RDS sto anche considerando 2 piccole istanze con implementazione Multi-AZ. – vikas
Va bene. Poiché sembra che ci siano 4 indirizzi IP "esterni", è possibile configurare 4 istanze di ELB (bilanciamento del carico elastico), una delle quali ospita ciascun indirizzo IP, e quindi aggiungere tolleranza di errore su richiesta, aggiungendo più di un nodo di elaborazione EC2 a ciascun ELB secondo necessità.Per quanto riguarda RDS, l'installazione sembra buona e Multi-AZ è sicuramente la soluzione giusta. Se la tua applicazione ha troppe letture di DB, puoi anche configurare alcune repliche di lettura. – Viccari