Giter Site home page Giter Site logo

dacleyra / acmeair-mainservice-java Goto Github PK

View Code? Open in Web Editor NEW

This project forked from blueperf/acmeair-mainservice-java

0.0 1.0 2.0 9.65 MB

This service contains the front end of AcmeAir Microservices.

License: Apache License 2.0

Shell 23.14% HTML 63.19% CSS 3.32% JavaScript 4.21% Dockerfile 1.75% Java 1.31% HCL 3.07%

acmeair-mainservice-java's Introduction

Acme Air Main Service - Java/Liberty

An implementation of the Acme Air Main Service for Java/Liberty. The main service primarily consists of the presentation layer (web pages) that interact with the other services.

This implementation can support running on a variety of runtime platforms including standalone bare metal system, Virtual Machines, docker containers, IBM Cloud, IBM Cloud Private, and other Kubernetes environments.

Build Instructions

Full Benchmark Installation Instructions on various docker enviornments.

alt text

Prereq *IMPORTANT*

All of these examples assume you have the acmeair-mainservice-java, acmeair-authservice-java, acmeair-bookingservice-java, acmeair-customerservice-java, and acmeair-flightservice-java directories, (and possibly others) on your docker machine in the same directory. It also assumes all applications have been built with maven.

Docker Instructions

Prereq: Install Docker, docker-compose, and start Docker daemon on your local machine

  1. cd acmeair-mainservice-java
  2. Create docker network
  • docker network create --driver bridge my-net
  1. Build/Start Containers. This will build all the micro-services, mongo db instances, and an nginx proxy.

    • docker-compose build
    • NETWORK=my-net docker-compose up
  2. Go to http://docker_machine_ip/main/acmeair

  3. Go to the Configuration Page and Load the Database

Minikube Instructions

  1. minikube docker-env
  2. eval $(minikube docker-env)
  3. minikube addons enable ingress
  4. cd acmeair-mainservice-java/scripts
  5. Build and Deploy Services ./buildAndDeployToMinikube.sh
  6. Wait a couple minutes and go to http://kubernetes_ip/acmeair
  7. Go to the Configuration Page and Load the Database

IBM Cloud Private Instructions - w/ Ingress

This doc assumes that

  • ICP is installed and configured

  • The docker env is logged into the CFC docker repo

    • docker login mycluster.icp:8500
  • kubectl and helm are attached the ICP cluster

  • You are running ICP as admin

  • maven is installed and set up to build with a full SDK.

  1. Build and push the apps
    • cd acmeair-mainservice-java/scripts
    • ./buildAndPushtoICP.sh
  2. Deploy to ICP using one of the following options:
    • Using ibm-websphere-liberty helm chart
      • ./deployChartToICP.sh
    • Using loose deployment manifests
      • ./deployToICP.sh
    • Using Microclimate
      • The AcmeAir java projects are structured to be imported and deployed using Microclimate.
  3. Wait a couple minutes and go to http://proxy_ip/acmeair
  4. Go to the Configuration Page and Load the Database
  5. Cleanup
    • Helm chart
      • ./deleteChartRelease.sh
    • Loose deployment manifests
      • ./deleteKubeObjects.sh
    • Using Microclimate
      • Delete the deployment pipeline

Microclimate Instructions

Prerequisites

  1. Import the following microservices into Microclimate with Importing projects:

  2. After you import all the microservices into Microclimate, you can deploy projects into IBM Cloud Private:

    • A.) Connect the remote Microclimate instance from your Microclimate dashboard with Connecting the local and IBM Cloud Private installations.
    • B.) Create a pipeline for each microservice with Creating a build pipeline.
    • C.) After a pipeline is created successfully, you can add deployments.
    • D.) Deploy all the microservices with Deploying applications.
    • E.) After successful deployments, you can reach the application from the http://proxy_ip/acmeair URL.
    • F.) Go to the Configuration page and click the Load the Database link.

Istio Instructions

When using Acmeair with the Istio ingress-gateway, the root context for the services need to be redefined as it does not support rewrites. Use the Dockerfile-istio file to build the images for the flight, booking, customer and auth services as it takes care of the required changes.

There is also a sample manifest file for deployment of the Acmeair application in a Istio service mesh, with all services and deployments required to run the application, including the gateway and virtual services definition. The required Mongo databases are also deployed as pods/services. You need to define the docker images to be used and inject the sidecars, either automatically or manually (with kubectl kube-inject command).

acmeair-mainservice-java's People

Contributors

dacleyra avatar jagraj avatar jdmcclur avatar jnativio avatar sishida avatar

Watchers

 avatar

Forkers

kgibm sishida

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.