ok
Direktori : /opt/alt/postgresql11/usr/share/doc/alt-postgresql11-9.2.24/html/ |
Current File : //opt/alt/postgresql11/usr/share/doc/alt-postgresql11-9.2.24/html/tutorial-arch.html |
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <HTML ><HEAD ><TITLE >Architectural Fundamentals</TITLE ><META NAME="GENERATOR" CONTENT="Modular DocBook HTML Stylesheet Version 1.79"><LINK REV="MADE" HREF="mailto:pgsql-docs@postgresql.org"><LINK REL="HOME" TITLE="PostgreSQL 9.2.24 Documentation" HREF="index.html"><LINK REL="UP" TITLE="Getting Started" HREF="tutorial-start.html"><LINK REL="PREVIOUS" TITLE="Installation" HREF="tutorial-install.html"><LINK REL="NEXT" TITLE="Creating a Database" HREF="tutorial-createdb.html"><LINK REL="STYLESHEET" TYPE="text/css" HREF="stylesheet.css"><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=ISO-8859-1"><META NAME="creation" CONTENT="2017-11-06T22:43:11"></HEAD ><BODY CLASS="SECT1" ><DIV CLASS="NAVHEADER" ><TABLE SUMMARY="Header navigation table" WIDTH="100%" BORDER="0" CELLPADDING="0" CELLSPACING="0" ><TR ><TH COLSPAN="5" ALIGN="center" VALIGN="bottom" ><A HREF="index.html" >PostgreSQL 9.2.24 Documentation</A ></TH ></TR ><TR ><TD WIDTH="10%" ALIGN="left" VALIGN="top" ><A TITLE="Installation" HREF="tutorial-install.html" ACCESSKEY="P" >Prev</A ></TD ><TD WIDTH="10%" ALIGN="left" VALIGN="top" ><A HREF="tutorial-start.html" ACCESSKEY="U" >Up</A ></TD ><TD WIDTH="60%" ALIGN="center" VALIGN="bottom" >Chapter 1. Getting Started</TD ><TD WIDTH="20%" ALIGN="right" VALIGN="top" ><A TITLE="Creating a Database" HREF="tutorial-createdb.html" ACCESSKEY="N" >Next</A ></TD ></TR ></TABLE ><HR ALIGN="LEFT" WIDTH="100%"></DIV ><DIV CLASS="SECT1" ><H1 CLASS="SECT1" ><A NAME="TUTORIAL-ARCH" >1.2. Architectural Fundamentals</A ></H1 ><P > Before we proceed, you should understand the basic <SPAN CLASS="PRODUCTNAME" >PostgreSQL</SPAN > system architecture. Understanding how the parts of <SPAN CLASS="PRODUCTNAME" >PostgreSQL</SPAN > interact will make this chapter somewhat clearer. </P ><P > In database jargon, <SPAN CLASS="PRODUCTNAME" >PostgreSQL</SPAN > uses a client/server model. A <SPAN CLASS="PRODUCTNAME" >PostgreSQL</SPAN > session consists of the following cooperating processes (programs): <P ></P ></P><UL ><LI ><P > A server process, which manages the database files, accepts connections to the database from client applications, and performs database actions on behalf of the clients. The database server program is called <TT CLASS="FILENAME" >postgres</TT >. </P ></LI ><LI ><P > The user's client (frontend) application that wants to perform database operations. Client applications can be very diverse in nature: a client could be a text-oriented tool, a graphical application, a web server that accesses the database to display web pages, or a specialized database maintenance tool. Some client applications are supplied with the <SPAN CLASS="PRODUCTNAME" >PostgreSQL</SPAN > distribution; most are developed by users. </P ></LI ></UL ><P> </P ><P > As is typical of client/server applications, the client and the server can be on different hosts. In that case they communicate over a TCP/IP network connection. You should keep this in mind, because the files that can be accessed on a client machine might not be accessible (or might only be accessible using a different file name) on the database server machine. </P ><P > The <SPAN CLASS="PRODUCTNAME" >PostgreSQL</SPAN > server can handle multiple concurrent connections from clients. To achieve this it starts (<SPAN CLASS="QUOTE" >"forks"</SPAN >) a new process for each connection. From that point on, the client and the new server process communicate without intervention by the original <TT CLASS="FILENAME" >postgres</TT > process. Thus, the master server process is always running, waiting for client connections, whereas client and associated server processes come and go. (All of this is of course invisible to the user. We only mention it here for completeness.) </P ></DIV ><DIV CLASS="NAVFOOTER" ><HR ALIGN="LEFT" WIDTH="100%"><TABLE SUMMARY="Footer navigation table" WIDTH="100%" BORDER="0" CELLPADDING="0" CELLSPACING="0" ><TR ><TD WIDTH="33%" ALIGN="left" VALIGN="top" ><A HREF="tutorial-install.html" ACCESSKEY="P" >Prev</A ></TD ><TD WIDTH="34%" ALIGN="center" VALIGN="top" ><A HREF="index.html" ACCESSKEY="H" >Home</A ></TD ><TD WIDTH="33%" ALIGN="right" VALIGN="top" ><A HREF="tutorial-createdb.html" ACCESSKEY="N" >Next</A ></TD ></TR ><TR ><TD WIDTH="33%" ALIGN="left" VALIGN="top" >Installation</TD ><TD WIDTH="34%" ALIGN="center" VALIGN="top" ><A HREF="tutorial-start.html" ACCESSKEY="U" >Up</A ></TD ><TD WIDTH="33%" ALIGN="right" VALIGN="top" >Creating a Database</TD ></TR ></TABLE ></DIV ></BODY ></HTML >