Translate

Mostrar mensagens com a etiqueta storage management. Mostrar todas as mensagens
Mostrar mensagens com a etiqueta storage management. Mostrar todas as mensagens

terça-feira, 31 de março de 2026

🔥 SEUS DADOS NÃO MORAM NO DISCO… ELES VIAJAM PELO UNIVERSO DO z/OS 😳

 

Bellacosa Mainframe num mergulho no mundo storage do z/os

🔥 SEUS DADOS NÃO MORAM NO DISCO… ELES VIAJAM PELO UNIVERSO DO z/OS 😳

O guia proibido de Storage Management que revela como memória, disco e sysplex trabalham juntos (e quase ninguém entende)

Você acha que seu dataset “fica no disco”?

👉 Não fica.

No z/OS, dados:

  • sobem pra memória
  • descem pra disco
  • migram pra fita
  • aparecem em outro LPAR
  • e até existem fora do seu address space

💥 “No mainframe, dado não tem endereço fixo… tem estratégia.”

Se você quer sair do nível “usuário” e pensar como engenheiro de sistema, esse é o mapa completo 👊🔥


🧠 1. ADDRESS SPACE — O UNIVERSO DO PROGRAMA

Cada programa roda em um address space isolado.


🔥 O que isso significa?

  • memória protegida
  • ambiente independente
  • controle total do sistema

💡 Insight

cada address space é um “universo privado”


⚡ 2. 64-BIT ADDRESSING — MEMÓRIA INFINITA (QUASE)

Com 64 bits:

👉 até 16 EXABYTES


🔥 Evolução histórica

EraLimite
24-bit16MB 😱
31-bit2GB
👉 64-bit16EB 🤯

💡 Tradução Bellacosa

“acabou a desculpa de falta de memória”


🧠 Uso real

  • Java
  • Db2
  • middleware
  • grandes buffers

🧩 3. DAT — A MÁGICA DA TRADUÇÃO

DAT (Dynamic Address Translation):

👉 converte endereço virtual → real


🔥 Sem DAT:

  • programa quebraria
  • memória não funcionaria

💡 Tradução

“você nunca acessa memória real diretamente”


🧠 4. STORAGE REQUESTS — COMO A MEMÓRIA É PEDIDA

Programas pedem memória via:

  • GETMAIN
  • STORAGE OBTAIN

🔥 O sistema decide:

  • onde alocar
  • em qual subpool
  • com qual proteção

💡 Insight

memória é gerenciada, não livre


🧱 5. SUBPOOLS — ORGANIZAÇÃO INTERNA

Memória é dividida em:

👉 subpools


🔥 Exemplos:

  • SP0 → sistema
  • SP229 → usuário

💡 Tradução

“cada tipo de dado tem seu bairro”


🌍 6. DATA SPACES & HIPERSPACES — FORA DO ADDRESS SPACE

🔹 Data Spaces

  • dados fora do address space
  • acessados via AR

🔹 Hiperspaces

  • alta performance
  • acesso indireto

🔥 Tradução Bellacosa

“memória extra fora do seu universo”


🧠 Exemplo

Programa → usa Data Space → grande volume de dados

⚡ 7. PAGING — QUANDO A MEMÓRIA NÃO CABE

Se falta memória:

👉 dados vão para disco (paging)


🔥 Fluxo

Memória cheia

página vai para DASD

quando necessário → volta

💡 Problema

👉 excesso de paging = sistema lento 💀


💾 8. FLASH STORAGE — O TURBO MODERNO

Flash (SSD):

  • baixa latência
  • alta velocidade
  • ideal para OLTP

💡 Uso

  • Db2
  • logs
  • datasets críticos

🔗 9. PARALLEL SYSPLEX — MEMÓRIA COMPARTILHADA ENTRE SISTEMAS

Aqui fica poderoso 😄


🔥 O que é?

Vários z/OS trabalhando juntos:

👉 como um só sistema


💡 Elementos:

  • LPARs
  • Coupling Facility (CF)
  • links de comunicação

🧠 Exemplo

LPAR A → acessa dado
LPAR B → acessa o mesmo dado

💡 Tradução

“dados compartilhados em tempo real”


🧠 10. COUPLING FACILITY (CF) — O CÉREBRO COMPARTILHADO

🔹 Função:

  • lock management
  • cache
  • filas

