Commit d1114d6
committed
Add AWS Aurora PostgreSQL auto-discovery support
This commit implements Aurora PostgreSQL auto-discovery functionality,
mirroring the existing Aurora MySQL implementation. The feature enables
automatic detection and management of Aurora PostgreSQL cluster topology.
Key features:
- Auto-discovery using aurora_replica_status() function
- Writer detection via session_id = 'MASTER_SESSION_ID'
- Automatic failover handling with hostgroup reconfiguration
- Replication lag-based server shunning
- Dynamic server addition when new nodes join the cluster
New tables:
- pgsql_aws_aurora_hostgroups (configuration)
- runtime_pgsql_aws_aurora_hostgroups (runtime)
Configuration parameters (same as MySQL Aurora):
- writer_hostgroup, reader_hostgroup
- aurora_port (default: 5432)
- domain_name, max_lag_ms, check_interval_ms, check_timeout_ms
- writer_is_also_reader, new_reader_weight
- add_lag_ms, min_lag_ms, lag_num_checks
Files modified:
- include/ProxySQL_Admin_Tables_Definitions.h: Aurora table definitions
- include/proxysql_admin.h: incoming_aurora_hostgroups field
- lib/Admin_Bootstrap.cpp: Admin table registration
- lib/ProxySQL_Config.cpp: Config file parsing
- lib/ProxySQL_Admin.cpp: Runtime load logic
- include/PgSQL_HostGroups_Manager.h: PgSQL_AWS_Aurora_Info class
- lib/PgSQL_HostGroups_Manager.cpp: Hostgroup management implementation
- include/PgSQL_Monitor.hpp: Monitoring class definitions
- lib/PgSQL_Monitor.cpp: Monitoring thread implementation1 parent 6ee087c commit d1114d6
File tree
9 files changed
+1574
-2
lines changed- include
- lib
9 files changed
+1574
-2
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
48 | 48 | | |
49 | 49 | | |
50 | 50 | | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
51 | 60 | | |
52 | 61 | | |
53 | 62 | | |
| |||
379 | 388 | | |
380 | 389 | | |
381 | 390 | | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
382 | 418 | | |
383 | 419 | | |
384 | 420 | | |
| |||
547 | 583 | | |
548 | 584 | | |
549 | 585 | | |
| 586 | + | |
| 587 | + | |
| 588 | + | |
| 589 | + | |
| 590 | + | |
| 591 | + | |
| 592 | + | |
550 | 593 | | |
551 | 594 | | |
552 | 595 | | |
| |||
839 | 882 | | |
840 | 883 | | |
841 | 884 | | |
| 885 | + | |
| 886 | + | |
| 887 | + | |
| 888 | + | |
| 889 | + | |
| 890 | + | |
| 891 | + | |
| 892 | + | |
| 893 | + | |
| 894 | + | |
| 895 | + | |
842 | 896 | | |
843 | 897 | | |
844 | 898 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
| 12 | + | |
| 13 | + | |
12 | 14 | | |
13 | 15 | | |
14 | 16 | | |
| |||
20 | 22 | | |
21 | 23 | | |
22 | 24 | | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
23 | 38 | | |
24 | 39 | | |
25 | 40 | | |
| |||
54 | 69 | | |
55 | 70 | | |
56 | 71 | | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
57 | 84 | | |
58 | 85 | | |
59 | 86 | | |
| |||
63 | 90 | | |
64 | 91 | | |
65 | 92 | | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
66 | 101 | | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
67 | 111 | | |
68 | 112 | | |
69 | 113 | | |
| |||
74 | 118 | | |
75 | 119 | | |
76 | 120 | | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
77 | 177 | | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
78 | 181 | | |
79 | 182 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
221 | 221 | | |
222 | 222 | | |
223 | 223 | | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
224 | 229 | | |
225 | 230 | | |
226 | 231 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
200 | 200 | | |
201 | 201 | | |
202 | 202 | | |
| 203 | + | |
203 | 204 | | |
204 | 205 | | |
205 | 206 | | |
206 | 207 | | |
207 | | - | |
| 208 | + | |
208 | 209 | | |
209 | 210 | | |
210 | 211 | | |
| |||
0 commit comments