vacuumdb.sgml 8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14
<refentry id="APP-VACUUMDB">
 <refmeta>
  <refentrytitle>
   <application>vacuumdb</application>
  </refentrytitle>
  <refmiscinfo>Application</refmiscinfo>
 </refmeta>
 <refnamediv>
  <refname id="vacuumdb">
   <application>vacuumdb</application>
  </refname>
  <refpurpose>
   Clean and analyze a <productname>Postgres</productname> database
  </refpurpose>
15
 </refnamediv>
16 17 18 19 20
 <refsynopsisdiv>
  <refsynopsisdivinfo>
   <date>1998-10-04</date>
  </refsynopsisdivinfo>
  <synopsis>
21 22 23
vacuumdb [ --analyze | -z ] [ --verbose | -v ] [ <replaceable class="parameter">dbname</replaceable> ]
vacuumdb [ -h <replaceable class="parameter">host</replaceable> ] [ -p <replaceable class="parameter">port</replaceable> ]
    [ --table '<replaceable class="parameter">table</replaceable> [ ( <replaceable class="parameter">column</replaceable> [,...] ) ]' ]
24
    [ <replaceable class="parameter">dbname</replaceable> ]
25
  </synopsis>
26

27 28 29 30 31
  <refsect2 id="R2-APP-VACUUMDB-1">
   <refsect2info>
    <date>1998-10-04</date>
   </refsect2info>
   <title>
32
    Inputs
33 34
   </title>
   <para>
35 36 37 38
    <application>vacuumdb</application> accepts the following command line arguments:
    
    <variablelist>
     <varlistentry>
39
      <term><replaceable class="parameter">dbname</replaceable></term>
40 41 42 43 44 45 46 47 48 49
      <listitem>
       <para>
	Specifies the name of the database to be cleaned or analyzed.
	<replaceable class="parameter">dbname</replaceable>
	defaults to the value of the
	<envar>USER</envar>
	environment variable.
       </para>
      </listitem>
     </varlistentry>
50

51
     <varlistentry>
52 53
      <term>--analyze</term>
      <term>-z</term>
54 55 56 57 58 59
      <listitem>
       <para>
	Calculate statistics on the database for use by the optimizer.
       </para>
      </listitem>
     </varlistentry>
60

61
     <varlistentry>
62 63
      <term>--verbose</term>
      <term>-v</term>
64 65 66 67 68 69
      <listitem>
       <para>
	Print detailed information during processing.
       </para>
      </listitem>
     </varlistentry>
70

71
     <varlistentry>
72 73
      <term>--table <replaceable class="parameter">table</replaceable> [ (<replaceable class="parameter">column</replaceable> [,...]) ]</term>
      <term>-t <replaceable class="parameter">table</replaceable> [ (<replaceable class="parameter">column</replaceable> [,...]) ]</term>
74 75 76 77 78 79 80 81
      <listitem>
       <para>
	Clean or analyze <replaceable class="parameter">table</replaceable> only.
	Column names may be specified only in conjunction with
	the <option>--analyze</option> option.
       </para>
      </listitem>
     </varlistentry>
82

83 84
    </variablelist>
   </para>
85

86 87 88 89 90 91
   <para>
    <application>vacuumdb</application> also accepts 
    the following command line arguments for connection parameters:
    
    <variablelist>
     <varlistentry>
92
      <term>-h <replaceable class="parameter">host</replaceable></term>
93 94 95 96 97 98 99 100 101
      <listitem>
       <para>
	Specifies the hostname of the machine on which the 
	<application>postmaster</application>
	is running.  Defaults to using a local Unix domain socket
	rather than an IP connection..
       </para>
      </listitem>
     </varlistentry>
102

103
     <varlistentry>
104
      <term>-p <replaceable class="parameter">port</replaceable></term>
105 106 107 108 109 110 111 112 113 114
      <listitem>
       <para>
	Specifies the Internet TCP/IP port or local Unix domain socket file 
	extension on which the <application>postmaster</application>
	is listening for connections.  The port number defaults to 5432,
	or the value of the <envar>PGPORT</envar>
	environment variable (if set).
       </para>
      </listitem>
     </varlistentry>
115

116
     <varlistentry>
117
      <term>-u</term>
118 119 120 121 122 123 124 125 126 127 128 129
      <listitem>
       <para>
	Use password authentication. 
	Prompts for
	<replaceable class="parameter">username</replaceable>
	and <replaceable class="parameter">password</replaceable>.
       </para>
      </listitem>
     </varlistentry>
    </variablelist>
   </para>
  </refsect2>
130

131 132 133 134 135
  <refsect2 id="R2-APP-VACUUMDB-2">
   <refsect2info>
    <date>1998-10-04</date>
   </refsect2info>
   <title>