🔥 Tipos:

  • Internal CF
  • External CF

💡 Tradução Bellacosa

“CF = memória compartilhada do sysplex”


⚡ 11. DUPLEXING — ZERO PERDA

🔥 O que faz?

  • duplica dados
  • garante disponibilidade

💡 Exemplo

CF primário → falha
CF secundário → assume

🧨 Curiosidade

Sistema continua rodando sem impacto 😳


🧠 12. CF OPERATIONS — O QUE ACONTECE POR TRÁS

CF gerencia:

  • locks
  • buffers
  • filas

💡 Uso real

  • Db2 data sharing
  • CICS
  • IMS

⚙️ 13. STORAGE + I/O + CPU — TUDO CONECTADO

Nada funciona isolado:

Memória → I/O → CPU → WLM → Storage

💡 Insight

performance é resultado do conjunto


🔄 14. PASSO A PASSO COMPLETO

Programa inicia

recebe address space

pede memória (GETMAIN)

DAT traduz endereço

usa data space se necessário

paging ocorre se faltar memória

dados vão para disco/flash

sysplex compartilha dados via CF

duplex garante disponibilidade

🧨 CURIOSIDADES (NÍVEL ROOT)

🤯 1. Você não controla diretamente onde o dado está


🔥 2. Dados podem estar fora do seu address space


💀 3. Paging excessivo mata performance


🧠 4. Sysplex permite vários sistemas compartilharem dados


⚡ 5. CF é o segredo da alta disponibilidade


🎯 RESUMO FINAL

✔ Address space = isolamento

✔ 64-bit = escala absurda

✔ DAT = tradução

✔ Subpools = organização

✔ Data space = expansão

✔ Paging = fallback

✔ Flash = velocidade

✔ Sysplex = escala

✔ CF = coordenação

✔ Duplexing = resiliência


💥 FRASE FINAL

“No z/OS, dados não ficam armazenados… eles são orquestrados entre memória, disco e múltiplos sistemas em tempo real.”

sábado, 10 de janeiro de 2026

💣 IDCAMS NÃO É SÓ DELETE E DEFINE — É O CANIVETE SUÍÇO QUE TODO DEV COBOL SUBESTIMA! 🔥

 

Bellacosa Mainframe arpesenta o IDCAMS no Z/OS

💣 IDCAMS NÃO É SÓ DELETE E DEFINE — É O CANIVETE SUÍÇO QUE TODO DEV COBOL SUBESTIMA! 🔥

Os segredos obscuros, históricos e poderosos do utilitário que governa o mundo VSAM no z/OS

Se você é um dev COBOL sênior e acha que já viu de tudo no z/OS… cuidado. O IDCAMS é aquele tipo de ferramenta que parece simples — até o dia em que salva (ou destrói) seu ambiente em produção.

Este não é um artigo básico. É um mergulho profundo, no estilo Bellacosa Mainframe: com história, bastidores, exemplos reais, curiosidades obscuras e aqueles “easter eggs” que só quem vive o mainframe conhece.


🧠 O QUE É IDCAMS — DE VERDADE?

O IDCAMS (Access Method Services) é o utilitário oficial do z/OS para gerenciar datasets VSAM e não-VSAM.

Mas reduzir o IDCAMS a “DEFINE e DELETE” é como dizer que COBOL é só MOVE e PERFORM.

👉 Ele é, na prática:

  • Um gerenciador de estruturas físicas de dados
  • Um motor de diagnóstico
  • Um orquestrador de catálogos
  • Um cirurgião de datasets corrompidos

🕰️ ORIGEM — QUANDO TUDO COMEÇOU

O IDCAMS nasceu junto com o VSAM (Virtual Storage Access Method) lá na década de 1970, substituindo métodos mais antigos como:

  • ISAM
  • BDAM
  • QSAM (ainda usado, mas com outro propósito)

📌 A ideia era revolucionária:

Criar um sistema de arquivos com acesso indexado, eficiente e resiliente.

E o IDCAMS virou o “painel de controle” disso tudo.


⚙️ O CORE DO IDCAMS — COMANDOS ESSENCIAIS

Vamos além do básico.

🔹 DEFINE — Criando um KSDS (o clássico)

