VSAM06

Download as pdf or txt
Download as pdf or txt
You are on page 1of 35

VSAM-06.

PRZ

VSE/VSAM Tips for Tuning


Dan Janda The Swami of VSAM
The Swami of
Dan Janda
VSE, VSAM and CICS Performance Consultant
RR 2 Box 49E Hamlin Road Montrose, PA 18801-9624

VSE/VSAM

World Alliance of VM, VSE and Linux Chattanooga, Tennessee April, 2006

04/09/06 10:08 PM

(570) 934-2862 theswami@epix.net http://business.epix.net/~theswami

Copyright 2003-2006 by Dan Janda 1 The Swami of VSE/VSAM

Chattanooga Tennessee

VSAM-06.PRZ

2006

Abstract and References

In this presentation, we give an overview of the VSE/VSAM Subsystem, its features and how to exploit them for best overall system performance. We intend to highlight newer features and those older features that are often overlooked and which our experience shows give the most "bang for the buck." We try to highlight key "gotchas" in the performance area. This presentation and its materials are copyrighted materials, developed by Dan Janda, The Swami of VSAM. (c) 2003-2006 by Dan Janda. Permission is granted to WAVV to reproduce this presentation for distribution to its members at no charge.
Trademarks: IBM, VSE, VSE/ESA, ESA, CICS and DL/I are trademarks or registered trademarks of the IBM Corporation The Swami of VSAM is a trademark of Dan Janda

Abstract:

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 2

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSE/VSAM Overview

Virtual Storage Access Method For Direct Access Storage Devices (disk devices) General Purpose File Organizations Sequential -- records stored in the sequence presented Direct -- records stored in arbitrary sequence Indexed -- records stored via keys and an index File Access Techniques Sequential -- processing in the order stored Direct -- processing in an arbitrary order Keyed -- processing in key order

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 3

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSE/VSAM Overview

Virtual Storage Access Method Functional Areas Catalog Volume, File information Usage statistics DASD Space Management Space allocation, including secondary allocations VSAM and non-VSAM files (VSAM managed SAM, etc.) System Files Libraries Performance Large data transfer sizes for sequential processing Buffer look-aside for direct processing Integrity Backup/Restore Intra- and Inter-System Sharing controls
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 4

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSE/VSAM Overview

Virtual Storage Access Method Data Organizations Key Sequenced Data Set (KSDS) Indexed, stored logically in key sequence Entry Sequenced Data Set (ESDS) Non-indexed, stored in order inserted, new records at end of file Relative Record Data Set (RRDS) Non-indexed, stored in relative record order, fixed length records Variable Length Relative Record Data Set (VRDS) Indexed, stored in relative record order, but variable length records Alternate Index Data Set (AIX) A form of KSDS used as a "finder file" Unique or non-unique keys are supported
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 5

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSE/VSAM Overview

Virtual Storage Access Method Access Techniques Sequential Access Sequential, forward or backward Keyed Access Sequential, forward or backward Skip Sequential, forward or backward Direct, by full or partial (generic) key Addressed Access Sequential, forward or backward Skip Sequential, forward or backward Direct, by record address Alternate Index Access Same as for keyed access, above Add direct access by non-unique key
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 6

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSE/VSAM Overview
Logically stores records on disk Capabilities enabled by these techniques Performance aspects Physically stores records on disk Disk space usage calculations Performance aspects

In this next section, we'll discuss how VSAM

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 7

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSE/VSAM Jargon

Control Interval (CI) The smallest unit of data transfer between main and disk storage One or more logical records are loaded into a CI

Rec 01

Rec 02

Rec 03

Rec ...

Freespace

RDF(s)

CIDF

Rec 01--Rec nn 1 to n logical records of any length Freespace Unused space within CI available for additional record insertion or increase in length of existing records RDF(s) 3-byte VSAM Record Descriptor Field for ESDS/KSDS, one per record length, one for all consecutive records of the same length for RRDS, one per numbered record slot CIDF 4-byte Control Interval Descriptor Field

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 8

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSE/VSAM Jargon

