Skip to content

ashvina/teeny

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

teeny

Teeny is an Apache Geode (incubating) based URL shortner application.

This application is intended to server as an introduction to Apache Geode basic concepts.

Requirements

On Linux use package managers available for most distributions.
On Mac use boot2docker or Kitematic

Then install docker-compose with sudo pip install -U docker-compose

Building and running the application

  1. Create the teeny client container: docker build -t geode/teeny-client .
  2. Start Apache Geode cluster
  • You can either do it using GFSH or through Docker. docker-compose up If you are using Docker on this step it may take a while depending on your internet connection.

This step will clone this repository and build the application, which consists of a SpringBoot application that has a single Servlet.

Otherwhise if you're running locally without Docker, clone this repository and build an executable jar:

mvn clean package

And start the client application with:

java -jar /teeny/target/teeny-0.1-SNAPSHOT.war

Creating Apache Geode regions

With the cluster up and running execute:

docker exec -it $(docker ps |grep -i locator|awk '{print $1}') data/setup.sh

This is going to grab the container ID for the current locator instance and execute a shell script inside the container. The shell script will create both regions required for the application.

Calling the application

  1. To create a teeny curl -X POST http://localhost:8080?url=yahoo.com
  2. To lookup a teeny curl http://localhost:8080/<return_value_from_create>
  3. To delete a teeny curl -X DELETE http://localhost:8080/<return_value_from_create>
  4. To list of most poplular teenyies curl http://localhost:8080

Scale using Docker & Apache Geode (incubating)

Given that it's easy to scale an Apache Geode cluster you can easily leverage docker-compose functionalities to add more containers and more nodes to any component of the solution.

For instance in order to add more instances of the teeny client just execute:

docker-compose scale client=2

To add more Apache Geode servers:

docker-compose scale server=2

Accessing Apache Geode RESTful API

You can reach Swagger interace that's part of Geode REST service using the following URL:

http://192.168.99.100:32788/gemfire-api/docs/index.html

About

Geode demo app

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published