//STEP01 EXEC PGM=IDCAMS
//SYSPRINT DD SYSOUT=*
//SYSIN DD *
DEFINE CLUSTER(NAME(MEU.KSDS)
INDEXED
KEYS(10 0)
RECORDSIZE(80 80)
TRACKS(10 5)
FREESPACE(10 10))
/*

💡 Insight avançado:

  • FREESPACE impacta diretamente performance e splits
  • TRACKS(prim sec) influencia fragmentação futura

🔹 DELETE — O perigo silencioso

DELETE MEU.KSDS CLUSTER

💣 Easter egg:
Se você rodar DELETE sem checar o catalog corretamente…
👉 Pode apagar mais do que imagina (especialmente com aliases mal configurados)


🔹 REPRO — O verdadeiro “MOVE” do mundo VSAM

REPRO INFILE(INPUT) OUTFILE(OUTPUT)

🔥 Muito mais poderoso do que parece:

  • Migração entre VSAM ↔ PS
  • Backup
  • Recovery
  • Testes de carga

💡 Dica de sênior:
Use REPRO ... REPLACE com extremo cuidado — ele sobrescreve sem dó.


🔹 LISTCAT — O raio-X do dataset

LISTCAT ENT(MEU.KSDS) ALL

📌 Aqui mora o ouro:

  • CI/CA size
  • Número de registros
  • Status físico
  • Informações de catálogo

💡 Curiosidade:
Muitos problemas de performance são detectáveis apenas com LISTCAT bem interpretado.


⚖️ Pontos Fortes vs Limitações

✅ Fortes

  • Nativo do z/OS
  • Extremamente poderoso
  • Sem custo adicional
  • Alta performance

❌ Limitações

  • Sintaxe pouco amigável
  • Documentação densa
  • Erros pouco intuitivos 

🧪 LAB PRÁTICO — DO ZERO AO CONTROLE TOTAL

🎯 Objetivo:

Criar, popular, consultar e remover um VSAM


🥇 Passo 1 — Criar KSDS

Use DEFINE (já vimos)


🥈 Passo 2 — Inserir dados via REPRO

//INPUT DD *
0000000001CLIENTE A
0000000002CLIENTE B
/*
//OUTPUT DD DSN=MEU.KSDS,DISP=OLD
REPRO INFILE(INPUT) OUTFILE(OUTPUT)

🥉 Passo 3 — Validar estrutura

LISTCAT ENT(MEU.KSDS) ALL

🏁 Passo 4 — Limpeza controlada

DELETE MEU.KSDS CLUSTER

🧬 CURIOSIDADES QUE POUCOS CONHECEM

🧩 1. IDCAMS NÃO É SÓ VSAM

Ele também gerencia:

  • GDG
  • Catalogs
  • Non-VSAM datasets

🧩 2. O “SET MAXCC” — o hack elegante

IF MAXCC > 0 THEN SET MAXCC = 0

🔥 Isso evita falhas em jobs quando o erro é esperado
(clássico em DELETE de dataset inexistente)


🧩 3. O retorno não é só 0 ou 8

Códigos comuns:

  • 0 → sucesso
  • 4 → warning
  • 8 → erro
  • 12/16 → desastre

💡 Dev sênior usa isso para lógica de controle em JCL


🧩 4. Você pode “debugar” storage com IDCAMS

Comandos como:

  • PRINT
  • VERIFY
  • EXAMINE

👉 Permitem inspecionar dados em baixo nível


🧠 DICAS DE OURO PARA DEV COBOL SÊNIOR

✔ Nunca culpe o COBOL antes de olhar o VSAM via IDCAMS
✔ LISTCAT é seu melhor amigo em troubleshooting
✔ REPRO é sua arma secreta para testes e recovery
✔ DELETE sem critério é suicídio em produção
✔ Entender CI/CA é mais importante que decorar sintaxe


⚠️ ARMADILHAS REAIS (BASEADAS EM CAMPO)

💣 Dataset aparentemente vazio… mas com índice inconsistente
💣 REPRO truncando dados por RECORDSIZE incorreto
💣 DEFINE com KEYS errado causando caos silencioso
💣 Catalog apontando para dataset inexistente


🧠 REFLEXÃO FINAL

O IDCAMS é aquele tipo de ferramenta que separa:

  • quem usa mainframe
    de quem entende mainframe

Ele opera no nível onde:
👉 estrutura física
👉 performance
👉 integridade

…se encontram.


☕ ESTILO BELLACOSA — VEREDITO FINAL

Se você domina COBOL mas ignora IDCAMS…

👉 você está pilotando um avião sem entender o motor.



💥 TABELA COMPLETA — PARÂMETROS IDCAMS (NA PRÁTICA)


🧱 🔹 DEFINE CLUSTER (o mais importante de todos)

ParâmetroTipoDescriçãoInsight de campo
NAMEobrigatórioNome do datasetBase de tudo
INDEXEDtipoKSDSMais comum
NONINDEXEDtipoESDSSequencial
LINEARtipoLDSUsado por DB2
KEYS(length offset)obrigatório (KSDS)Define chaveErro aqui = desastre
RECORDSIZE(avg max)obrigatórioTamanho registroImpacta CI
FREESPACE(ci ca)opcionalEspaço livreEvita split
CYLINDERS(primary secondary)opcionalAlocaçãoProdução padrão
TRACKSopcionalAlternativa a cilindrosMais granular
SHAREOPTIONS(x y)opcionalConcorrênciaCICS crítico
REUSEopcionalReutilizaçãoBatch útil
SPEEDopcionalMais rápidoSem recovery
RECOVERYopcionalMais seguroDefault prod
UNIQUEKEYopcionalChave únicaDefault KSDS
NONUNIQUEKEYopcionalPermite duplicidadeMuito usado
BUFFERSPACEopcionalMemóriaRaro
CISZopcionalControl IntervalPerformance tuning
VOLUMESopcionalVolume físicoStorage define
ERASEopcionalSegurançaLGPD vibes 😄
CONTROLINTERVALSIZEopcionalMesmo que CISZNome longo
IMBEDopcionalÍndice embutidoRaro hoje
REPLICATEopcionalReplica índiceLegado
LOG / NOLOGopcionalLoggingBatch tuning

🧩 🔹 DEFINE DATA / INDEX

ParâmetroDescriçãoObservação
NAMENome componenteObrigatório
CYLINDERS / TRACKSEspaçoSeparação física
VOLUMESVolumeMulti-volume
CONTROLINTERVALSIZECI sizeAjuste fino
FREESPACEEspaço livreMesmo conceito
BUFFERSPACEMemóriaPouco usado

💡 Insight:
Separar DATA e INDEX melhora performance em ambientes grandes.


🔄 🔹 REPRO (o ETL raiz do mainframe)

ParâmetroDescriçãoUso real
INFILEEntrada DDBatch clássico
OUTFILESaída DD
INDATASETEntrada diretaAlternativa
OUTDATASETSaída direta
REPLACESobrescreveMuito usado
COUNT(n)Limite registrosTeste
SKIP(n)Pula registrosDebug
FROMKEYInício por chaveVSAM
TOKEYFim por chaveVSAM
KEYSIntervaloFiltro
LOG / NOLOGLoggingPerformance
FASTLOADCarga rápidaGrandes volumes

💣 Insight avançado:
REPRO pode substituir ferramentas ETL simples.


🔍 🔹 LISTCAT (diagnóstico avançado)

ParâmetroDescriçãoUso
ENTRY / ENTNome datasetDireto
ALLTudoSempre usar
LEVELPrefixoListagem
HISTORYHistóricoAuditoria
VOLUMEInfo volumeStorage
ALLOCATIONEspaçoCapacidade

💡 Dica:
LISTCAT é seu “debugger de storage”.


❌ 🔹 DELETE

ParâmetroDescriçãoRisco
CLUSTERRemove tudoNormal
DATASó dadosAvançado
INDEXSó índiceRaro
PURGEIgnora proteção💀 perigoso
ERASEApaga fisicamenteSegurança
NOSCRATCHRemove catálogo apenasDeixa dados

🔧 🔹 ALTER

ParâmetroDescriçãoUso
NEWNAMERenomeiaMuito usado
VOLUMESMuda volumeStorage
BUFFERSPACEAjuste memóriaRaro

🖨️ 🔹 PRINT

ParâmetroDescriçãoUso
INDATASETDatasetBase
CHARACTERTextoDebug
HEXHexadecimalDebug avançado
DUMPDump brutoForense
COUNTLimiteTeste

🧪 🔹 VERIFY

ParâmetroDescrição
DATASETDataset alvo
RECOVERTenta corrigir

👉 Essencial após crash


⚙️ 🔹 Parâmetros via DD (tuning real)

ParâmetroOndeDescrição
AMPDDParâmetros avançados
BUFNDAMPBuffers de dados
BUFNIAMPBuffers de índice
STRNOAMPConcorrência
OPTCDAMPModo acesso
MACRFAMPMétodo acesso

🧠 🔹 Parâmetros menos conhecidos (nível ninja)

ParâmetroDescriçãoQuando usar
IMBEDÍndice dentro do CIPequenos datasets
REPLICATEReplica índiceLegado
LOGLoggingAuditoria
NOLOGSem logPerformance
SPEEDPerformanceBatch
RECOVERYSegurançaProd

🤯 RELAÇÃO COM COBOL (o que ninguém explica)

Tudo isso impacta diretamente:

  • FILE STATUS
  • Tempo de I/O
  • Locks (CICS)
  • CPU usage

👉 Exemplo real:

  • FREESPACE errado → split → slowdown → batch estoura janela

⚖️ RESUMO ESTRATÉGICO

👉 Os parâmetros mais críticos na prática:

  1. KEYS
  2. RECORDSIZE
  3. FREESPACE
  4. CISZ
  5. SHAREOPTIONS
  6. BUFND / BUFNI

🧨 VERDADE FINAL 

“IDCAMS não é sobre comando…
é sobre controle físico dos dados.”

Se você domina isso:

  • Você prevê problema antes de acontecer
  • Você resolve incidente sem depender de ninguém
  • Você vira referência no time


domingo, 10 de novembro de 2019

☕💥 A Jornada do Padawan COBOL – Parte 11 Desvendando o Universo dos CALLs no Mainframe

 

Bellacosa Mainframe apresenta o call em cobol parte xi

☕💥 A Jornada do Padawan COBOL – Parte 11

Desvendando o Universo dos CALLs no Mainframe

GRS, ENQ/DEQ, VVDS, VTOC, UCB, IOS, FICON, Channel Subsystem e os Segredos dos Guardiões do Storage IBM Z

Ou como descobrir que, antes de um simples OPEN funcionar, dezenas de componentes já trabalharam silenciosamente para você

Por Vagner Bellacosa – Bellacosa Mainframe


O dia em que o Padawan percebe que um OPEN não é apenas um OPEN

Após dez capítulos, nosso Padawan já entende:

✔ CALL

✔ LE

✔ CICS

✔ JES2

✔ RMF

✔ Telum

✔ Spyre

✔ DevOps

Então ele escreve:

OPEN INPUT CLIENTES

E pensa:

Deve ser simples...

Veterano do Storage sorri.

Não responde.

Abre RMF.

Abre ISMF.

Abre DEVSERV.

E diz:

— Vamos conversar.


O Grande Segredo

Antes do OPEN ocorrer.

Diversos subsistemas trabalham.


Visualmente


COBOL

↓

OPEN

↓

LE

↓

Access Method

↓

Catalog

↓

VVDS

↓

VTOC

↓

UCB

↓

IOS

↓

Channel Subsystem

↓

FICON

↓

DASD


Padawan:

— Tudo isso?

Veterano:

— Apenas para abrir um arquivo.


GRS

Global Resource Serialization


Pouquíssimos desenvolvedores conhecem.

Todos usam.

Diariamente.


Ele evita.

Caos.


Imagine:

Programa A

Atualizando KSDS.

Programa B

Atualizando KSDS.

Programa C

Atualizando KSDS.


Sem GRS.

Corrupção.


Com GRS.

Ordem.

Disciplina.


ENQ

Reserve recurso.


Exemplo

ENQ


SYSDSN


CLIENTE.MASTER

Programa obtém.

Exclusividade.


DEQ

Libera.


Exemplo

DEQ


CLIENTE.MASTER

Easter Egg

Muitos problemas batch.

São.

ENQ presos.


Como descobrir?

SDSF

GRSQ

D GRS


RESERVE

Mais antigo.


Bloqueia.

Dispositivo físico.


Pouco usado.

Hoje.


Sysplex prefere.

GRS.


Catalog

O Google.

Do Mainframe.


Pergunta.

Onde está.

CLIENTE.MASTER?

Catalog responde.

Volume.

Device.

VVDS.


VVDS

VSAM Volume Data Set


Armazena.

Informações VSAM.


Exemplo

KSDS.

ESDS.

RRDS.


VTOC

Volume Table Of Contents


O índice.

Do disco.


Sem VTOC.

Nada existe.


Visualmente


3390


↓

VTOC


↓

Dataset



DSCB

Data Set Control Block


Informações.

Dataset.


Organização.

Extents.

Blocos.


UCB

Unit Control Block


Representa.

Dispositivo.


Exemplo

3390-123


UCB


ONLINE

IOS

Input Output Supervisor


Herói desconhecido.


Gerencia.

I/O.


Escalona.

Requisições.


Comunica.

Canal.


Channel Subsystem

Uma obra-prima IBM.


CPU.

Não conversa.

Diretamente.

Com disco.


Canal conversa.


Visualmente


CPU


↓


CSS


↓


FICON


↓


Storage




FICON

Fiber Connectivity


Substituiu.

ESCON.


Velocidade.

Gigabits.


Latência.

Mínima.


Disponibilidade.

Enorme.


Pidb

Pouco conhecido.


Performance Information Data Base


Engenheiros IBM.

Gostam.

Muito.


Dynamic Path Management

Storage inteligente.


Falhou caminho?

Troca automaticamente.


Aplicação.

Nem percebe.


HyperPAP

Outro segredo.


Balanceia.

I/O.


Otimiza.

Caminhos.


OPEN em detalhes

Padawan escreve.

OPEN INPUT CLIENTE

Sistema executa.


OPEN


↓

Catalog


↓

VVDS


↓

VTOC


↓

GRS


↓

IOS


↓

CSS


↓

FICON


↓

DASD


↓

Retorna



Tudo.

Em milissegundos.


O dia em que o arquivo não abre

Padawan vê.

IEC161I

Pânico.


Veterano pergunta.

Volume?

Catalog?

VVDS?

ENQ?

Path?

FICON?

IOS?


Padawan.

Silêncio.


Ferramentas Jedi

LISTCAT

LISTCAT ENT(CLIENTE.MASTER)

D U,DASD

Ver dispositivos.


DEVSERV

Ver caminhos.


D GRS

Ver locks.


ISMF

Storage Management.


RMF

Pode mostrar.


Tempo de I/O.


Cache Hit.

Miss.


Path Busy.


SMF

Tipos úteis.

SMF42

DFSMS

SMF74

Coupling

SMF70

CPU


Dicas Bellacosa

Dica 1

Aprenda LISTCAT.


Dica 2

Estude VVDS.


Dica 3

GRS salva vidas.


Dica 4

FICON é fascinante.


Dica 5

IOS merece respeito.


Easter Egg Mainframe

Existe um pequeno grupo.

Que consegue olhar.

Isto.

IOS000I


GRS


SMF42


RMF74


UCB


VVDS


E descobrir.

Em dez minutos.

Porque um banco inteiro.

Parou.


Eles.

Não usam capa.

Mas deveriam.


São conhecidos.

Como.

Os Guardiões do Storage IBM Z


Checklist Jedi

✅ Entender GRS

✅ Conhecer ENQ

✅ Conhecer DEQ

✅ Estudar Catalog

✅ Dominar LISTCAT

✅ Aprender VVDS

✅ Entender VTOC

✅ Conhecer UCB

✅ Respeitar IOS

✅ Estudar CSS

✅ Conhecer FICON

✅ Interpretar RMF


A Filosofia Jedi – Parte 11

O Padawan iniciante acredita:

OPEN é um comando.

O desenvolvedor experiente pensa:

OPEN localiza datasets.

O especialista compreende:

OPEN coordena dezenas de componentes do z/OS.

E o Arquiteto IBM Z sabe algo ainda mais profundo:

Um simples OPEN INPUT CLIENTE aciona mecanismos de serialização global, gerenciamento de catálogos, subsistemas de I/O, canais FICON, estruturas de controle de storage e décadas de engenharia IBM, tudo isso para que o desenvolvedor apenas enxergue:

OPEN INPUT CLIENTE

E continue acreditando que foi algo simples.


Próxima aventura do Padawan COBOL – Parte 12

"As Runas Finais do IBM Z: PSA, CVT, ASCB, TCB, RB, SRB, ACEE, CSA, ECSA, SQA, LSQA, PSA Internals e os mistérios dos Control Blocks que sustentam todo o universo z/OS."