Control Area (CA) A group of CIs. In an indexed file, all the data CIs in a CA are mapped by a single index CI.
CI 00 CI 10 CI 20 CI 30 CI 01 CI 11 CI 21 CI 31 CI 02 CI 12 CI 22 CI 32 CI 03 CI 13 CI 23 CI 33 CI 04 CI 14 CI 24 CI 34 CI 05 CI 15 CI 25 CI 35 CI 06 CI 16 CI 26 CI 36 CI 07 CI 17 CI 27 CI 37 CI 08 CI 18 CI 28 CI 38 CI 09 CI 19 CI 29 CI 39

The size of a CA is the smallest among: -- one cylinder (or "max-CA") on the device -- the size of the primary allocation amount -- the size of the secondary allocation amount The number of CIs per CA depends on the device characteristics -(track size, number of tracks per cylinder) and the CI and CA sizes It is generally beneficial to have as large a CA size as possible
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 9

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSE/VSAM Jargon

Index Control Interval (Index CI) A CI in an index, containing pointer entries to The next level in the index, or The data CI within the CA (if this is a Sequence Set CI)

CI 00 CI 10 CI 20 CI 30
04/09/06 10:08 PM

CI 01 CI 11 CI 21 CI 31

CI 02 CI 12 CI 22 CI 32

CI 03 CI 13 CI 23 CI 33

CI 04 CI 14 CI 24 CI 34

CI 05 CI 15 CI 25 CI 35

CI 06 CI 16 CI 26 CI 36

CI 07 CI 17 CI 27 CI 37

CI 08 CI 18 CI 28 CI 38

CI 09 CI 19 CI 29 CI 39

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 10

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSE/VSAM Jargon
There is always exactly one high-level index CI There may be no to many intermediate-level index CIs There may be one or more low-level (sequence set) index CIs. If only one sequence set CI, it is also the high-level index CI.

Index and data structure... Balanced Tree Sparse Index

...
CI 01 CI 02 CI 03 CI 04 CI 05 CI 06 CI 11 CI 12 CI 13 CI 14 CI 15 CI 16

...
CI 00 CI 01 CI 02 CI 03 CI 04 CI 05 CI 06 CI 07 CI 08 CI 09 CI 00 CI 01 CI 02 CI 03 CI 04 CI 05 CI 06 CI 07 CI 08 CI 09 CI 00 CI 01 CI 02 CI 03 CI 04 CI 05 CI 06 CI 07 CI 08 CI 09 CI 00 CI 07 CI 08 CI 09 CI 10 CI 11 CI 12 CI 13 CI 14 CI 15 CI 16 CI 17 CI 18 CI 19 CI 10 CI 11 CI 12 CI 13 CI 14 CI 15 CI 16 CI 17 CI 18 CI 19 CI 10 CI 11 CI 12 CI 13 CI 14 CI 15 CI 16 CI 17 CI 18 CI 19 CI 10 CI 17 CI 18 CI 19 CI 20 CI 21 CI 22 CI 23 CI 24 CI 25 CI 26 CI 27 CI 28 CI 29 CI 20 CI 21 CI 22 CI 23 CI 24 CI 25 CI 26 CI 27 CI 28 CI 29 CI 20 CI 21 CI 22 CI 23 CI 24 CI 25 CI 26 CI 27 CI 28 CI 29 CI 20 CI 21 CI 22 CI 23 CI 24 CI 25 CI 26 CI 27 CI 28 CI 29 CI 30 CI 31 CI 32 CI 33 CI 34 CI 35 CI 36 CI 37 CI 38 CI 39 CI 30 CI 31 CI 32 CI 33 CI 34 CI 35 CI 36 CI 37 CI 38 CI 39 CI 30 CI 31 CI 32 CI 33 CI 34 CI 35 CI 36 CI 37 CI 38 CI 39 CI 30 CI 31 CI 32 CI 33 CI 34 CI 35 CI 36 CI 37 CI 38 CI 39

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 11

Chattanooga Tennessee

VSAM-06.PRZ

2006

Performance Tips
Especially if file is processed sequentially

Use as large a DATA CI as possible Use as small an INDEX CI as possible


Larger DATA CIs permit smaller INDEX CIs

Use as large a DATA CA as possible


Primary and secondary allocation amounts should be at least a cylinder in size

Use reasonable primary and secondary allocation amounts


Avoid use of many allocations

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 12

Chattanooga Tennessee

VSAM-06.PRZ

2006

Disk Space Usage Calculations


Determine Freespace in each CI
CI Size * Freespace percentage rounded up

Determine number of records per CI


