Skip to content

doddatpivotal/redis-chat-app

 
 

Repository files navigation

pcf-redis-chatapp

Example architecture for building a web based chat application integrating Redis for PCF.

The Redis for PCF Chat Application (see diagram below) demonstrates how to build a web chat client using Vue.js and Socket.io on the frontend to communicate with a backend service using Node.js, Socket.io and Redis for PubSub communication.

Redis Chat Application Architecture Diagram

This repository contains sample code for the frontend web client as well as the backend service implementation. The web client is built using Vue.js for DOM manipulation and Socket.io for websocket communication to the backend service.

The backend service is implemented using Node.js and Socket.io. The Node.js service uses the ioredis.io library to communicate with redis cluster, which supports communication between the service instances using builtin PubSub features to redis.

Testing the example

The application can be tested by performing the following steps:

  1. create a redis service on your PCF environment.
  2. configure the manifest.yml based on your PCF enviroment token.
  3. push this app into Cloud Foundry.

This browser window represents one participant in the chat room. User registration and authentication are not part of the example, and participant usernames and avatars are generated at random each time the client is loaded or refreshed in the browser. Once the client is loaded in the browser, you should see a chatroom like the screenshot below:

ElastiCache Chat Application Screenshot

You can chat with other participants in the room by typing in the message box at the bottom of the screen and clicking the Send button. Messages that you type will appear in your chatroom and the chatroom of the other participants.

To simulate multiple users, you can open additional browser windows to add new participants to the chatroom. New participants are added to the list on the left. When you close a browser window, the participants are removed from the list of the other chatrooms, but the message history is retained.

Click "disconnect" button when you want to leave this chat room.

Kubernetes

Create and publish docker image

A Dockerfile at the root can be used to build a docker image with the redis chat front end.

docker build -t <user-name>/redis-chat
docker push -t <user-name>/redis-chat

Deploy to kubernetes

Prereq: Update redis-chat-web-deployment to reference the you pushed the image to. Or use dpfefferatpivotal.

You can deploy redis-chat to kubernetes using the manifest files below

kubectl apply -f k8s/redis-chat-redis-deployment.yml \
    -f k8s/redis-chat-redis-service.yml \
    -f k8s/redis-chat-web-deployment.yml \
    -f k8s/redis-chat-web-service.yml

Then query kubernetes to obtain the external url of the redis-chat app.

echo http://$(kubectl get nodes -o go-template='{{index ((index .items 0).metadata.labels) "spec.ip"}}'):$(kubectl get services/redis-chat-web-service -o go-template='{{(index .spec.ports 0).nodePort}}')

Clean up kubernetes resources

kubectl delete -f k8s/redis-chat-redis-deployment.yml \
    -f k8s/redis-chat-redis-service.yml \
    -f k8s/redis-chat-web-deployment.yml \
    -f k8s/redis-chat-web-service.yml

Setting up Kubernetes to access harbor registry

kubectl create secret docker-registry regsecret \
--docker-server="harbor.pks.haas-125.pez.pivotal.io" \
--docker-username="dpfefferatpivotal" \
--docker-password="**********" \
--docker-email="[email protected]"

Deploy to CF Commands

cf create-service p-redis dedicated-vm chat-db
cf push

About

A simple Redis chat app for use on Pivotal Cloud Foundry. Adapted from https://github.com/aws-samples/elasticache-refarch-chatapp.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 47.4%
  • HTML 39.3%
  • CSS 11.1%
  • Shell 1.2%
  • Dockerfile 1.0%