- 29 Jul, 2005 2 commits
- 
- 
Bruce Momjian authoredUse O_DIRECT if available when using O_SYNC for wal_sync_method. Also, write multiple WAL buffers out in one write() operation. ITAGAKI Takahiro --------------------------------------------------------------------------- > If we disable writeback-cache and use open_sync, the per-page writing > behavior in WAL module will show up as bad result. O_DIRECT is similar > to O_DSYNC (at least on linux), so that the benefit of it will disappear > behind the slow disk revolution. > > In the current source, WAL is written as: > for (i = 0; i < N; i++) { write(&buffers[i], BLCKSZ); } > Is this intentional? Can we rewrite it as follows? > write(&buffers[0], N * BLCKSZ); > > In order to achieve it, I wrote a 'gather-write' patch (xlog.gw.diff). > Aside from this, I'll also send the fixed direct io patch (xlog.dio.diff). > These two patches are independent, so they can be applied either or both. > > > I tested them on my machine and the results as follows. It shows that > direct-io and gather-write is the best choice when writeback-cache is off. > Are these two patches worth trying if they are used together? > > > | writeback | fsync= | fdata | open_ | fsync_ | open_ > patch | cache | false | sync | sync | direct | direct > ------------+-----------+--------+-------+-------+--------+--------- > direct io | off | 124.2 | 105.7 | 48.3 | 48.3 | 48.2 > direct io | on | 129.1 | 112.3 | 114.1 | 142.9 | 144.5 > gather-write| off | 124.3 | 108.7 | 105.4 | (N/A) | (N/A) > both | off | 131.5 | 115.5 | 114.4 | 145.4 | 145.2 > > - 20runs * pgbench -s 100 -c 50 -t 200 > - with tuning (wal_buffers=64, commit_delay=500, checkpoint_segments=8) > - using 2 ATA disks: > - hda(reiserfs) includes system and wal. > - hdc(jfs) includes database files. writeback-cache is always on. > > --- > ITAGAKI Takahiro
- 
Bruce Momjian authoredAn attached patch is a small additional improvement. This patch use appendStringInfoText instead of appendStringInfoString. There is an overhead of PG_TEXT_GET_STR when appendStringInfoString is executed by text type. This can be reduced by appendStringInfoText. Atsushi Ogawa 
 
- 
- 28 Jul, 2005 11 commits
- 
- 
Tom Lane authoredwhere applicable. 
- 
Bruce Momjian authoredThere's no tab-completion for "PREPARE TRANSACTION 'xxx'" since that would be ambigous with "PREPARE xxx AS xx". Heikki Linnakangas 
- 
Tom Lane authoredplanning logic for bitmap indexscans. Partial indexes create corner cases in which a scan might be done with no explicit index qual conditions, and the code wasn't handling those cases nicely. Also be a little tenser about eliminating redundant clauses in the generated plan. Per report from Dmitry Karasik. 
- 
Bruce Momjian authored
- 
Neil Conway authorednot ever write through the `isnull' parameter, it does not need to be an out parameter. Therefore it can be declared a "bool" rather than a "bool *". 
- 
Neil Conway authoredto the "text" segment. It would be possible to mark the elements of the array "const" as well, but this would require multiple API changes and does not seem to be worth the notational inconvenience. 
- 
Tom Lane authored
- 
Tom Lane authoredinto .def and .exp files automatically on Windows, AIX, and the like. An additional benefit is that changes in libpgport files correctly propagate to force rebuild of the backend executable. This is my reworking of Rocco Altier's idea, and if it breaks anything it's definitely my fault. 
- 
Tom Lane authoredThe first rule of portability for us is 'thou shalt have no other gods before c.h', and a whole lot of these files were either not including c.h at all, or including random system headers beforehand, either of which sins can mess up largefile support nicely. Once you have included c.h, there is no need to re-include what it includes, either. 
- 
Tom Lane authored
- 
Tom Lane authoredPer Kevin McArthur. 
 
- 
- 27 Jul, 2005 4 commits
- 
- 
Neil Conway authored
- 
Neil Conway authoredparentheses. This avoids possible operator precedence problems, and is consistent with most of the macro definitions in the tree. 
- 
Neil Conway authored
- 
Neil Conway authoredno database has been explicitly specified. Per gripe from Omar Kilani. 
 
- 
- 26 Jul, 2005 4 commits
- 
- 
Tom Lane authoredbe rewritten, but at least the reference pages are reasonably sane. 
- 
Tom Lane authoredsensibly, even though we don't document it. 
- 
Tom Lane authoreddoesn't automatically inherit the privileges of roles it is a member of; for such a role, membership in another role can be exploited only by doing explicit SET ROLE. The default inherit setting is TRUE, so by default the behavior doesn't change, but creating a user with NOINHERIT gives closer adherence to our current reading of SQL99. Documentation still lacking, and I think the information schema needs another look. 
- 
Tom Lane authoredexisting ones for object privileges. Update the information_schema for roles --- pg_has_role() makes this a whole lot easier, removing the need for most of the explicit joins with pg_user. The views should be a tad faster now, too. Stephen Frost and Tom Lane. 
 
- 
- 25 Jul, 2005 5 commits
- 
- 
Tom Lane authoredI'm still working on the has_role function and information_schema changes. 
- 
Bruce Momjian authoredAdrian Maier 
- 
Bruce Momjian authored> o Allow postgresql.conf file values to be changed via an SQL API > o Allow the server to be stopped/restarted via an SQL API 
- 
Tom Lane authoredpg_strcasecmp and pg_strncasecmp ... but I see some of the former have crept back in. Eternal vigilance is the price of locale independence, apparently. 
- 
Tom Lane authoredon the not-very-good .so pattern rules in the port-specific Makefiles. (This leaves only pgxs' MODULES case needing those rules.) Also, compile pgsleep.c locally and add it to regress.so to avoid failure on AIX. 
 
- 
- 24 Jul, 2005 7 commits
- 
- 
Tom Lane authoredPer Rocco Altier. 
- 
Tom Lane authored
- 
Tom Lane authoredfails near DST transition days, so remove the advice about that testing problem. Also improve the description of variant-comparison-file selection. 
- 
Tom Lane authorederror message in Python 2.3 and before. Per Michael Fuhr and buildfarm results. 
- 
Bruce Momjian authoredinterval_mul function. 
- 
Tom Lane authoreda lossy page has to be lossy, because we don't know exactly which tuples on the page should remain part of the bitmap. Per Jie Zhang. 
- 
Tom Lane authoredintegration. Not clear this explains recent stats problems, but it's definitely wrong. 
 
- 
- 23 Jul, 2005 7 commits
- 
- 
Tom Lane authoredscans are candidates for exclusion; this should be fixed eventually. Simon Riggs, with some help from Tom Lane. 
- 
Bruce Momjian authored
- 
Bruce Momjian authored
- 
Bruce Momjian authored
- 
Bruce Momjian authorednear daylight savings time boudaries. This handles it properly, e.g. test=> select '2005-04-03 04:00:00'::timestamp at time zone 'America/Los_Angeles'; timezone ------------------------ 2005-04-03 07:00:00-04 (1 row)
- 
Tom Lane authoredfunction that actually sleeps, instead of busy-waiting. Perhaps this will resolve some of the intermittent stats failures we keep seeing. 
- 
Bruce Momjian authoredtest=> select (CURRENT_DATE + '05:00'::time)::timestamp at time zone 'Canada/Pacific'; timezone ------------------------ 2005-07-22 08:00:00-04 (1 row) 
 
-