os.OpenFile mit O_RDONLY hängt an der Named Pipe ohne Writer
Der PHP-Editor Banana führt Sie in eine spezielle Operationsmethode ein, bei der die Funktion os.OpenFile mit O_RDONLY verwendet wird, um ohne Writer auf einer Named Pipe zu mounten. Diese Operationsmethode kann den Lesevorgang der Named Pipe realisieren, sodass Sie die Dateninformationen in der Named Pipe problemlos abrufen können, ohne einen Writer zu verwenden. Diese Technik ist einfach zu verstehen und einfach zu bedienen, was sie zu einer ausgezeichneten Wahl für Entwickler beim Umgang mit Named Pipes macht. Als Nächstes stellen wir Ihnen detailliert vor, wie Sie mit dieser Methode den Lesevorgang der Named Pipe implementieren.
Frageninhalt
Ich schreibe einen Daemon, der Benachrichtigungen von Ad-hoc-CLI-Befehlen empfangen soll und dies über Unix-Named Pipes tun soll. Ich habe ein kurzes Paket geschrieben, das einerseits eine separate Goroutine generiert, um von Knoten zu lesen und empfangene Benachrichtigungen an Kanäle zu senden (Spielwiese mit Unit-Tests):
type Writer struct { f *os.File } func NewWriter(ipc string) (*Writer, error) { f, err := os.OpenFile(ipc, os.O_WRONLY, 0600) if err != nil { return nil, fmt.Errorf("writer: open file: %w", err) } return &Writer{f: f}, nil } func (w *Writer) WriteString(str string) (int, error) { return w.f.WriteString(fmt.Sprint(str, "\n")) } func (w *Writer) Close() error { return w.f.Close() } type Reader struct { f *os.File rmFn func() error quit chan struct{} done *sync.WaitGroup } func NewReader(ipc string) (*Reader, error) { err := syscall.Mkfifo(ipc, 0640) if err != nil { return nil, fmt.Errorf("reader: create fifo: %w", err) } f, err := os.OpenFile(ipc, os.O_RDONLY, 0640) if err != nil { return nil, fmt.Errorf("reader: open fifo: %w", err) } return &Reader{ f: f, quit: make(chan struct{}), done: &sync.WaitGroup{}, rmFn: func() error { return os.Remove(ipc) }, }, nil } func (r *Reader) PollRead() <-chan string { reader := bufio.NewReader(r.f) out := make(chan string) r.done.Add(1) go func() { defer r.done.Done() for { line, err := reader.ReadBytes('\n') if err != nil { fmt.Printf("error reading from named pipe: %v\n", err) return } nline := string(line) nline = strings.TrimRight(nline, "\n") select { case out <- nline: case <-r.quit: close(out) return } } }() return out } func (r *Reader) Close() error { close(r.quit) r.done.Wait() err := r.f.Close() if err != nil { return fmt.Errorf("error closing named pipe: %v", err) } err = r.rmFn() if err != nil { return fmt.Errorf("error removing named pipe: %v", err) } return nil }
Das scheint zu funktionieren, aber es weist ein eigenartiges Verhalten auf, bei dem kein Leser die Datei öffnen kann, bevor irgendein Autor die Datei öffnet, was aufgrund anderer Beiträge, die ich zu diesem Thema gelesen habe, der Fall zu sein scheint um das Verhalten umzukehren; die übliche Beschwerde ist, dass der Autor hängen bleibt, weil es keine Leser gibt, hier kann der Leser jedoch überhaupt nicht instanziiert werden.
Lösung
Dies ist die posix-Systemschnittstelle:
o_nonblock Beim Öffnen eines FIFO mit o_rdonly oder o_wronly gesetzt: if o_nonblock ist gesetzt, schreibgeschütztes open() wird ohne zurückgegeben Verzögerung. Wenn kein Prozess vorhanden ist, gibt die schreibgeschützte Funktion open() einen Fehler zurück Die Datei ist derzeit zum Lesen geöffnet.
Wenn o_nonblock gelöscht ist, blockiert die schreibgeschützte Funktion open() Wird aufgerufen, bis der Thread die Datei zum Schreiben öffnet. ein offenes() Schreibgeschützt sollte den aufrufenden Thread blockieren, bis der Thread geöffnet wird Datei zum Nachlesen.
Beim Öffnen unterstützter Blockspezial- oder Zeichenspezialdateien Nicht blockierend geöffnet:
Wenn o_nonblock gesetzt ist, wird die Funktion open() ohne zurückgegeben Verhindern Sie, dass das Gerät bereit oder verfügbar ist. nachfolgendes Verhalten Geräteeigenschaften sind gerätespezifisch.
Wenn o_nonblock gelöscht ist, blockiert die Funktion open() den Aufruf l> Der Thread kehrt erst zurück, wenn das Gerät bereit oder verfügbar ist.
Andernfalls verursacht das Flag o_nonblock keinen Fehler, ist aber der Fall Es ist nicht angegeben, ob das Dateistatus-Flag o_nonblock enthält Logo.
Die Lösung besteht also darin, syscall.o_nonblock
标志添加到 openfile
in den Anruf einzufügen:
f, err := os.OpenFile(ipc, os.O_RDONLY|syscall.O_NONBLOCK, 0640)
BEARBEITEN: Wie in den Kommentaren besprochen, ist diese Lösung nicht zum darwin
环境。更便携的解决方案是在读取器端使用 o_rdwr
Öffnen von Dateien portierbar.
Das obige ist der detaillierte Inhalt vonos.OpenFile mit O_RDONLY hängt an der Named Pipe ohne Writer. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen





