Skip to content

Latest commit

 

History

History
59 lines (43 loc) · 3.32 KB

README.md

File metadata and controls

59 lines (43 loc) · 3.32 KB

OpenShift ZNC

Many avid IRC users use an IRC bouncer, a proxy service that remains persistently connected to your preferred IRC networks and channels. Instead of connecting directly to an IRC network such as irc.example.com, you connect to a machine like bouncer.mysite.com which runs the bouncer software. The bouncer, in turn, is connected to the IRC network. When you log into your bouncer, it shows messages in your channels you may have missed while offline, as well as private messages from other users. Read more here.

ZNC is an IRC bouncer. And this git repo is a simple example of wrapping the dockerhub znc container image to run our own ZNC bouncer in OpenShift.

docker hub stats

OCP logo

How to use all of this with your apps

Sounds cool right? It is. And here's how you can use it.

If you just want to try running this ZNC image in OpenShift...

Create the app from the Docker Hub image and expose it to webtraffic

  • oc new-app dudash/openshift-znc --name=znc-demo
  • oc expose service znc-demo

Now you can access it via the route that was automatically exposed on port 6697.

Even better you can fork this repo, tweak it and run your tweaked image

Fork this repo by clicking the button on the top right of this page.

Create the app from a Docker image and expose it to webtraffic

  • oc new-app https://github.com/yourfork/openshift-znc.git --name=znc-demo
  • oc expose service znc-demo

(Note: if you are using OpenShift Online you will have to build your own docker image and new-app from that image because Dockerfile builds are currently not allowed when using OpenShift Online).

Setup the config to persist via a config map

Here's a quick way to set that up.

  1. Download the znc.conf from this repo or create your own
  2. Turn that file into a config map by running: oc create configmap znc-config --from-file=./znc.conf
  3. Pause the rollouts so we can make all our changes without rolling updates oc rollout pause dc/znc-demo
  4. Map the configmap to the deployment config by running: oc volume dc/znc-demo --add --configmap-name=znc-config --mount-path='/znc-config/configs/' --default-mode='0777'
  5. Set an ENV var to tell the scripts running in the pod to use a different config path oc env dc/znc-demo OVERRIDE_DATADIR='/znc-config'
  6. Resume deployments oc rollout resume dc/znc-demo
  7. Now OCP will re-deploy and the znc.conf file is mounted in a /znc-config/configs path on the running container

Setup the config to persist via a persistent volume

You could also consume the config map data in a PV so that changes are preserved. I'll leave this as an exercise for you to figure out. Start by reading the details here:

References