Comunicação Inter-Processo em Unix. Pipes FIFO (Named Pipes) Pipes
|
|
|
- Maria dos Santos Prado Cortês
- 9 Há anos
- Visualizações:
Transcrição
1 Comunicação Inter-Processo em Unix Pipes FIFO (Named Pipes) 1 Pipes 2 1!
2 Comunicação entre pai e filho Ao chamar um fork(), processos pai e filho deixam de compartilhar memória Como fazer então para que o resultado de um processo possa ser recebido pelo outro? Exemplos: Processo pai distribui dados para os processos filho, que devolvem resultados que são consolidados pelo pai. 3 Pipes como mecanismo de comunicação entre processos Na shell, em cmd1 cmd2 estamos direcionando o STDOUT de cmd1 para o STDIN de cmd2 Exemplos: > ps aml sort r k 7 less // lista os processos com maior uso de memória > ps axl grep zombie // lista todos os processos zombie (*) Isso é um pipe (ou pipeline), ou seja, um canal, que é uma estrutura de dados do kernel Processos pai e filho podem se comunicar através de pipes. Usa-se a a função de sistema pipe() Obs: (*) processo zombie já terminou a sua execução mais ainda tem sua entrada na tabela de processos, que é necessária para o pai ler o status de exit do filho. 4 2!
3 Função pipe() Cria um canal de comunicação entre processos Definido em <unistd.h> int pipe(int fd[2]); Cria dois canais de comunicação (visíveis pelo pai e filho) fd[0] é aberto para leitura fd[1] é aberto para escrita Retorna: 0 (zero) em caso de sucesso -1 em caso de erro Função pipe() Pipes abertos pela função pipe() devem ser fechados pela função close() Dados escritos no descritor de arquivo fd[1] podem ser lidos do fd[0] Dois processos podem se comunicar através de um pipe se eles lêem e escrevem em fd[0] e fd[1] respectivamente Os dados são transmitidos e recebidos através de write() e read() 3!
4 Função pipe() processo pipe() processo fd[0] fd[1] fork() pai fd[0] fd[1] fd[1] fd[0] filho Esquema de comunicação via pipe pipe(fd)! fork()! Para um pipe do pai para o filho, o pai fecha fd[0] e o filho fecha o fd[1].! Para um pipe do filho para o pai, ocorre o contrário.! close(fd[1])! close(fd[0])! read(fd[0])! write(fd[1])! close(fd[0])! close(fd[1])! Processo pai! Processo filho! 4!
5 Criando os canais com pipe() int fd[2]; // descritor dos pipes if (pipe(fd) < 0) puts ("Erro ao abrir os pipes"); exit (-1); Em caso de sucesso, a chamada à pipe() retorna 0 e fd[0] conterá o descritor de leitura e fd[1] o de escrita Em caso de falha, a função retorna -1 Função write() Utilizada para escrever dados em um arquivo ou qualquer outro objeto identificado por um descritor de arquivo (file descriptor) Definido em <unistd.h> ssize_t write(int fildes, const void *buf, size_t nbyte); Onde fildes : é o descritor do arquivo (ou do pipe) buf : endereço da área de memória onde estão os dados que serão escritos nbytes : número de bytes que serão escritos Valor retornado: Em caso de sucesso, a função retorna a quantidade de dados escritas Em caso de falha, o valor retornado difere da quantidade de bytes enviados 5!
6 Função read() Lê dados de um arquivo ou de qualquer outro objeto identificado por um descritor de arquivo Definido em <unistd.h> ssize_t read(int fildes,void *buf, size_t nbyte); Onde: fildes : descritor do arquivo buf : endereço de memória onde os dados serão armazenados depois de lidos nbyte : quantidade máxima de bytes que podem ser transferidos Retorna: Quantidade de dados lidos Exemplo do uso de pipe #include <stdio.h> #include <string.h> #include <stdlib.h> #include <unistd.h> int main (int argc, char *argv[]) int ndadostx, ndadosrx; // quantidade de dados transmitidos/recebidos int fd[2]; // descritor dos pipes const char textotx[] = "uma mensagem"; char textorx[sizeof textotx]; if (pipe(fd) < 0) puts ("Erro ao abrir os pipes"); exit (-1); ndadostx = write(fd[1], textotx, strlen(textotx)+1); printf("%d dados escritos\n", ndadostx); ndadosrx = read(fd[0], textorx, sizeof textorx); printf("%d dados lidos: %s\n", ndadosrx, textorx); close(fd[0]); close(fd[1]); return 0; 6!
7 Exemplo: pai escreve para o filho #include <stdio.h> #include <string.h> #include <stdlib.h> #include <unistd.h> void main () int fd[2]; pipe(fd); if (fork() == 0) /* filho */ close(fd[1]); /* fd[1] desnecessario */ read(fd[0],...); /* lê do pai */... else close(fd[0]); /* fd[1] desnecessario */ write(fd[1],...); /* escreve para o filho */... Outras formas de comunicação entre processos Named pipes (FIFO) usa o Sistema de Arquivos (mas não cria um arquivo de fato) Usa-se mkfifo() ou mknod()! Exemplo: mkfifo my_pipe! gzip -9 c < my_pipe > out.gz &! cat file > my_pipe!! rm my_pipe Anonymous pipe = apenas em uma direcão 14 7!
8 FIFO (ou named pipes) FIFO permite que dois processos quaisquer se comuniquem Um named pipe é um tipo especial de arquivo presente no sistema de arquivo Criando FIFO s FIFO s são criadas pelo comando mkfifo $ mkfifo filename FIFO pela linha de comando: 8!
9 Criando FIFO s Em um programa C, podemos utilizar a seguinte chamada do sistema (system call) Definido em: <sys/stat.h> int mkfifo(const char *filename, mode_t mode); Onde: filename : nome da FIFO a ser criada mode : bits com as permissões de criação da mesma forma que para arquivos (user, group, other) x (read, write) S_IRUSR S_IWUSR S_IRGRP S_IWGRP S_IROTH S_IWOTH... Retorna: Em caso de sucesso, 0 (zero) Em caso de erro, -1 Criando uma FIFO #include <stdio.h> #include <sys/stat.h> int main (void) if (mkfifo("minhafifo", S_IRUSR S_IWUSR) == 0) puts ("FIFO criada com sucesso"); return 0; puts ("Erro na criação da FIFO"); return -1; 9!
10 Utilizando a FIFO int main (void) FILE *parq; if ((parq = fopen("minhafifo", "w")) == NULL) puts ("Erro ao abrir a FIFO para escrita"); return -1; fputs ("Melancia sem caroço", parq); fclose (parq); return 0; int main (void) FILE *parq; char ch; if ((parq = fopen("minhafifo", "r")) == NULL) puts ("Erro ao abrir a FIFO para escrita"); return -1; while ((ch = fgetc(parq))!= EOF) putchar (ch); fclose (parq); return 0; FIFO: comunicação unidirecional Um programa não deve abrir uma FIFO para leitura e escrita. Se houver necessidade de comunicação bidirecional, devemos utilizar duas FIFO s, uma para cada direção 10!
11 Abertura de FIFO pode ser blockin ou nonblocking Determinado pela flag O_NONBLOCK open(const char *path, O_RDONLY); Neste caso, a chamada a open( ) ficará bloqueada até que um processo abra a mesma FIFO para escrita. open(const char *path, O_RDONLY O_NONBLOCK); A chamada a open( ) retornará imediatamente, mesmo que a FIFO não tenha sido aberta para escrita por outro processo open(const char *path, O_WRONLY); Neste caso, a chamada a open( ) irá bloquear o processo até que a mesma FIFO seja aberta para leitura open(const char *path, O_WRONLY O_NONBLOCK); A chamada retorna imediatamente, mas se a FIFO não estiver aberta para leitura por algum processo, open( ) retorna -1 indicando erro Abrindo FIFO para leitura sem bloqueio #include < > #define OPENMODE (O_RDONLY O_NONBLOCK) #define FIFO "minhafifo" int main (void) int fpfifo; char ch; if (access(fifo, F_OK) == -1) if (mkfifo (FIFO, S_IRUSR S_IWUSR)!= 0) fprintf (stderr, "Erro ao criar FIFO %s\n", FIFO); return -1; puts ("Abrindo FIFO"); if ((fpfifo = open (FIFO, OPENMODE)) < 0) fprintf (stderr, "Erro ao abrir a FIFO %s\n", FIFO); return -2; puts ("Começando a ler..."); while (read (fpfifo, &ch, sizeof(ch)) > 0) putchar (ch); puts ("Fim da leitura"); close (fpfifo); return 0; 11!
12 Abrindo FIFO para escrita sem bloqueio #include < > #define OPENMODE (O_WRONLY O_NONBLOCK) #define FIFO "minhafifo" int main (void) int fpfifo; char mensagem[] = "Melancia sem caroço"; if (access(fifo, F_OK) == -1) if (mkfifo (FIFO, S_IRUSR S_IWUSR)!= 0) fprintf (stderr, "Erro ao criar FIFO %s\n", FIFO); return -1; puts ("Abrindo FIFO"); if ((fpfifo = open (FIFO, OPENMODE)) < 0) fprintf (stderr, "Erro ao abrir a FIFO %s\n", FIFO); return -2; puts ("Começando a escrever..."); write(fpfifo, mensagem, strlen(mensagem)); puts ("Fim da escrita"); close (fpfifo); return 0; O mesmo programa, com bloqueio 12!
Comunicação entre Processos Named Pipes (FIFO)
Comunicação entre Processos Named Pipes (FIFO) 5/17/18 1 Named pipe (FIFO) FIFO permite que dois processos quaisquer se comuniquem É um tipo especial de arquivo visível no sistema de arquivos Na troca
Comunicação entre Processos
Comunicação entre Processos Pipes Redirecionamento de entrada e saída 4/19/18 1 O Pipe: Características (1) Canal de comunicação entre processos parentes, usando a politica First-In-First-Out (FIFO) Tipicamente,
Comunicação entre pai e filho
Comunicação entre pai e filho Ao chamar um fork(), processos pai e filho deixam de compartilhar memória Como fazer então para que o resultado de um processo possa ser recebido pelo outro? Exemplos: Processo
Comunicação entre Processos Memória Compartilhada
Comunicação entre Processos Memória Compartilhada 3/23/17 1 Métodos de comunicação entre processos Memória compartilhada Sinais Pipes Troca de mensagens Memória Compartilhada Memória compartilhada Permite
I/O de baixo-nível em ficheiros
7 I/O de baixo-nível em ficheiros Sumário: Introdução Funções de entrada/saída de baixo-nível Referência bibliográfica: W. Stevens. Advanced Programming in the UNIX Environment. Addison-Wesley, 1992 (cap.3,
Comunicação entre Processos Memória Compartilhada
Comunicação entre Processos Memória Compartilhada 8/30/18 1 Métodos de comunicação entre processos Memória compartilhada Sinais Pipes Troca de mensagens Memória Compartilhada Memória compartilhada Permite
Computação 2. Aula 8. Profª. Fabiany Arquivos
Computação 2 Aula 8 Arquivos Profª. Fabiany [email protected] E/S com Arquivos A linguagem C não possui nenhum comando de E/S. Todas as operações de E/S ocorrem mediante chamadas a funções de biblioteca
6. Comunicação entre processos - Pipes
6. Comunicação entre s - Pipes 6.1 O que são pipes Os pipes em UNIX constituem um canal de comunicação unidirecional entre s com um ascendente comum (entre um pai e um seu descendente). Uma vez estabelecido
Inter-process Communication (IPC)
Inter-process Communication (IPC) Comunicação entre processos (1) Introdução Tubos (Pipes) Filas (FIFOs, Named Pipes) Comunicação entre Processos (1) Os sistemas operacionais implementam mecanismos que
Programação de Sistemas
Programação de Sistemas FIFOs Programação de Sistemas FIFOs : 1/13 Introdução APUE 15.5 Os tubos só podem ser usados por processos que tenham um antecessor comum. Para resolver a limitação dos tubos, o
Inter-process Communication (IPC)
Inter-process Communication (IPC) Comunicação entre processos (1) Introdução Tubos (Pipes) Filas (FIFOs, Named Pipes) Comunicação entre Processos (1) Os sistemas operacionais implementam mecanismos que
Comunicação entre Processos Canal de comunicação Arquitetura da comunicação Modelos de comunicação
Comunicação entre Processos Canal de comunicação Arquitetura da comunicação Modelos de comunicação Sistemas Operativos 2015-2016 O que construímos até agora... A abstração de processo 2 A possibilidade
Disciplina de Introdução à Ciência da Computação ICC 1 - Teoria
USP - ICMC - SSC SSC 0501-1o. Semestre 2015 Disciplina de Introdução à Ciência da Computação ICC 1 - Teoria Prof. Fernando Santos Osório Email: fosorio [at] icmc. usp. br, gmail. com Página Pessoal: http://www.icmc.usp.br/~fosorio/
Aula 16: Manipulação de Arquivos em C
Aula 16: Manipulação de Arquivos em C Fernanda Passos Universidade Federal Fluminense Programação de Computadores IV Fernanda Passos (UFF) Manipulação de Arquivos Programação de Computadores IV 1 / 33
Inter-process Communication (IPC) Comunicação entre processos (1) Introdução Tubos (Pipes)
Inter-process Communication (IPC) Comunicação entre processos (1) Introdução Tubos (Pipes) Comunicação entre Processos (1) Os sistemas operacionais implementam mecanismos que asseguram a independência
Linguagem C Ficheiros Compilação Separada
Linguagem C Ficheiros Compilação Separada typedef definição de tipos Apontadores para estruturas Ficheiros na bibiloteca standard do C Compilação Separada Definição de novos tipos em C É possível definir
CAP. IX - MANIPULAÇÃO DE ARQUIVOS Generalidades sobre Arquivos. 9.2 Abertura e Fechamento de Arquivos. Operações com arquivos:
CAP. IX - MANIPULAÇÃO DE ARQUIVOS 9.1 Generalidades sobre arquivos 9.2 Abertura e fechamento de arquivos 9.3 Arquivos textos e arquivos binários 9.4 Leitura e escrita em arquivos binários 9.5 Procura direta
Existe uma quantidade de informação que pode ser armazenada para resolver o problema.
Arquivos Introdução As estruturas vistas anteriormente armazenam as informações na memória principal do computador. Nem sempre é conveniente. Problemas: A informação é perdida; As estruturas de dados são
Sistemas Operacionais II
Sistemas Operacionais II Aula 1 Autor: Renê de Souza Pinto Orientação: Prof. Dr. Francisco José Monaco [email protected], [email protected] Universidade de São Paulo Instituto de Ciências Matemáticas
Sumário. Ficheiros. Ficheiros
Sumário Ficheiros Motivação Operações Ficheiros de texto e binários Manipulação de ficheiros de texto Abertura Encerramento Descritores de ficheiros: stdin, stdout, stderr Escrita Leitura Outras funções
Memória partilhada em Unix SysV
Memória partilhada em Unix SysV A forma mais geral de comunicação entre processos é através de memória partilhada. segmento de memoria partilhada Processo A Processo B p q Criação de um segmento de memória
Linguagem C. Armazenamento de Dados em Arquivos - Continuação
Linguagem C Armazenamento de Dados em Arquivos - Continuação Arquivos Binários Comandos para gravação e leitura de arquivos (revisão): FILE *arquivo; arquivo = fopen( nome, modo ); fwrite (&variavel, sizeof
Capítulo 06: Arquivos
Capítulo 06: Arquivos INF1004 e INF1005 Programação 1 Pontifícia Universidade Católica Departamento de Informática Funções de entrada e saída em arquivos Motivação: quando um programa precisa processar
Programação. MEAer e LEE. Manipulação de ficheiros de texto. Bertinho Andrade da Costa. Instituto Superior Técnico. 2010/2011 1º Semestre
Programação MEAer e LEE Bertinho Andrade da Costa 2010/2011 1º Semestre Instituto Superior Técnico Manipulação de ficheiros de texto Programação 2010/2011 IST-DEEC Manipulação de Ficheiros 1 Sumário Ficheiros
Linguagem de Programação C. Arquivos
Arquivos Cristiano Lehrer Introdução Em C um arquivo é apenas um conjunto de bytes colocados uns após os outros de forma sequencial: Utilização de arquivos: Fonte de dados para o programa: Trata-se de
Linguagem C: Arquivo-Texto
Prof. Paulo R. S. L. Coelho [email protected] Faculdade de Computação Universidade Federal de Uberlândia GEQ007 Organização 1 Introdução em C 2 3 Organização Introdução em C 1 Introdução em C 2 3 Introdução
MIEIC SISTEMAS OPERATIVOS 2009/2010 1S FEUP
MIEIC SISTEMAS OPERATIVOS 2009/2010 1S FEUP Tipo de prova: sem consulta Exame de Recurso da Época Normal Duração: 2 horas 12 de Fevereiro de 2010 Cotação máxima: 20 valores Estrutura da prova: Parte I
PIP/CA - Programa Interdisciplinar de Pós-Graduação em Computação Aplicada da UNISINOS ALGORITMOS & ESTRUTURAS DE DADOS
PIP/CA - Programa Interdisciplinar de Pós-Graduação em Computação Aplicada da UNISINOS Disciplina de Nivelamento - 2000/1: ALGORITMOS & ESTRUTURAS DE DADOS Professor Responsável: Prof. Fernando Santos
Memória compartilhada
Memória compartilhada Luiz Affonso Guedes 1 Ivanovitch Silva 1 [email protected] [email protected] 1 Universidade Federal do Rio Grande do Norte 15 de outubro de 2009 Memória compartilhada DCA0109 - Prática
Arquivos em C Parte 2
Universidade de São Paulo São Carlos Instituto de Ciências Matemáticas e de Computação Arquivos em C Parte 2 Profa Rosana Braga Material preparado pela profa Silvana Maria Affonso de Lara 1º semestre de
INF1005: Programação 1. Arquivos. 02/05/10 (c) Paula Rodrigues 1
INF1005: Programação 1 Arquivos 02/05/10 (c) Paula Rodrigues 1 Tópicos Principais Motivação Abertura e fechamento de arquivos Leitura com fscanf Escrita com fprintf 08/03/10 (c) Paula Rodrigues 2 Motivação
Introdução à Computação II AULA 08 BCC Noturno - EMA896115B
Introdução à Computação II AULA 08 BCC Noturno - EMA896115B Prof. Rafael Oliveira [email protected] Universidade Estadual Paulista Júlio de Mesquita Filho UNESP Rio Claro 2014 (Sem 2) O ambiente de execução
Ambientes de Execução
KERNEL Conceitos Conceitos POSIX Portable Operating System Interface for UNIX. Um conjunto de padrões da IEEE e ISO que definem como programas e sistemas operacionais de interface com os outros. Sistemas
Computação 2. Aula Profª. Fabiany Listas Duplamente Encadeadas
Computação 2 Aula 10.1 Listas Duplamente Encadeadas Profª. Fabiany [email protected] ListaEncadeada.h #ifndef _LISTAENCADEADA_H_ #define _LISTAENCADEADA_H_ #include #include #include
Métodos Computacionais. Arquivos
Métodos Computacionais Arquivos Arquivos Um arquivo representa um elemento de informação armazenado em memória secundária (disco) Características: Informações são persistidas Atribui-se nomes aos elementos
3.1 - Funções para manipular dados de entrada e saída padrão
1616161616161616161616161616161616161616161616161616 3- ENTRADA E SAÍDA EM C Os principais meios para executar operações de entrada e saída (E/S) são: Entrada e saída pelo console (ou padrão): teclado
Exercícios Avaliativos Memória Compartilhada
1ª Avaliação Faculdades Integradas de Caratinga Sistemas Distribuídos Jacson RC Silva Exercícios Avaliativos Memória Compartilhada Uma posição de memória compartilhada é identificada por uma chave. Essa
Manipulação de Arquivos
Manipulação de Arquivos Estrutura de Dados II Prof. Guilherme Tavares de Assis Universidade Federal de Ouro Preto UFOP Instituto de Ciências Exatas e Biológicas ICEB Departamento de Computação DECOM Tipo
Computação Eletrônica. Aula 12 Arquivos Texto e Binário. Prof: Luciano Barbosa. CIn.ufpe.br
Computação Eletrônica Aula 12 Arquivos Texto e Binário Prof: Luciano Barbosa Relembrando a Arquitetura Básica de um Computador Até agora, toda a informação armazenada por nossos programas estava na memória
INF 1620 P2-14/10/05 Questão 1 Nome:
INF 1620 P2-14/10/05 Questão 1 Considere um cadastro de produtos de um estoque, com as seguintes informações para cada produto: Código de identificação do produto: representado por um valor inteiro Nome
Fundamentos de Arquivos
Fundamentos de Arquivos Leandro C. Cintra M.C.F. de Oliveira Rosane Minghim 2004-2010 Fonte: Folk & Zoelick, File Structures 2 Arquivos Informação mantida em memória secundária HD Fitas magnéticas CD DVD
