-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathwrapper_script.sh
More file actions
executable file
·38 lines (34 loc) · 1.21 KB
/
wrapper_script.sh
File metadata and controls
executable file
·38 lines (34 loc) · 1.21 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#!/bin/bash
# https://docs.docker.com/config/containers/multi-service_container/
# Start the first process
/usr/bin/redis-server --daemonize yes
status=$?
if [ $status -ne 0 ]; then
echo "Failed to start /usr/bin/redis-server: $status"
exit $status
fi
# # Start the second process
# ./my_second_process -D
# status=$?
# if [ $status -ne 0 ]; then
# echo "Failed to start my_second_process: $status"
# exit $status
# fi
# Naive check runs checks once a minute to see if either of the processes exited.
# This illustrates part of the heavy lifting you need to do if you want to run
# more than one service in a container. The container exits with an error
# if it detects that either of the processes has exited.
# Otherwise it loops forever, waking up every 60 seconds
while sleep 15; do
ps aux |grep redis-server |grep -q -v grep
PROCESS_1_STATUS=$?
# ps aux |grep my_second_process |grep -q -v grep
# PROCESS_2_STATUS=$?
# If the greps above find anything, they exit with 0 status
# If they are not both 0, then something is wrong
# if [ $PROCESS_1_STATUS -ne 0 -o $PROCESS_2_STATUS -ne 0 ]; then
if [ $PROCESS_1_STATUS -ne 0 ]; then
echo "One of the processes has already exited."
exit 1
fi
done