Les fonctions suivantes concernent la réalisation d'une connexion avec un
serveur PostgreSQL. Un programme peut avoir
plusieurs connexions ouvertes sur des serveurs à un même moment (une raison
de la faire est d'accéder à plusieurs bases de données). Chaque connexion
est représentée par un objet
PGconn
, obtenu avec la
fonction PQconnectdb
,
PQconnectdbParams
, ou PQsetdbLogin
. Notez que
ces fonctions renverront toujours un pointeur d'objet non nul, sauf peut-être
dans un cas de manque de mémoire pour l'allocation de l'objet
PGconn
. La fonction PQstatus
doit être appelée pour vérifier le code retour pour une connexion réussie
avant de lancer des requêtes via l'objet de connexion.
Si des utilisateurs non dignes de confiance ont accès à une base de
données qui n'a pas adopté une méthode sécurisée d'utilisation des
schémas, commencez chaque session en supprimant du
search_path
les schémas accessibles par tout le monde.
Il est possible de configurer le paramètre options
à
la valeur -csearch_path=
. Sinon, il est possible
d'exécuter PQexec(
tout de suite
après la connexion. Cette considération n'est pas spécifique à la
libpq ; elle s'applique à chaque
interface permettant d'exécuter des commandes SQL arbitraires.
conn
, "SELECT
pg_catalog.set_config('search_path', '', false)")
Sur Unix, la création d'un processus via l'appel système fork() avec des
connexions libpq ouvertes peut amener à des résultats imprévisibles car
les processus parent et enfants partagent les même sockets et les mêmes
ressources du système d'exploitation. Pour cette raison, un tel usage n'est
pas recommandé, alors qu'exécuter un exec
à partir
du processus enfant pour charger un nouvel exécutable est sûr.
PQconnectdbParams
Établit une nouvelle connexion au serveur de base de données.
PGconn *PQconnectdbParams(const char * const *keywords, const char * const *values, int expand_dbname);
Cette fonction ouvre une nouvelle connexion à la base de données en
utilisant les paramètres à partir des deux tableaux terminés par un
NULL
. Le premier, keywords
, est
défini comme un tableau de chaînes, chacune étant un mot-clé. Le second,
values
, donne la valeur pour chaque mot-clé.
Contrairement à PQsetdbLogin
ci-dessous, l'ensemble
des paramètres peut être étendu sans changer la signature de la fonction
donc son utilisation (ou ses versions non bloquantes, à savoir
PQconnectStartParams
et
PQconnectPoll
) est recommendée pour les nouvelles
applications.
Les mots clés actuellement reconnus sont listés dans Section 33.1.2.
Les tableaux fournis peuvent être vides pour utiliser tous les
paramètres par défaut ou peuvent contenir une ou plusieurs
configurations. Elles doivent correspondre en longueur. Le traitement
s'arrêtera à la première entrée NULL
dans le tableau
keywords
. De plus, si l'entrée
values
associée à une entrée
keywords
non NULL
est
NULL
ou une chaîne vide, cette entrée est ignorée et
le traitement continue avec la prochaine paire d'entrées des tableaux.
Quand expand_dbname
est différent de zéro, la valeur
pour le premier mot-clé dbname
est testé pour
vérifier s'il s'agit d'une chaîne de connexion.
Dans ce cas, elle sera « éclatée » dans les paramètres
individuels de connexion. La valeur est considérée être une chaîne de
connexion, plutôt qu'un nom de base, si elle contient un signe égal
(=
) ou si elle commence avec un désignateur de
schéma URI. (Vous trouverez plus de détails sur les formats de chaîne
de connexion dans Section 33.1.1.) Seule la première
occurence de dbname
est traitée de cette
façon ; tout paramètre dbname
supplémentaire est traité comme un simple nom de base.
En général, les tableaux de paramètres sont traités du début à la fin.
Si un mot clé est répété, la dernière valeur (non NULL
ou vide) est utilisée. Cette règle s'applique en particulier quand un
mot clé trouvé dans la chaîne de connexion est en conflit avec un mot
clé apparaissant dans le tableau keywords
. De ce
fait, le développeur peut déterminer si les entrées du tableau peuvent
surcharger ou être surchargées par des valeurs prises dans la chaîne de
connexion. Les entrées du tableau apparaissant avant une entrée
dbname
éclatée peuvent être surchargées par les
champs de la chaîne de connexion et, à leur tour,ces champs peuvent
être surchargés par des entrées du tableau apparaissant après
dbname
(mais, encore une fois, seulement si ces
entrées fournissent des valeurs non vides).
Après avoir traité toutes les entrées de tableau et toute chaîne de connexion éclatée, tous les paramètres de connexion restants non configurés sont remplis avec leur valeurs par défaut. Si une variable d'environnement d'un paramètre non configuré (voir Section 33.14) est configuré, sa valeur est utilisée. Si la variable denvironnement n'est pas configurée, alors la valeur par défaut interne du paramètre est utilisée.
PQconnectdb
Établit une nouvelle connexion à un serveur de bases de données.
PGconn *PQconnectdb(const char *conninfo);
Cette fonction ouvre une nouvelle connexion à la base de données en
utilisant les paramètres pris à partir de la chaîne
conninfo
.
La chaîne passée peut être vide pour utiliser tous les paramètres par défaut ou elle peut contenir un ou plusieurs paramètres, séparés par des espaces blancs. Elle peut aussi contenir une URI. Voir Section 33.1.1 pour les détails.
PQsetdbLogin
Crée une nouvelle connexion sur le serveur de bases de données.
PGconn *PQsetdbLogin(const char *pghost, const char *pgport, const char *pgoptions, const char *pgtty, const char *dbName, const char *login, const char *pwd);
C'est le prédécesseur de PQconnectdb
avec un ensemble
fixe de paramètres. Cette fonction a les mêmes fonctionnalités sauf que les
paramètres manquants seront toujours initialisés avec leur valeurs par
défaut. Écrire NULL
ou une chaîne vide pour un de ces
paramètres fixes dont vous souhaitez utiliser la valeur par défaut.
Si dbName
contient un signe =
ou
a un préfixe URI de connexion valide,
il est pris pour une chaîne conninfo
exactement
de la même façon que si elle était passée à
PQconnectdb
, et le reste des paramètres est
ensuite appliqué comme spécifié dans PQconnectdbParams
.
PQsetdb
Crée une nouvelle connexion sur le serveur de bases de données.
PGconn *PQsetdb(char *pghost, char *pgport, char *pgoptions, char *pgtty, char *dbName);
C'est une macro faisant appel à PQsetdbLogin
avec des
pointeurs nuls pour les paramètres login
et pwd
.
Elle est fournie pour une compatibilité ascendante des très vieux programmes.
PQconnectStartParams
PQconnectStart
PQconnectPoll
Crée une connexion au serveur de bases de données d'une façon non bloquante.
PGconn *PQconnectStartParams(const char * const *keywords, const char * const *values, int expand_dbname); PGconn *PQconnectStart(const char *conninfo); PostgresPollingStatusType PQconnectPoll(PGconn *conn);
Ces trois fonctions sont utilisées pour ouvrir une connexion au serveur de
bases de données d'une façon telle que le thread de votre application n'est
pas bloqué sur les entrées/sorties distantes en demandant la connexion. Le
but de cette approche est que l'attente de la fin des entrées/sorties peut se
faire dans la boucle principale de l'application plutôt qu'à l'intérieur de
PQconnectdbParams
ou PQconnectdb
, et donc l'application peut gérer des opérations en
parallèle à d'autres activités.
Avec PQconnectStartParams
, la connexion à la base
de données est faite en utilisant les paramètres à partir des tableaux
keywords
et values
, et contrôlée
par expand_dbname
, comme décrit dans
Section 33.1.2.
Avec PQconnectStart
, la connexion à la base de
données est faite en utilisant les paramètres provenant de la chaîne
conninfo
comme décrit ci-dessus pour
PQconnectdb
.
Ni PQconnectStartParams
ni
PQconnectStart
ni PQconnectPoll
ne bloqueront, aussi longtemps qu'un certain nombre de restrictions est
respecté :
Le paramètre hostaddr
doit être utilisé de façon
appropriée pour vous empêche que des requêtes DNS soient exécutées.
Voir la documentation de ce paramètre dans Section 33.1.2 pour les détails.
Si vous appelez PQtrace
, assurez-vous que l'objet de
flux dans lequel vous enregistrez les traces ne bloquera pas.
Assurez-vous que le socket soit dans l'état approprié avant d'appeler
PQconnectPoll
, comme décrit ci-dessous.
Pour commencer une demande de connexion non bloquante, appelez
PQconnectStart
ou
PQconnectStartParams
. Si le résultat est null,
alors libpq a été incapable d'allouer une
nouvelle structure PGconn
. Sinon, un pointeur
valide vers une structure PGconn
est renvoyé
(bien qu'il ne représente pas encore une connexion valide vers la base
de données). Ensuite, appelez PQstatus(conn)
. Si le
résultat vaut CONNECTION_BAD
, la tentative de
connexion a déjà échoué, généralement à cause de paramètres de
connexion invalides.
Si PQconnectStart
ou
PQconnectStartParams
réussit, la prochaine étape
est d'appeler souvent libpq de façon à ce
qu'il continue la séquence de connexion. Utilisez
PQsocket(conn)
pour obtenir le descripteur de
socket sous la connexion à la base de données. (Attention : ne
supposez pas que le socket reste le même auprès plusieurs appels à
PQconnectPoll
.) Du coup, une boucle : si le
dernier retour de PQconnectPoll(conn)
est
PGRES_POLLING_READING
, attendez que la socket soit prête
pour lire (comme indiqué par select()
, poll()
ou
une fonction système similaire). Puis, appelez de nouveau
PQconnectPoll(conn)
. En revanche, si le dernier retour de
PQconnectPoll(conn)
est
PGRES_POLLING_WRITING
, attendez que la socket soit prête
pour écrire, puis appelez de nouveau
PQconnectPoll(conn)
. Sur la première itération, si vous devez encore appeler
PQconnectPoll
, continuez comme s'il avait renvoyé
PGRES_POLLING_WRITING
. Continuez cette boucle jusqu'à ce que
PQconnectPoll(conn)
renvoie
PGRES_POLLING_FAILED
, indiquant que la procédure de
connexion a échoué ou PGRES_POLLING_OK
, indiquant le
succès de la procédure de connexion.
À tout moment pendant la connexion, le statut de cette connexion pourrait
être vérifié en appelant PQstatus
. Si le résultat est
CONNECTION_BAD
, alors la procédure de connexion a échoué ;
si, au contraire, elle renvoie CONNECTION_OK
, alors la
connexion est prête. Ces deux états sont détectables à partir de la valeur
de retour de PQconnectPoll
, décrite ci-dessus. D'autres états
pourraient survenir lors (et seulement dans ce cas) d'une procédure de
connexion asynchrone. Ils indiquent l'état actuel de la procédure de
connexion et pourraient être utile pour fournir un retour à l'utilisateur.
Ces statuts sont :
CONNECTION_STARTED
Attente de la connexion à réaliser.
CONNECTION_MADE
Connexion OK ; attente d'un envoi.
CONNECTION_AWAITING_RESPONSE
Attente d'une réponse du serveur.
CONNECTION_AUTH_OK
Authentification reçue ; attente de la fin du lancement du moteur.
CONNECTION_SSL_STARTUP
Négociation du cryptage SSL.
CONNECTION_SETENV
Négociation des paramétrages de l'environnement.
CONNECTION_CHECK_WRITABLE
Vérification que la connexion est capable de gérer des transactions en écriture.
CONNECTION_CONSUME
Consuming any remaining response messages on connection.
Notez que, bien que ces constantes resteront (pour maintenir une compatibilité), une application ne devrait jamais se baser sur l'apparition de ces états dans un ordre particulier, ou leur survenance tout court, ou sur le fait que le statut fait partie de ces valeurs documentées. Une application pourrait faire quelque chose comme ça :
switch(PQstatus(conn)) { case CONNECTION_STARTED: feedback = "Connexion en cours..."; break; case CONNECTION_MADE: feedback = "Connecté au serveur..."; break; . . . default: feedback = "Connexion..."; }
Le paramètre de connexion connect_timeout
est ignoré lors
de l'utilisation PQconnectPoll
; c'est de la
responsabilité de l'application de décider quand une période de temps
excessive s'est écoulée. Sinon, PQconnectStart
suivi par
une boucle PQconnectPoll
est équivalent à
PQconnectdb
.
Notez que si PQconnectStart
ou
PQconnectStartParams
renvoie un pointeur non nul,
vous devez appeler PQfinish
lorsque vous en avez
terminé avec lui, pour supprimer la structure et tous les blocs
mémoires qui lui sont associés. Ceci doit être fait même si la
tentative de connexion échoue ou est abandonnée.
PQconndefaults
Renvoie les options de connexion par défaut.
PQconninfoOption *PQconndefaults(void); typedef struct { char *keyword; /* Mot clé de l'option */ char *envvar; /* Nom de la variable d'environnement équivalente */ char *compiled; /* Valeur par défaut interne */ char *val; /* Valeur actuelle de l'option ou NULL */ char *label; /* Label du champ pour le dialogue de connexion */ char *dispchar; /* Indique comment afficher ce champ dans un dialogue de connexion. Les valeurs sont : "" Affiche la valeur entrée sans modification "*" Champ de mot de passe - cache la valeur "D" Option de débogage - non affiché par défaut */ int dispsize; /* Taille du champ en caractère pour le dialogue */ } PQconninfoOption;
Renvoie un tableau d'options de connexion. Ceci pourrait être utilisé pour
déterminer toutes les options possibles de PQconnectdb
et leur valeurs par défaut. La valeur de retour pointe vers un tableau de
structures PQconninfoOption
qui se termine avec une
entrée utilisant un pointeur nul pour keyword
. Le pointeur
null est renvoyé si la mémoire n'a pas pu être allouée. Notez que les
valeurs par défaut actuelles (champs val
)
dépendront des variables d'environnement et d'autres contextes. Un
fichier de service manquant ou non valide sera ignoré de manière
silencieuse. Les demandeurs doivent traiter les données des options de
connexion en lecture seule.
Après le traitement du tableau d'options, libérez-le en le passant à la
fonction PQconninfoFree
. Si cela n'est pas fait, un
petit groupe de mémoire est perdu à chaque appel de
PQconndefaults
.
PQconninfo
Renvoie les options de connexion utilisées par une connexion en cours.
PQconninfoOption *PQconninfo(PGconn *conn);
Renvoie un tableau des options de connexion. Cette fonction peut être
utilisée pour déterminer les valeurs de toutes les options de
PQconnectdb
qui ont été utilisées pour se
connecter au serveur. La valeur renvoyée pointe vers un tableau de
structures PQconninfoOption
qui se termine avec
une entrée possédant un pointeur keyword
nul.
Toutes les notes ci-dessus pour PQconndefaults
s'appliquent aussi au résultat de PQconninfo
.
PQconninfoParse
Renvoit les options de connexions analysées d'après la chaîne de connexion fournie.
PQconninfoOption *PQconninfoParse(const char *conninfo, char **errmsg);
Analyse une chaîne de connexion et renvoie les options résultantes
dans un tableau ; renvoit NULL
si un problème a été détecté avec
la chaîne de connexion. Ceci peut être utilisé pour déterminer les
options de PQconnectdb
dans la chaîne de connexion
fournie. La valeur de retour pointe vers un tableau de structures
PQconninfoOption
et termine avec une entrée
ayant un pointeur keyword
nul.
Toutes les options légales seront présentes dans le tableau en résultat
mais le PQconninfoOption
pour toute option absente
de la chaîne de connexion aura sa valeur (val
)
configurée à NULL
; les valeurs par défaut ne
sont pas utilisées.
Si errmsg
n'est pas NULL
, alors
*errmsg
est configuré à NULL
en cas de succès et sinon
à un message d'erreur (alloué via un appel à malloc
) expliquant le
problèm. (Il est aussi possible pour *errmsg
d'être
configuré à NULL
et la fonction de renvoyer NULL
; cela indique un
cas de mémoire épuisée.)
Après avoir traité le tableau des options, libérez-le en le passant à
PQconninfoFree
. Si ce n'est pas fait, de la mémoire
sera perdu à chaque appel à PQconninfoParse
.
Réciproquement, si une erreur survient et que errmsg
n'est pas NULL
, assurez-vous de libérer la chaîne d'erreur en utilisant
PQfreemem
.
PQfinish
Ferme la connexion au serveur. Libère aussi la mémoire utilisée par l'objet
PGconn
.
void PQfinish(PGconn *conn);
Notez que même si la connexion au serveur a échoué (d'après l'indication
de PQstatus
), l'application devrait appeler
PQfinish
pour libérer la mémoire utilisée par l'objet
PGconn
. Le pointeur PGconn
ne doit
pas être encore utilisé après l'appel à PQfinish
.
PQreset
Réinitialise le canal de communication avec le serveur.
void PQreset(PGconn *conn);
Cette fonction fermera la connexion au serveur et tentera le rétablissement d'une nouvelle connexion au même serveur en utilisant tous les paramètres utilisés précédemment. Ceci pourrait être utile en cas de récupération après une perte de connexion.
PQresetStart
PQresetPoll
Réinitialise le canal de communication avec le serveur d'une façon non bloquante.
int PQresetStart(PGconn *conn); PostgresPollingStatusType PQresetPoll(PGconn *conn);
Ces fonctions fermeront la connexion au serveur et tenteront de rétablir
une nouvelle connexion sur le même serveur, en utilisant tous les paramètres
précédemment utilisés. Ceci peut être utile pour revenir à un état normal
après une erreur si une connexion est perdue. Ces fonctions diffèrent de
PQreset
(ci-dessus) dans le fait qu'elles agissent
d'une façon non bloquante. Ces fonctions souffrent des mêmes restrictions
que PQconnectStartParams
, PQconnectStart
et PQconnectPoll
.
Pour lancer une réinitialisation de la connexion, exécutez
PQresetStart
. Si cette fonction 0, la réinitialisation
a échoué. Si elle renvoie 1, récupérez le résultat de la réinitialisation
en utilisant PQresetPoll
exactement de la même
façon que vous auriez créé la connexion en utilisant
PQconnectPoll
.
PQpingParams
PQpingParams
renvoie le statut du serveur. Elle
accepte les mêmes paramètres de connexion que ceux de la fonction
PQconnectdbParams
, décrite ci-dessus. Néanmoins,
il n'est pas nécessaire de fournir les bons nom d'utilisateur, mot de
passe, ou nom de base de données pour obtenir le statut du serveur.
Néanmoins, si des valeurs incorrectes sont fournies, le serveur
tracera une tentative échouée de connexion.
PGPing PQpingParams(const char * const *keywords, const char * const *values, int expand_dbname);
La fonction renvoie une des valeurs suivantes :
PQPING_OK
Le serveur est en cours d'exécution et semble accepter les connexions.
PQPING_REJECT
Le serveur est en cours d'exécution mais est dans un état qui interdit les connexions (démarrage, arrêt, restauration après crash).
PQPING_NO_RESPONSE
Le serveur n'a pas pu être contacté. Cela pourrait indiquer que le serveur n'est pas en cours d'exécution ou qu'il y a un problème avec les paramètres de connexion donnés (par exemple un mauvais numéro de port). Cela peut aussi indiquer un problème de connexion réseau (par exemple un pare-feu qui bloque la demande de connexion).
PQPING_NO_ATTEMPT
Aucune tentative n'a été faite pour contacter le serveur à cause des paramètres fournis erronnés ou à cause d'un problème au niveau client (par exemple un manque mémoire).
PQping
PQping
renvoie l'état du serveur. Elle
accepte les mêmes paramètres de connexion que ceux de la fonction
PQconnectdb
, décrite ci-dessus. Néanmoins,
il n'est pas nécessaire de fournir les bons nom d'utilisateur, mot de
passe, ou nom de base de données pour obtenir le statut du serveur;
toutefois, si des valeurs incorrectes sont fournies, le serveur tracera
une tentative de connexion en échec.
PGPing PQping(const char *conninfo);
Les valeurs de retour sont les mêmes que pour PQpingParams
.
Plusieurs fonctions de la bibliothèque libpq analysent une chaîne donnée par l'utilisateur pour obtenir les paramètres de connexion. Deux formats sont acceptés pour ces chaînes : les chaînes mot clé/valeur et les URI. Les URI respectent généralement la RFC 3986, sauf que les chaînes de connexions multi hôtes sont autorisées, comme décrit ci-dessous.
Dans le format mot clé/valeur, chaque configuration de paramètre se
présente sous la forme mot clé
=
valeur
avec des espaces
entre les paramètres. Les espaces autour du signe égal
sont optionnels. Pour écrire une valeur vide ou une valeur contenant des
espaces, il est nécessaires de l'entourer de guillemets simples, par
exemple clé = 'une valeur'
. Les guillemets simples et
les antislashs compris dans une valeur doivent être échappés par un
antislash, comme ceci \'
et ceci \\
.
Exemple :
host=localhost port=5432 dbname=mabase connect_timeout=10
Les mots clés reconnus pour les paramètres sont listés dans Section 33.1.2.
La forme générale pour une URI de connexion est :
postgresql://[utilisateur[:mot_de_passe]@][hote][:port][,...][/nom_base][?param1=valeur1&...] postgresql://[spec_utilisateur
@][spec_hote
][/nom_base
][?spec_param
] oùspec_utilisateur
vaut :utilisateur
[:motdepasse
] etspec_hote
vaut : [hote
][:port
][,...] etspec_param
vaut :nom
=valeur
[&...]
Le désignateur dURI peut être soit
postgresql://
soit postgres://
.
Chacune des parties restantes de l'URI est
optionnelle. Les exemples suivants montrent des syntaxes valides pour
l'URI :
postgresql:// postgresql://localhost postgresql://localhost:5433 postgresql://localhost/ma_base postgresql://utilisateur@localhost postgresql://utilisateur:secret@localhost postgresql://autre@localhost/autre_base?connect_timeout=10&application_name=mon_appli postgresql://host1:123,host2:456/somedb?target_session_attrs=any&application_name=myapp
Les valeurs qui apparaitraient normalement dans la partie hiérarchique de l'URI peuvent être aussi données sous la forme de paramètres nommés. Par exemple :
postgresql:///ma_base?host=localhost&port=5433
Tous les paramètres nommés doivent correspondre aux mots clés listés dans
Section 33.1.2, sauf que, pour la compatibilité
avec les URI des connexions JDBC, les parties avec of
ssl=true
sont traduites en
sslmode=require
.
L'encodage du signe pourcent peut être utilisé pour inclure des symboles
dotés d'une signification spéciale dans toutes les parties de
l'URI, par exemple en remplaçant =
avec %3D
.
La partie host peut être soit un nom d'hôte soit une adresse IP. Pour indiquer une adresse IPv6, il est nécessaire de l'englober dans des crochets :
postgresql://[2001:db8::1234]/database
La partie host est interprété de la façon décrite pour le paramètre host. En particulier, une connexion par socket de domaine Unix est choisi si la partie host est vide ou si elle ressemble à un chemin absolu. Dans tous les autres cas, une connexion TCP/IP est démarrée. Cependant, notez que le slash est un caractère réservé dans la partie hiérarchique de l'URI. Donc, pour indiquer un répertoire non standard pour la socket de domaine Unix, il faut soit omettre d'indiquer la partie host de l'URI, soit l'indiquer en tant que paramètre nommé, soit encoder le chemin dans la partie host de l'URI :
postgresql:///dbname?host=/var/lib/postgresql postgresql://%2Fvar%2Flib%2Fpostgresql/dbname
Il est possible de spécifier plusieurs composants hôte, chacun avec un port
optionnel, dans une seule URI. Une URI de la forme
postgresql://host1:port1,host2:port2,host3:port3/
est
équivalent à une chaîne de connexion de la forme
host=host1,host2,host3 port=port1,port2,port3
. Comme
indiqué plus en détails plus bas, chaque hôte sera testé à son tour
jusqu'à ce qu'une connexion soit établie avec succès.
Il est possible de spécifier plusieurs hôtes où se connecter. Ils sont
essayés dans l'ordre donné. Dans un format clé/valeur, les options
host
, hostaddr
et
port
acceptent des listes de valeurs séparées par une
virgule. Le même nombre d'éléments doit être donné dans chaque option spécifiée
pour que le premier élément dans hostaddr
correspond au premier
nom d'hôte, le second hostaddr
correspond au second
nom d'hôte, et ainsi de suite. Seule exception pour l'option
port
, si un seul port est spécifié, il est utilisé
pour tous les hôtes.
Dans le format de connexion URI, vous pouvez lister plusieurs paires
hote:port
séparées par des virgules dans le composant
host
de l'URI.
Quelque soit le format, un simple nom d'hôte peut aussi se traduire en plusieurs adresses réseau. Un exemple habituel est un hôte qui a à la fois une adresse IPv4 et une adresse IPv6.
Quand plusieurs hôtes sont indiqués ou quand un nom d'hôte est converti en plusieurs adresses, tous les hôtes et adresses seront essayés dans l'ordre jusqu'à ce qu'une connexion réussisse. Si aucun des hôtes ne peut être atteint, la connexion échoue. Si la connexion réussit mais que l'authentification échoue, les autres hôtes de la liste ne seront pas testés.
Si un fichier de mots de passe est utilisé, vous pouvez avoir plusieurs mots de passe pour des hôtes différents. Toutes les autres options de connexion sont identiques pour chaque hôte de la liste. Par exemple, il n'est pas possible d'indiquer un nom d'utilisateur différent pour les différents hôtes.
Les mots clés actuellement reconnus sont :
host
Nom de l'hôte où se connecter. Si un nom d'hôte commence avec un slash, il
spécifie une communication par domaine Unix plutôt qu'une communication
TCP/IP ; la valeur est le nom du répertoire où le fichier socket
est stocké. Par défaut, quand
host
n'est pas spécifié ou quand il est vide, il s'agit d'une
communication par socket de domaine Unix dans /tmp
(ou
tout autre répertoire de socket spécifié lors de la construction de
PostgreSQL). Sur les machines sans sockets
de domaine Unix, la valeur par défaut est de se connecter à
localhost
.
Une liste séparée de virgules de noms d'hôtes est aussi acceptée, auquel cas chaque nom d'hôte est testé dans un ordre précis ; un élément vide dans la liste revient au comportement par défaut expliqué ci-dessus. Voir Section 33.1.1.3 pour plus de détails.
hostaddr
Adresse IP numérique de l'hôte de connexion. Elle devrait être au format
d'adresse standard IPv4, c'est-à-dire 172.28.40.9
. Si votre
machine supporte IPv6, vous pouvez aussi utiliser ces adresses. La
communication TCP/IP est toujours utilisée lorsqu'une chaîne non vide est
spécifiée pour ce paramètre.
Utiliser hostaddr
au lieu de host
permet à l'application d'éviter une recherche de nom d'hôte, qui
pourrait être importante pour les applications ayant des
contraintes de temps. Un nom d'hôte est requis pour les méthodes
d'authentification GSSAPI ou SSPI, ainsi que pour la
vérification de certificat SSL en verify-full
.
Les règles suivantes sont observées :
Si host
est indiqué sans
hostaddr
, une recherche du nom de l'hôte est
lancée. (Lors de l'utilisation de
PQconnectPoll
, la recherche survient quand
PQconnectPoll
considère en premier lieu ce nom
d'hôte, et cela pourrait causer le blocage de
PQconnectPoll
pendant longtemps.)
Si hostaddr
est indiqué sans
host
, la valeur de
hostaddr
donne l'adresse réseau de
l'hôte. La tentative de connexion échouera si la méthode
d'authentification nécessite un nom d'hôte.
Si host
et hostaddr
sont indiqués, la valeur de hostaddr
donne l'adresse réseau de l'hôte. La valeur de
host
est ignorée sauf si la méthode
d'authentification la réclame, auquel cas elle sera
utilisée comme nom d'hôte.
Notez que l'authentification a de grandes chances d'échouer si
host
n'est pas identique au nom du serveur pour
l'adresse réseau hostaddr
. De même, quand
host
et hostaddr
sont spécifiés,
host
est utilisé pour identifier la connexion dans
un fichier de mots de passe (voir la Section 33.15).
Une liste séparée de virgules de noms d'hôtes est aussi acceptée, auquel cas chaque nom d'hôte est placé dans un ordre précis. Un élément vide dans la chaîne fera que le nom d'hôte correspondant sera utilisé, ou le nom d'hôte par défaut s'il est vidé. Voir Section 33.1.1.3 pour plus de détails.
Sans un nom ou une adresse d'hôte, libpq se
connectera en utilisant un socket local de domaine Unix. Sur des machines
sans sockets de domaine Unix, il tentera une connexion sur
localhost
.
port
Numéro de port pour la connexion au serveur ou extension du nom de
fichier pour des connexions de domaine Unix.
Si plusieurs hôtes ont
été saisis dans les paramètres host
ou
hostaddr
, ce paramètre peut spécifier une liste de
ports, séparés de virgules, de la même longueur que la liste d'hôtes.
Il peut aussi n'indiquer qu'un seul port, qui sera utilisé pour tous
les hôtes. Une chaîne vide ou un élément vode dans la liste, cible le
numéro de port par défaut établi lors de la construction de
PostgreSQL.
dbname
Nom de la base de données. Par défaut, la même que le nom utilisateur. Dans certains contextes, la valeur est vérifiée pour les formats étendues ; voir Section 33.1.1 pour plus d'informations.
user
Nom de l'utilisateur PostgreSQL qui se connecte. Par défaut, il s'agit du nom de l'utilisateur ayant lancé l'application.
password
Mot de passe à utiliser si le serveur demande une authentification par mot de passe.
passfile
Spécifie le nom du fichier utilisé pour stocker les mots de passe
(voir Section 33.15).
La valeur par défaut est ~/.pgpass
, ou
%APPDATA%\postgresql\pgpass.conf
sur Microsoft
Windows. (Aucune erreur n'est levée si le fichier n'existe pas.)
connect_timeout
Attente maximum pour une connexion, en secondes (saisie comme un
entier décimal, par exemple 10
). Zéro, négatif ou
non spécifié signifie une attente indéfinie. Le délai minimal autorisé
est de 2 secondes, du coup, une valeur de 1
est
interprété comme 2
. Ce délai s'applique séparément
pour chaque nom d'hôte et adresse IP. Par exemple, si vous indiquez
deux hôtes et que le paramètre connect_timeout
vaut
5, chaque hôte sera en timeout si aucune connexion n'est réalisée en
cinq secondes, donc le temps total passé à attendre une connexion ira
jusqu'à dix secondes.
client_encoding
Ceci configure le paramètre client_encoding
pour cette connexion. En plus des valeurs acceptées par
l'option serveur correspondante, vous pouvez utiliser
auto
pour déterminer le bon encodage à
partir de la locale courante du client (variable
d'environnement LC_CTYPE
sur les systèmes Unix).
options
Spécifie les options en ligne de commande à envoyer au serveur à
l'exécution. Par exemple, en le configurant à -c
geqo=off
, cela configure la valeur de la session
pour le paramètre geqo
à
off
. Les espaces à l'intérieur de cette
chaîne sont considérés comme séparateurs d'arguments,
sauf si ils sont échappés avec le caractère d'échappement
\
; écrivez \\
pour obtenir
le caractère d'échappement lui-même.
Pour une discussion détaillée des options
disponibles, voir Chapitre 19.
application_name
Précise une valeur pour le paramètre de configuration application_name.
fallback_application_name
Indique une valeur de secours pour le paramètre de configuration
application_name. Cette valeur sera utilisée
si aucune valeur n'est donnée à application_name
via un paramètre de connexion ou la variable d'environnement.
L'indication d'un nom de secours est utile pour les programmes
outils génériques qui souhaitent configurer un nom d'application
par défaut mais permettrait sa surcharge par l'utilisateur.
keepalives
Contrôle si les paramètres TCP keepalives côté client sont utilisés. La valeur par défaut est de 1, signifiant ainsi qu'ils sont utilisés. Vous pouvez le configurer à 0, ce qui aura pour effet de les désactiver si vous n'en voulez pas. Ce paramètre est ignoré pour les connexions réalisées via un socket de domaine Unix.
keepalives_idle
Contrôle le nombre de secondes d'inactivité après lequel TCP doit
envoyer un message keepalive au server. Une valeur de zéro utilise
la valeur par défaut du système. Ce paramètre est ignoré pour les
connexions réalisées via un socket de domaine Unix ou si les
paramètres keepalives sont désactivés. Ce paramètre est uniquement
supporté sur les systèmes où les options
TCP_KEEPIDLE
ou une option socket équivalente
sont disponibles et sur Windows ; pour les autres systèmes,
ce paramètre n'a pas d'effet.
keepalives_interval
Contrôle le nombre de secondes après lequel un message TCP
keepalive doit être retransmis si le serveur ne l'a pas acquitté.
Une valeur de zéro utilise la valeur par défaut du système. Ce
paramètre est uniquement supporté sur les systèmes où l'option
TCP_KEEPINTVL
ou une option socket équivalente est
disponible et sur Windows ;
pour les autres systèmes, ce paramètre n'a pas d'effet.
keepalives_count
Contrôle le nombre de messages TCP keepalives pouvant être perdus
avant que la connexion du client au serveur ne soit considérée
comme perdue. Une valeur de zéro utilise la valeur par défaut du
système. Ce paramètre est uniquement supporté sur les systèmes où
l'option TCP_KEEPCNT
ou une option socket équivalente
est disponible et sur
Windows ; pour les autres systèmes, ce paramètre n'a pas
d'effet.
tty
Ignoré (auparavant, ceci indiquait où envoyer les traces de débogage du serveur).
sslmode
Cette option détermine si ou avec quelle priorité une connexion TCP/IP SSL sécurisée sera négociée avec le serveur. Il existe six modes :
disable
essaie seulement une connexion non SSL
allow
essaie en premier lieu une connexion non SSL ; si cette tentative échoue, essaie une connexion SSL
prefer
(default)essaie en premier lieu une connexion SSL ; si cette tentative échoue, essaie une connexion non SSL
require
essaie seulement une connexion SSL.
Si un certificat racine d'autorité est présent, vérifie
le certificat de la même façon que si
verify-ca
était spécifié
verify-ca
essaie seulement une connexion SSL et vérifie que le certificat client est créé par une autorité de certification (CA) de confiance
verify-full
essaie seulement une connexion SSL, vérifie que le certificat client est créé par un CA de confiance et que le nom du serveur correspond bien à celui du certificat
Voir Section 33.18 pour une description détaillée de comment ces options fonctionnent.
sslmode
est ignoré pour la communication par
socket de domaine Unix.
Si PostgreSQL est compilé sans le support
de SSL, l'utilisation des options require
,
verify-ca
et
verify-full
causera
une erreur alors que les options allow
et
prefer
seront acceptées mais
libpq ne sera pas capable de négocier une
connexion SSL.
requiressl
Cette option est obsolète et remplacée par l'option sslmode
.
Si initialisée à 1, une connexion SSL au serveur est
requise (ce qui est équivalent à un sslmode
require
). libpq refusera alors de se
connecter si le serveur n'accepte pas une connexion
SSL. Si initialisée à 0 (la valeur par défaut),
libpq négociera le type de connexion avec le serveur
(équivalent à un sslmode
prefer
). Cette option
est seulement disponible si PostgreSQL est compilé avec
le support SSL.
sslcompression
Si initialisé à 1 (la valeur par défaut), les données envoyées sur une connexion SSL seront compressées. Si initialisé à 0, la compression sera désactivée (ceci requiert OpenSSL 1.0.0 ou ultérieur). Ce paramètre est ignoré si un connexion est tentée sans SSL ou si la version d'OpenSSL en vigueur ne le supporte pas.
La compression utilise du temps processeur mais peut améliorer la bande-passante si le réseau est le goulet d'étranglement. Désactiver la compression peut améliorer les temps de réponse et la bande passante si les performances des processeurs sont le facteur limitant.
sslcert
Ce paramètre indique le nom du fichier du certificat SSL client,
remplaçant le fichier par défaut,
~/.postgresql/postgresql.crt
. Ce paramètre
est ignoré si la connexion n'utilise pas SSL.
sslkey
Ce paramètre indique l'emplacement de la clé secrète utilisée pour
le certificat client. Il peut soit indiquer un nom de fichier qui
sera utilisé à la place du fichier
~/.postgresql/postgresql.key
par défaut, soit
indiquer un clé obtenue par un moteur externe (les moteurs sont des modules chargeables
d'OpenSSL). La spécification d'un moteur
externe devrait consister en un nom de moteur et un identifiant de
clé spécifique au moteur, les deux séparés par une virgule. Ce paramètre
est ignoré si la connexion n'utilise pas SSL.
sslrootcert
Ce paramètre indique le nom d'un fichier contenant le ou les
certificats de l'autorité de certification SSL
(CA). Si le fichier existe, le certificat du
serveur sera vérifié. La signature devra appartenir à une de ces
autorités. La valeur par défaut de ce paramètre est
~/.postgresql/root.crt
.
sslcrl
Ce paramètre indique le nom du fichier de la liste de révocation
du certificat serveur SSL. Les certificats listés dans ce fichier, s'il
existe bien, seront rejetés lors d'une tentative d'authentification
avec le certificat du serveur. La valeur par défaut de ce paramètre
est ~/.postgresql/root.crl
.
requirepeer
Ce paramètre indique le nom d'utilisateur du serveur au
niveau du système d'exploitation, par exemple
requirepeer=postgres
. Lors d'une connexion
par socket de domaine Unix, si ce paramètre est configuré, le
client vérifie au début de la connexion si le processus
serveur est exécuté par le nom d'utilisateur indiqué ;
dans le cas contraire, la connexion est annulée avec une
erreur. Ce paramètre peut être utilisé pour fournir une
authentification serveur similaire à celle disponible pour les
certificats SSL avec les connexions TCP/IP. (Notez que, si
la socket de domaine Unix est dans /tmp
ou tout espace autorisé en écriture pour tout le monde,
n'importe quel utilisateur peut mettre un serveur en écoute à
cet emplacement. Utilisez ce paramètre pour vous assurer que
le serveur est exécuté par un utilisateur de confiance.) Cette
option est seulement supportée par les plateformes sur
lesquelles la méthode d'authentification peer
est disponible ; voir Section 20.3.6.
krbsrvname
Nom du service Kerberos à utiliser lors de l'authentification avec GSSAPI. Il doit correspondre avec le nom du service spécifié dans la configuration du serveur pour que l'authentification Kerberos puisse réussir (voir aussi la Section 20.3.3.)
gsslib
Ce paramètre est actuellement ignoré, sauf sur les versions Windows
qui incluent la prise en charge de GSSAPI et de SSPI. Dans ce cas,
configurer ce paramètre à gssapi
pour amener la
libpq à utiliser la bibliothèque GSSAPI pour l'authentification au
lieu de SSPI par défaut.
service
Nom du service à utiliser pour des paramètres supplémentaires. Il spécifie
un nom de service dans pg_service.conf
contenant
des paramètres de connexion supplémentaires. Ceci permet aux
applications de spécifier uniquement un nom de service, donc les
paramètres de connexion peuvent être maintenus de façon centrale. Voir
Section 33.16.
target_session_attrs
Si ce paramètre est positionné à read-write
, seule
une connexion dans laquelle les transactions en lecture/écriture sont
acceptées par défaut est considéré comme acceptable. La requête
SHOW transaction_read_only
sera envoyée à chaque
connexion réussie; si elle retourne on
, la connexion
sera fermée. Si plusieurs hôtes étaient spécifiés dans la chaîne de
connexion, chaque serveur restant sera testé tout comme si la tentative
de connexion avait échouée. La valeur par défaut pour ce paramètre,
any
, considère toutes les connexions comme
acceptables.