-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathtest-replication.sh
executable file
·88 lines (58 loc) · 2.59 KB
/
test-replication.sh
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#!/bin/bash
set -o errexit
set -o nounset
IMG="$1"
MASTER_CONTAINER="postgres-master"
MASTER_DATA_CONTAINER="${MASTER_CONTAINER}-data"
SLAVE_CONTAINER="postgres-slave"
SLAVE_DATA_CONTAINER="${SLAVE_CONTAINER}-data"
function cleanup {
echo "Cleaning up"
docker rm -f "$MASTER_CONTAINER" "$MASTER_DATA_CONTAINER" "$SLAVE_CONTAINER" "$SLAVE_DATA_CONTAINER" || true
}
trap cleanup EXIT
cleanup
USER=testuser
PASSPHRASE=testpass
DATABASE=testdb
echo "Initializing data containers"
docker create --name "$MASTER_DATA_CONTAINER" "$IMG"
docker create --name "$SLAVE_DATA_CONTAINER" "$IMG"
echo "Initializing replication master"
MASTER_PORT=54321
docker run -i --rm \
-e USERNAME="$USER" -e PASSPHRASE="$PASSPHRASE" -e DATABASE="$DATABASE" \
--volumes-from "$MASTER_DATA_CONTAINER" \
"$IMG" --initialize
docker run -d --name="$MASTER_CONTAINER" \
-e "PORT=${MASTER_PORT}" \
--volumes-from "$MASTER_DATA_CONTAINER" \
"$IMG"
until docker exec -i "$MASTER_CONTAINER" sudo -u postgres psql -c '\dt'; do sleep 0.1; done
MASTER_IP="$(docker inspect --format '{{ .NetworkSettings.IPAddress }}' "$MASTER_CONTAINER")"
MASTER_URL="postgresql://$USER:$PASSPHRASE@$MASTER_IP:$MASTER_PORT/$DATABASE"
echo "Creating test_before table"
docker run -i --rm "$IMG" --client "$MASTER_URL" -c "CREATE TABLE test_before (col TEXT);"
docker run -i --rm "$IMG" --client "$MASTER_URL" -c "INSERT INTO test_before VALUES ('TEST DATA BEFORE');"
echo "Initializing replication slave"
SLAVE_PORT=54322
docker run -i --rm \
--volumes-from "$SLAVE_DATA_CONTAINER" \
"$IMG" --initialize-from "$MASTER_URL" # TODO - Is this even gonna work?
docker run -d --name "$SLAVE_CONTAINER" \
-e "PORT=${SLAVE_PORT}" \
--volumes-from "$SLAVE_DATA_CONTAINER" \
"$IMG"
SLAVE_IP="$(docker inspect --format '{{ .NetworkSettings.IPAddress }}' "$SLAVE_CONTAINER")"
SLAVE_URL="postgresql://$USER:$PASSPHRASE@$SLAVE_IP:$SLAVE_PORT/$DATABASE"
# Wait for slave to come up
until docker exec -i "$SLAVE_CONTAINER" sudo -u postgres psql -c '\dt'; do sleep 0.1; done
# Create a test table now that replication has started
docker run -i --rm "$IMG" --client "$MASTER_URL" -c "CREATE TABLE test_after (col TEXT);"
docker run -i --rm "$IMG" --client "$MASTER_URL" -c "INSERT INTO test_after VALUES ('TEST DATA AFTER');"
# Give replication a little time. (Hopefully) much more than needed!
sleep 1
# Check that data is present in both tables
docker run -i --rm "$IMG" --client "$SLAVE_URL" -c 'SELECT * FROM test_before;' | grep 'TEST DATA BEFORE'
docker run -i --rm "$IMG" --client "$SLAVE_URL" -c 'SELECT * FROM test_after;' | grep 'TEST DATA AFTER'
echo "Test OK!"