136
    Outputs
137 138
   </title>
   <para>
139 140
    <application>vacuumdb</application> executes a <command>VACUUM</command> command
    on the specified database, so has not explicit external output.
141

142 143
    <variablelist>
     <varlistentry>
144 145 146 147
      <term><computeroutput>
ERROR:  Can't vacuum columns, only tables.  You can 'vacuum analyze' columns.
vacuumdb: database vacuum failed on <replaceable class="parameter">dbname</replaceable>.
       </computeroutput></term>
148 149 150 151 152 153 154
      <listitem>
       <para>
	The non-analyze mode requires cleaning full tables or databases.
	Individual columns may be specified only when analyzing a specific table.
       </para>
      </listitem>
     </varlistentry>
155

156
     <varlistentry>
157 158 159 160 161
      <term><computeroutput>
Connection to database 'template1' failed.
connectDB() failed: Is the postmaster running and accepting connections
at 'UNIX Socket' on port '<replaceable class="parameter">port</replaceable>'?
       </computeroutput></term>
162 163 164 165 166 167 168 169 170 171 172 173
      <listitem>
       <para>
	<application>vacuumdb</application> could not attach to the 
	<application>postmaster</application> 
	process on the specified host and port.  If you see this message,
	ensure that the <application>postmaster</application> 
	is running on the proper host and that you have specified the proper
	port.  If your site uses an authentication system, ensure that you
	have obtained the required authentication credentials.
       </para>
      </listitem>
     </varlistentry>
174

175
     <varlistentry>
176 177 178 179
      <term><computeroutput>
Connection to database '<replaceable class="parameter">dbname</replaceable>' failed.
FATAL 1:  SetUserId: user '<replaceable class="parameter">username</replaceable>' is not in 'pg_shadow'
       </computeroutput></term>
180 181 182 183 184 185 186 187 188 189
      <listitem>
       <para>
	You do not have a valid entry in the relation <literal>pg_shadow</literal>
	and and will not be allowed to access <productname>Postgres</productname>. 
	Contact your <productname>Postgres</productname> administrator.
       </para>
      </listitem>
     </varlistentry>
    </variablelist>
   </para>
190

191 192 193 194 195 196 197 198 199 200 201 202
   <note>
    <para>
     <application>vacuumdb</application> internally executes a
     <command>VACUUM</command> <acronym>SQL</acronym> statement. 
     If you have problems running <application>vacuumdb</application>,
     make sure you are able to run <command>VACUUM</command> on the database using, for
     example, <application>psql</application>.
    </para>
   </note>
  </refsect2>
 </refsynopsisdiv>
 
203 204 205 206 207
 <refsect1 id="R1-APP-VACUUMDB-1">
  <refsect1info>
   <date>1998-10-04</date>
  </refsect1info>
  <title>
208
   Description
209
  </title>
210

211
  <para>
212 213 214 215 216 217
   <application>vacuumdb</application> is a utility for cleaning a
   <productname>Postgres</productname> database.
   <application>vacuumdb</application> will also generate internal statistics
   used by the <productname>Postgres</productname> query optimizer.
  </para>
 </refsect1>
218

219 220 221 222 223
 <refsect1 id="R1-APP-VACUUMDB-2">
  <refsect1info>
   <date>1998-10-04</date>
  </refsect1info>
  <title>
224
   Notes
225
  </title>
226

227
  <para>
228
   See <xref endterm="vacuum" linkend="vacuum"> for more details.
229 230 231
  </para>
 </refsect1>
 
232 233 234 235 236
 <refsect1 id="R1-APP-VACUUMDB-3">
  <refsect1info>
   <date>1998-10-04</date>
  </refsect1info>
  <title>
237
   Usage
238 239
  </title>
  <para>
240 241 242
   To clean a database of the same name as the user:
   
   <programlisting>
243
% vacuumdb
244 245
   </programlisting>
  </para>
246

247 248
  <para>
   To analyze a database named <literal>bigdb</literal> for the optimizer:
249

250
   <programlisting>
251
% vacuumdb --analyze bigdb
252 253 254 255 256
   </programlisting>
  </para>
  <para>
   To analyze a single column <literal>bar</literal> in table <literal>foo</literal>
   in a database named <literal>xyzzy</literal> for the optimizer:
257

258
   <programlisting>
259
% vacuumdb --analyze --verbose --table 'foo(bar)' xyzzy
260 261 262
   </programlisting>
  </para>
 </refsect1>
263
</refentry>
264 265 266 267

<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
268
sgml-omittag:nil
269 270 271 272 273 274 275 276 277 278 279 280
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
sgml-parent-document:nil
sgml-default-dtd-file:"../reference.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:"/usr/lib/sgml/catalog"
sgml-local-ecat-files:nil
End:
-->