OpenSSL bietet als Open -Source -Bibliothek, die in der sicheren Kommunikation weit verbreitet sind, Verschlüsselungsalgorithmen, Tasten und Zertifikatverwaltungsfunktionen. In seiner historischen Version sind jedoch einige Sicherheitslücken bekannt, von denen einige äußerst schädlich sind. Dieser Artikel konzentriert sich auf gemeinsame Schwachstellen und Antwortmaßnahmen für OpenSSL in Debian -Systemen. DebianopensL Bekannte Schwachstellen: OpenSSL hat mehrere schwerwiegende Schwachstellen erlebt, wie z. Ein Angreifer kann diese Sicherheitsanfälligkeit für nicht autorisierte Lesen sensibler Informationen auf dem Server verwenden, einschließlich Verschlüsselungsschlüssel usw.

In der Bibliothek, die für den Betrieb der Schwimmpunktnummer in der GO-Sprache verwendet wird, wird die Genauigkeit sichergestellt, wie die Genauigkeit ...

Das Problem der Warteschlange Threading In Go Crawler Colly untersucht das Problem der Verwendung der Colly Crawler Library in Go -Sprache. Entwickler stoßen häufig auf Probleme mit Threads und Anfordern von Warteschlangen. � ...

Backend Learning Path: Die Erkundungsreise von Front-End zu Back-End als Back-End-Anfänger, der sich von der Front-End-Entwicklung verwandelt, Sie haben bereits die Grundlage von Nodejs, ...

In diesem Artikel werden eine Vielzahl von Methoden und Tools eingeführt, um PostgreSQL -Datenbanken im Debian -System zu überwachen, um die Datenbankleistung vollständig zu erfassen. 1. verwenden Sie PostgreSQL, um die Überwachungsansicht zu erstellen. PostgreSQL selbst bietet mehrere Ansichten für die Überwachung von Datenbankaktivitäten: PG_STAT_ACTIVITY: Zeigt Datenbankaktivitäten in Echtzeit an, einschließlich Verbindungen, Abfragen, Transaktionen und anderen Informationen. PG_STAT_REPLIKATION: Monitore Replikationsstatus, insbesondere für Stream -Replikationscluster. PG_STAT_DATABASE: Bietet Datenbankstatistiken wie Datenbankgröße, Transaktionsausschüsse/Rollback -Zeiten und andere Schlüsselindikatoren. 2. Verwenden Sie das Log -Analyse -Tool PGBADG

Der Unterschied zwischen Stringdruck in GO -Sprache: Der Unterschied in der Wirkung der Verwendung von Println und String () ist in Go ...

Das Problem der Verwendung von RETISTREAM zur Implementierung von Nachrichtenwarteschlangen in der GO -Sprache besteht darin, die Go -Sprache und Redis zu verwenden ...

Wie kann man im Beegoorm -Framework die mit dem Modell zugeordnete Datenbank angeben? In vielen BeEGO -Projekten müssen mehrere Datenbanken gleichzeitig betrieben werden. Bei Verwendung von BeEGO ...