Fixed Length: (CI Size - 10 - Freespace) / Logical Record Length rounded down Variable Length: (CI Size - 7 - Freespace) / (Average Logical Record Length + 3) [average logical record length may not be known without study]
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 13

Chattanooga Tennessee

VSAM-06.PRZ

2006

Disk Space Usage Calculations


Determine Freespace in each CA
Number of CIs in each CA (from Listcat, or device characteristics (3390, 4K = 12/track, 180/cylinder) Depends on IMBED (should not be used) choice CA Freespace = N Cis in CA * CA Fspc Percentage rounded up

Determine number of CIs loaded per CA


N CIs in CA - CA Freespace

Determine number of Records per CA


Loaded CIs in CA * NumRecs in CI

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 14

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSAM Catalogs
Required Assigned at IPL by DEF CAT command otherwise by DEFINE MCAT

One Master Catalog

User Catalogs
As desired But, at most one catalog defined on a volume Multiple catalogs can own space on a volume

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 15

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSAM Catalogs
Self describing records User catalog pointers Volume definitions Space definitions Cluster definitions Component (Data, Index) definitions Alternate Index and Path definitions

Catalog contents

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 16

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSAM Catalogs

Recommendations

Use naming conventions Name Cluster, Data and Index components explicitly Use partition and system independent names when applicable Separate Static files (seldom defined or deleted) Dynamic files (frequently defined or deleted) On-line critical files Batch files Multiple baskets -- all the eggs won't be broken Copyright 2003-2006 by Dan Jand
04/09/06 10:08 PM

The Swami of VSE/VSAM 17

Chattanooga Tennessee

VSAM-06.PRZ

2006

VSAM Catalogs
Avoid "One-Way Safety"
Don't use RECOVERABLE catalogs If catalog is damaged, file can be opened with CRA If CRA is damaged, file can't be opened If catalog is restored, CRA can uplevel catalog If CRA is restored, catalog cannot uplevel CRA

Recommendations -- continued

Logic errors can corrupt both catalog and CRA


No recovery help there

Recoverable catalogs were designed in days of small, removable media with (relatively) frequent failures BACKUP is a MUCH better idea
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 18

Chattanooga Tennessee

VSAM-06.PRZ

2006

CI and CA Splits

A CI Split occurs when there is not enough freespace in a CI to hold the record being inserted. CI Split processing -- four writes:
Set "Split in Progress", write CI Move half of records to new CI in buffer, write new CI Update sequence set with new key and pointer, write index CI Erase moved records from old CI in buffer, turn off "Split in Progress", write old CI

Failures:
System fails during split -System corrected at next update access to CI No free CI in the CA -a CA split becomes necessary
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 19

Chattanooga Tennessee

VSAM-06.PRZ

2006

CI and CA Splits

A CA Split occurs when there is not enough freespace in a CA to hold the CI being split. CA Split processing -- MANY writes:
Set "Split in Progress", write sequence set CI Format new CA at High Used RBA position in file Move half of CIs to new CA, read and write each CI moved Write new sequence set CI for new CA Update higher level index CIs as needed (bottom up) Erase moved CIs from old CA, write clear CIs Write updated original sequence set CI

Failures:
System fails during split -System corrected at next update access to CI No free CI in the CA -a CA split becomes necessary 04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 20

Chattanooga Tennessee

VSAM-06.PRZ

2006

CI and CA Splits

Recommendations
Don't worry about CI splits They're inexpensive in time and space Avoid excess CA splits by defining CA Freespace (free CIs in each CA) They can be very expensive in time and space Don't use occurrence of some number of CI or CA splits as a trigger to cause reorganization Better understand the insert strategy VSAM uses Most inserts tend to be somewhat clustered A CI or CA split creates additional freespace exactly where it is most likely to be needed Reorganization will squeeze this freespace out and require more splits in the future, in most cases.
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 21

Chattanooga Tennessee

VSAM-06.PRZ

2006

CI and CA Splits

Recommendations

Avoid too-frequent reorganization Reorganization will squeeze out the free space previous CI and CA splits have inserted If there are more inserts expected in the same area of the file, there will be more splits Once a split has occurred, the processing cost of the split has been paid You have to understand the insert processing one "hot spot" little distributed free space, let splits handle several or many "hot spots" little distributed free space, let splits handle fairly evenly distributed, with no "hot spots" exploit distributed free space Copyright 2003-2006 by Dan Jand
04/09/06 10:08 PM

The Swami of VSE/VSAM 22

Chattanooga Tennessee

VSAM-06.PRZ

2006

Strings and Things (no sealing wax)

VSAM permits multiple concurrent processing


E.G., CICS transactions Browsing Updating Placeholders (commonly called strings) are used to hold file location information

Non-Shared Resources (NSR)


Each string owns buffers for its exclusive use Multiple copies of CIs may be in buffers Works well for single string (e.g. batch type) processing

Local Shared Resources (LSR)


A pool of strings shares a pool of buffers (LSR) Only a single copy of a CI will exist in the pool Ideal for on-line, multiple string processing
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 23

Chattanooga Tennessee

VSAM-06.PRZ

2006

Strings and Things (no sealing wax)

Recommendations:
Non-Shared Resources (NSR) Each string must have adequate index buffers Requirements PER STRING... Unacceptable -- one buffer (old default) Acceptable -- one buffer per index level (new default) Good -- enough buffers to hold all high level index plus one Best -- enough buffers to hold entire index Local Shared Resources (LSR) The pool must have adequate index buffers See above -- Requirements PER STRING becomes IN POOL Monitor VSAM LSR statistics to ensure sufficient buffers are provided in pool to get high probability of finding desired record in the pool (high hit ratio) Data buffers monitored for high hit ratios as well

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 24

Chattanooga Tennessee

VSAM-06.PRZ

2006

Strings and Things (no sealing wax)

Recommendations:
Non-Shared Resources (NSR) Chained I/O strategy used to "read ahead" and "write behind" Better to read multiple CIs in one I/O than to use smaller I/O chains in an overlapping fashion Block big -Large CI sizes Be aware of VSAM splitting CIs into physical blocks to save space e.g. 3390 disk, 32K CI size VSAM will write each CI as two 16K blocks, 1-1/2 CIs, 48K data per track. Buffer big -Allow from 1/2 to a full cylinder of buffer space to minimize I/O time Local Shared Resources (LSR) In LSR, VSAM reads only a single CI at a time No chained I/O benefits even for sequential processing
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 25

Chattanooga Tennessee

VSAM-06.PRZ

2006

Strings and Things (no sealing wax)

Recommendations:

Monitor I/O and buffering LISTCAT statistics (before and after a critical job step) Shows data and index EXCPs EXCP -- EXecute Channel Program -- a physical I/O operation Job Accounting data Shows I/O counts by physical device Useful if files are well distributed across devices Still shows overall I/O and CPU activity CICS Shutdown (and Requested) Statistics Shows Logical and physical I/O counts by file LSR Buffer Pool "hits" and "misses" VSAM buffer statistics information is available Sample subroutine in the VSE/ESA Examples documentation Think big -LSR buffers are in 31-bit storage More are generally better, but don't start paging Copyright 2003-2006 by Dan Jand
04/09/06 10:08 PM

The Swami of VSE/VSAM 26

Chattanooga Tennessee

VSAM-06.PRZ

2006

Sharing VSAM Data Sets

VSAM permits sharing files among partitions in a VSE system VSAM permits sharing files among VSE systems But:
TANSTAAFL (Robert Heinlein) Sharing is not a performance option (The Swami)

Sharing is based on
VSE Lock Table within a single VSE system VSE Lock File when sharing across VSE systems

The VSE sharing mechanism is not compatible with


zOS (or OS/390 or MVS) zVM (or VM/ESA or VM)

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 27

Chattanooga Tennessee

VSAM-06.PRZ

2006

Sharing VSAM Data Sets

Most processing associated with sharing happens at OPEN/CLOSE


Entries are checked and placed in lock table If DASD volume is shared (ADD cuu,SHR) Additional processing is needed Entries are checked and placed in lock file VSE and VSAM permit concurrent processing and can protect against concurrent update activity causing damage to a file Integrity classes NO INTEGRITY -- VSE and VSAM do not provide data protection services and your data can be destroyed WRITE INTEGRITY -- VSE and VSAM protect your data from corruption by other output activity READ INTEGRITY -- VSE and VSAM ensure your program will always "see" the latest version of any record being read

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 28

Chattanooga Tennessee

VSAM-06.PRZ

2006

Sharing VSAM Data Sets

Most processing associated with sharing happens at OPEN/CLOSE


Integrity Scope Within a single VSE system image Multiple partitions Across multiple VSE system images Multiple partitions in multiple VSE systems Integrity Costs Higher levels of integrity require more processing Broader scopes of integrity require more processing SHAREOPTION specifications made at DEFINE CLUSTER SHR(1) -- Single output or multiple input OPENs permitted SHR(2) -- Single output and multiple input OPENs permitted SHR(3) -- No VSE or VSAM checking or locking performed SHR(4) -- Multiple output OPENs in one VSE system, and multiple input OPENs across all VSE systems SHR(4 4) -- Multiple output OPENs across all VSE systems multiple input OPENs as well Copyright
04/09/06 10:08 PM

2003-2006 by Dan Jand The Swami of VSE/VSAM 29

Chattanooga Tennessee

VSAM-06.PRZ

2006

Sharing VSAM Data Sets

Most processing associated with sharing happens at OPEN/CLOSE


SHAREOPTION specifications made at DEFINE CLUSTER SHR(1) -- Single output or multiple input OPENs permitted External lock at OPEN, unlock at CLOSE SHR(2) -- Single output and multiple input OPENs permitted External lock at OPEN, unlock at CLOSE SHR(3) -- No VSE or VSAM checking or locking performed No locking -- your data can be corrupted SHR(4) -- Multiple output OPENs in one VSE system, and multiple input OPENs across all VSE systems External lock at OPEN, unlock at CLOSE Internal lock at access, unlock at release SHR(4 4) -- Multiple output OPENs across all VSE systems multiple input OPENs as well External lock at OPEN, unlock at CLOSE External lock at access, unlock at release If file is not resident on shared device, external locks become internal locks
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 30

Chattanooga Tennessee

VSAM-06.PRZ

2006

Alternate Index Information


They serve as "finder files" or "pointer files" for another file Target file (Base Cluster) can be KSDS Pointers will be Base Cluster key values Target file (Base Cluster) can be ESDS Pointers will be Relative Byte Addresses Ideal when multiple keys are needed, or for non-unique keys BUT remember Processing a file through an AIX requires both Processing of the AIX This may be sequential processing Processing of the Base Cluster This is ALWAYS direct processing

Alternate Indexes (AIX) are VSAM KSDS files

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 31

Chattanooga Tennessee

VSAM-06.PRZ

2006

Alternate Index Information


DEFINE CLUSTER for the base cluster as usual DEFINE AIX for the Alternate Index cluster Specify base cluster's name, alternate key Data and Index CI sizes DEFINE PATH Permits specification of NOUPGRADE paths BLDINDEX Scans base cluster Extracts primary and alternate key information Sorts into alternate key sequence Loads alternate index

Alternate Index Definition and Loading

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 32

Chattanooga Tennessee

VSAM-06.PRZ

2006

Alternate Index Information

Recommendations
Don't use AIX instead of SORT when processing all records in base cluster Remember base cluster will be processed directly, based on alternate key values Base cluster will need additional index buffering for batch ONLY WAY to do this is to specify much larger value for the Base Cluster's BUFFERSPACE when it is defined Make it large enough to hold all the base cluster's index records if possible -- all the high-level index records if not.

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 33

Chattanooga Tennessee

VSAM-06.PRZ

2006

Alternate Index and CICS

LSR considerations for CICS


New jargon... SPHERE a base cluster and all AIX (paths) related to it Requirements Each sphere must be wholly within one LSR pool (AIX paths must be in same LSR pool as their base cluster) Use Data Set Name Sharing (see CICS documentation) In CICS 2.3, add BASE=cluster's file name to FCT entries for: Base cluster file entry Each related path file entry In CICS TS this is automatic Don't use SHR(3) or (4) or (4 4) for these files SHR(2) should be sufficient Check with VSAM and CICS level 2 for any applicable service!
04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 34

Chattanooga Tennessee

VSAM-06.PRZ

2006

Contacting the Presenter


You can contact the Swami by e-mail theswami@epix.net

For more information...

He's building a web site about VSE/VSAM issues http://business.epix.net/~theswami His knowledge and experience can help you, too!

04/09/06 10:08 PM

Copyright 2003-2006 by Dan Jand The Swami of VSE/VSAM 35

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy