Skip to content

nevzatseferoglu/hz-go-service

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Running Hazelcast Go Client on Kubernetes Example

  • This example shows how to run a sample proxy service which uses Hazelcast Go Client connected to the Hazelcast members in the same network and exposes itself to the outside through k8s ingress.

Table of Contents

  1. Requirements
  2. Deployment
  3. Examples
  4. Deletion of Kubernetes Resources
  5. Running Service Locally

Requirements

Deployment

The guide assumes that Docker Engine is ready and running properly. You can run it on other container and virtual machine environments, but it is not tested.

  1. Open a new terminal session and type the following commands one by one in a row to observe the service.
  2. git clone https://github.com/hazelcast/hazelcast-go-client.git
  3. cd hazelcast-go-client/examples/k8s/service
  4. minikube start --driver=docker
  5. minikube docker-env
  6. eval $(minikube -p minikube docker-env)
  7. Open another new terminal session.
    1. minikube addons enable ingress
    2. sudo minikube tunnel
  8. Go back to previous session and continue on with docker build -t example/hz-go-service .
  9. Add 127.0.0.1 hz-go-service.info at the bottom of the /etc/hosts file.
  10. chmod +x start-deployment.sh
  11. Then, ./start-deployments.sh
  12. After that point, status of all k8s resources can be examined through: kubectl get all
  13. kubectl logs pod/hazelcast-sample-0: checks whether Hazelcast members are up and running.
  14. As a last step, lets ensure that the service is up and running by the help of ingress ip resolution:
  15. curl hz-go-service.info

Examples

  • Returns properties of the service and the Hazelcast Client as a json.
     ❯ curl hz-go-service.info/config
     {
        "ServiceConfig": {
          "ServiceName": "hazelcast-go-client-proxy-service",
          "Port": 8080,
          "Timeout": 5000000000
        },
        "HazelcastClientInfo": {
          "Name": "proxy-service-go-client",
          "Running": true,
          "MapSize": 3
        }
     }%
  • Returns the value of the entry that matches with key1.
     ❯ curl 'hz-go-service.info/map?name=myDistributedMap&key=key1'
     {"Key":"key1","Value":"value1"}%
  • Returns the value of the entry that matches with key2.
     ❯ curl 'hz-go-service.info/map?name=myDistributedMap&key=key2'
     {"Key":"key2","Value":"value2"}%
  • Changes the value of existing entry that has key1 as a key of the given map through POST request.
     ❯ curl -H "Content-Type: application/json" --data-binary '{"value": "myValue"}' -X POST 'hz-go-service.info/map?name=myDistributedMap&key=key1'
     Value: myValue has been put to map: myDistributedMap successfully.
  • Returns the updated value of the entry that matches with key1.
     ❯ curl 'hz-go-service.info/map?name=myDistributedMap&key=key1'
     {"Key":"key1","Value":"myValue"}%

Deletion of Kubernetes Resources

  • ./delete-deployments.sh
  • Turn of running Minikube tunnel.

Running Service Locally

  1. Open a new terminal session.
  2. export HZ_GO_SERVICE_WITHOUT_K8S=true
  3. Open another new terminal session.
    1. hz CLI tool is need. For detailed information, here.
    2. Then, hz start: Starts a new Hazelcast cluster in local through CLI.
  4. Go back to previous session and check out Operations.

Releases

No releases published

Packages

No packages published