forked frompostgres/postgres
- Notifications
You must be signed in to change notification settings - Fork6
Commit721f7bd
committed
libpq: Add target_session_attrs parameter.
Commit274bb2b made it possible tospecify multiple IPs in a connection string, but that's not goodenough for the case where you have a read-write master and a bunch ofread-only standbys and want to connect to whichever server is themaster at the current time. This commit allows that, by making itpossible to specify target_session_attrs=read-write as a connectionparameter.There was extensive discussion of the best name for the connectionparameter and its values as well as the best way to distinguish masterand standbys. For now, adopt the same solution as JDBC: if the userwants a read-write connection, issue 'show transaction_read_only' andrejection the connection if the result is 'on'. In the future, wecould add additional values of this new target_session_attrs parameterthat issue different queries; or we might have some way ofdistinguishing the server type without resorting to an SQL query; butright now, we have this, and that's (hopefully) a good start.Victor Wagner and Mithun Cy. Design review by Álvaro Herrera, CatalinIacob, Takayuki Tsunakawa, and Craig Ringer; code review by me. Ichanged Mithun's patch to skip all remaining IPs for a host if wereject a connection based on this new parameter, rewrote thedocumentation, and did some other cosmetic cleanup.Discussion:http://postgr.es/m/CAD__OuhqPRGpcsfwPHz_PDqAGkoqS1UvnUnOnAB-LBWBW=wu4A@mail.gmail.com1 parent4fafa57 commit721f7bd
File tree
4 files changed
+227
-51
lines changed- doc/src/sgml
- src/interfaces/libpq
4 files changed
+227
-51
lines changedLines changed: 28 additions & 1 deletion
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
811 | 811 |
| |
812 | 812 |
| |
813 | 813 |
| |
814 |
| - | |
| 814 | + | |
815 | 815 |
| |
816 | 816 |
| |
817 | 817 |
| |
| |||
1386 | 1386 |
| |
1387 | 1387 |
| |
1388 | 1388 |
| |
| 1389 | + | |
| 1390 | + | |
| 1391 | + | |
| 1392 | + | |
| 1393 | + | |
| 1394 | + | |
| 1395 | + | |
| 1396 | + | |
| 1397 | + | |
| 1398 | + | |
| 1399 | + | |
| 1400 | + | |
| 1401 | + | |
| 1402 | + | |
| 1403 | + | |
| 1404 | + | |
| 1405 | + | |
1389 | 1406 |
| |
1390 | 1407 |
| |
1391 | 1408 |
| |
| |||
7069 | 7086 |
| |
7070 | 7087 |
| |
7071 | 7088 |
| |
| 7089 | + | |
| 7090 | + | |
| 7091 | + | |
| 7092 | + | |
| 7093 | + | |
| 7094 | + | |
| 7095 | + | |
| 7096 | + | |
| 7097 | + | |
| 7098 | + | |
7072 | 7099 |
| |
7073 | 7100 |
| |
7074 | 7101 |
| |
|
Lines changed: 193 additions & 49 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
108 | 108 |
| |
109 | 109 |
| |
110 | 110 |
| |
| 111 | + | |
111 | 112 |
| |
112 | 113 |
| |
113 | 114 |
| |
| |||
300 | 301 |
| |
301 | 302 |
| |
302 | 303 |
| |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
303 | 309 |
| |
304 | 310 |
| |
305 | 311 |
| |
| |||
336 | 342 |
| |
337 | 343 |
| |
338 | 344 |
| |
| 345 | + | |
| 346 | + | |
339 | 347 |
| |
340 | 348 |
| |
341 | 349 |
| |
| |||
1025 | 1033 |
| |
1026 | 1034 |
| |
1027 | 1035 |
| |
| 1036 | + | |
| 1037 | + | |
| 1038 | + | |
| 1039 | + | |
| 1040 | + | |
| 1041 | + | |
| 1042 | + | |
| 1043 | + | |
| 1044 | + | |
| 1045 | + | |
| 1046 | + | |
| 1047 | + | |
| 1048 | + | |
| 1049 | + | |
| 1050 | + | |
| 1051 | + | |
1028 | 1052 |
| |
1029 | 1053 |
| |
1030 | 1054 |
| |
| |||
1814 | 1838 |
| |
1815 | 1839 |
| |
1816 | 1840 |
| |
| 1841 | + | |
1817 | 1842 |
| |
1818 | 1843 |
| |
1819 | 1844 |
| |
| |||
2752 | 2777 |
| |
2753 | 2778 |
| |
2754 | 2779 |
| |
2755 |
| - | |
2756 |
| - | |
2757 |
| - | |
2758 |
| - | |
2759 |
| - | |
2760 |
| - | |
2761 |
| - | |
2762 |
| - | |
2763 |
| - | |
2764 |
| - | |
2765 |
| - | |
2766 |
| - | |
2767 |
| - | |
2768 |
| - | |
2769 |
| - | |
2770 |
| - | |
2771 |
| - | |
2772 |
| - | |
2773 |
| - | |
2774 |
| - | |
2775 |
| - | |
2776 | 2780 |
| |
2777 | 2781 |
| |
2778 | 2782 |
| |
| |||
2782 | 2786 |
| |
2783 | 2787 |
| |
2784 | 2788 |
| |
2785 |
| - | |
| 2789 | + | |
| 2790 | + | |
| 2791 | + | |
| 2792 | + | |
| 2793 | + | |
| 2794 | + | |
| 2795 | + | |
| 2796 | + | |
| 2797 | + | |
| 2798 | + | |
| 2799 | + | |
| 2800 | + | |
| 2801 | + | |
| 2802 | + | |
| 2803 | + | |
| 2804 | + | |
| 2805 | + | |
| 2806 | + | |
2786 | 2807 |
| |
2787 | 2808 |
| |
2788 | 2809 |
| |
| |||
2814 | 2835 |
| |
2815 | 2836 |
| |
2816 | 2837 |
| |
| 2838 | + | |
| 2839 | + | |
| 2840 | + | |
| 2841 | + | |
| 2842 | + | |
| 2843 | + | |
| 2844 | + | |
| 2845 | + | |
| 2846 | + | |
| 2847 | + | |
| 2848 | + | |
| 2849 | + | |
| 2850 | + | |
| 2851 | + | |
| 2852 | + | |
| 2853 | + | |
| 2854 | + | |
2817 | 2855 |
| |
2818 | 2856 |
| |
2819 | 2857 |
| |
2820 | 2858 |
| |
| 2859 | + | |
| 2860 | + | |
| 2861 | + | |
| 2862 | + | |
| 2863 | + | |
| 2864 | + | |
| 2865 | + | |
| 2866 | + | |
| 2867 | + | |
| 2868 | + | |
| 2869 | + | |
| 2870 | + | |
| 2871 | + | |
| 2872 | + | |
| 2873 | + | |
| 2874 | + | |
| 2875 | + | |
| 2876 | + | |
| 2877 | + | |
| 2878 | + | |
| 2879 | + | |
| 2880 | + | |
| 2881 | + | |
| 2882 | + | |
| 2883 | + | |
| 2884 | + | |
| 2885 | + | |
| 2886 | + | |
| 2887 | + | |
| 2888 | + | |
| 2889 | + | |
| 2890 | + | |
| 2891 | + | |
| 2892 | + | |
| 2893 | + | |
| 2894 | + | |
| 2895 | + | |
| 2896 | + | |
| 2897 | + | |
| 2898 | + | |
| 2899 | + | |
| 2900 | + | |
| 2901 | + | |
| 2902 | + | |
| 2903 | + | |
| 2904 | + | |
| 2905 | + | |
| 2906 | + | |
| 2907 | + | |
| 2908 | + | |
| 2909 | + | |
| 2910 | + | |
| 2911 | + | |
| 2912 | + | |
| 2913 | + | |
| 2914 | + | |
| 2915 | + | |
| 2916 | + | |
| 2917 | + | |
| 2918 | + | |
| 2919 | + | |
| 2920 | + | |
| 2921 | + | |
| 2922 | + | |
| 2923 | + | |
| 2924 | + | |
| 2925 | + | |
| 2926 | + | |
| 2927 | + | |
| 2928 | + | |
| 2929 | + | |
| 2930 | + | |
| 2931 | + | |
| 2932 | + | |
| 2933 | + | |
| 2934 | + | |
| 2935 | + | |
| 2936 | + | |
| 2937 | + | |
| 2938 | + | |
| 2939 | + | |
| 2940 | + | |
2821 | 2941 |
| |
2822 | 2942 |
| |
2823 | 2943 |
| |
| |||
3109 | 3229 |
| |
3110 | 3230 |
| |
3111 | 3231 |
| |
| 3232 | + | |
| 3233 | + | |
3112 | 3234 |
| |
3113 | 3235 |
| |
3114 | 3236 |
| |
| |||
3120 | 3242 |
| |
3121 | 3243 |
| |
3122 | 3244 |
| |
3123 |
| - | |
3124 |
| - | |
3125 |
| - | |
3126 |
| - | |
3127 |
| - | |
3128 |
| - | |
| 3245 | + | |
| 3246 | + | |
3129 | 3247 |
| |
| 3248 | + | |
3130 | 3249 |
| |
3131 |
| - | |
| 3250 | + | |
3132 | 3251 |
| |
3133 |
| - | |
3134 |
| - | |
| 3252 | + | |
| 3253 | + | |
| 3254 | + | |
| 3255 | + | |
| 3256 | + | |
| 3257 | + | |
| 3258 | + | |
| 3259 | + | |
| 3260 | + | |
| 3261 | + | |
| 3262 | + | |
| 3263 | + | |
3135 | 3264 |
| |
| 3265 | + | |
| 3266 | + | |
| 3267 | + | |
| 3268 | + | |
| 3269 | + | |
| 3270 | + | |
| 3271 | + | |
| 3272 | + | |
| 3273 | + | |
| 3274 | + | |
| 3275 | + | |
| 3276 | + | |
| 3277 | + | |
| 3278 | + | |
| 3279 | + | |
3136 | 3280 |
| |
3137 | 3281 |
| |
3138 | 3282 |
| |
| |||
3147 | 3291 |
| |
3148 | 3292 |
| |
3149 | 3293 |
| |
| 3294 | + | |
| 3295 | + | |
| 3296 | + | |
| 3297 | + | |
| 3298 | + | |
| 3299 | + | |
| 3300 | + | |
| 3301 | + | |
| 3302 | + | |
| 3303 | + | |
| 3304 | + | |
| 3305 | + | |
| 3306 | + | |
| 3307 | + | |
| 3308 | + | |
| 3309 | + | |
| 3310 | + | |
3150 | 3311 |
| |
3151 | 3312 |
| |
3152 | 3313 |
| |
| |||
3165 | 3326 |
| |
3166 | 3327 |
| |
3167 | 3328 |
| |
3168 |
| - | |
3169 |
| - | |
3170 |
| - | |
3171 |
| - | |
3172 |
| - | |
3173 |
| - | |
3174 |
| - | |
3175 |
| - | |
3176 |
| - | |
3177 |
| - | |
3178 |
| - | |
3179 |
| - | |
| 3329 | + | |
3180 | 3330 |
| |
3181 |
| - | |
3182 |
| - | |
3183 |
| - | |
3184 |
| - | |
3185 |
| - | |
3186 |
| - | |
3187 | 3331 |
| |
3188 | 3332 |
| |
3189 | 3333 |
| |
|
Lines changed: 3 additions & 1 deletion
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
62 | 62 |
| |
63 | 63 |
| |
64 | 64 |
| |
65 |
| - | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
66 | 68 |
| |
67 | 69 |
| |
68 | 70 |
| |
|
0 commit comments
Comments
(0)