项目作者: s8sg

项目描述 :
a lightweight dependency resolver
高级语言: C
项目地址: git://github.com/s8sg/linker.git
创建时间: 2017-12-13T06:23:03Z
项目社区:https://github.com/s8sg/linker

开源协议:

下载


linker

Linker is a lightweight dependency resolver

Compile

  1. gcc linker.c -lpthread -o linker

Help

  1. $ linker -h
  2. linker [opt] [event:script].. [service:event]..
  3. opt:
  4. -h : print help
  5. -r <role> : set role [deamon/waitfor]
  6. -p <port> : listen port
  7. -P <peerport> : peer port (port to send request/response)
  8. example:
  9. ./linker -p 5000 -r deamon mysql_start:/usr/local/mysql_start_check.sh
  10. ./linker -p 4000 -P 5000 -r waitfor mysql:mysql_start

How to use

Role:

Linker use two roles:
1. Daemon
2. waitfor

While running as daemon linker runs in background, to perform event check requests. On a event check request from dependent node, it executes corresponsing event check script and return response

While running as waitfor linker runs in foreground, to halt execution till all the event has successfully occured

Using with Docker Compose:

linker can be useful in a docker compose environment. Docker entrypoint script can use linker to waitfor other service in different container

For a situation where webserver container depends on mysql container, we can use docker compose features to link and depends_on. Although depends_on check if the container has started, but not the application status

to halt webserver from starting, linter can be used to waitfor mysql to start

Daemon

to check mysql status locally, linker deamon can be started in mysql container as:

  1. linker -r deamon -p 5001 -P 5000 mysql_start:./mysql_start_check.sh

Here we registering mysql_start_check.sh script for mysql_start event
mysql_start_check.sh should return zero if mysql is started, and non zero in case of error
mysql_start_check.sh script can be written as:

  1. #!/bin/bash
  2. USER=root
  3. PASS=root123
  4. mysqladmin -h remote_server_ip -u$USER -p$PASS processlist
  5. if [ $? -eq 0 ]
  6. then
  7. echo "do nothing"
  8. else
  9. ssh remote_server_ip
  10. service mysqld start
  11. fi
Waitfor

to make webserver container wait for mysql to start, linker can be started to waitfor in the entrypoint script:

  1. linker -r waitfor -p 5000 -P 5001 mysql:mysql_start

A service name can be used, which would be resolved dynamically if the containers are linked

Multiple events:

In a daemon multiple events check script can be resgisterd
For example in db service:

  1. linker -r deamon -p 5001 -P 5000 mysql_start:./mysql_start_check.sh pesql_start:./pesql_start_check.sh

At the same way, While waiting for multiple events can be resgisterd as

  1. linker -r waitfor -p 5000 -P 5001 db:mysql_start db:pesql_start