INFO: Dieses Forum nutzt Cookies...
Cookies sind für den Betrieb des Forums unverzichtbar. Mit der Nutzung des Forums erklärst Du dich damit einverstanden, dass wir Cookies verwenden.

Es wird in jedem Fall ein Cookie gesetzt um diesen Hinweis nicht mehr zu erhalten. Desweiteren setzen wir Google Adsense und Google Analytics ein.


Antwort schreiben 

Dieses Thema hat akzeptierte Lösungen:

Remote VI - Deploy und Start mit VI Server



Wenn dein Problem oder deine Frage geklärt worden ist, markiere den Beitrag als "Lösung",
indem du auf den "Lösung" Button rechts unter dem entsprechenden Beitrag klickst. Vielen Dank!

02.02.2013, 04:40
Beitrag #1

KeineFrageGuteFrage Offline
LVF-Neueinsteiger


Beiträge: 3
Registriert seit: Feb 2013

8.5.1
2011
DE_EN



Remote VI - Deploy und Start mit VI Server
Hallo!

Dies einmal vorweg: Ich habe das Forum durchsucht und habe mir viele und lange und langatmige Beiträge und Lösungsvorschläge bei ni.com zu dem oben genannten Thema (Betreff) durchgelesen. Leider komme ich auf keinen grünen Zweig bei meiner Programmierung der VI Server.

Mein Setup besteht aus einem cFP-2020 mit RealTime 8.5.1, Betriebssystem Pharlab und einem PC mit Windows NT und LabView 8.5.1. Kommunikation erfolgt über TCP.

Mein Ziel ist es ein VI für den Rechner zu schreiben, das ein anderes auf dem Rechner befindliches VI auf den cFP überträgt (Remote VI) und dort startet. Dieses soll später Daten nehmen und an den Rechner übertragen, welcher die Daten auf die Festplatte schreibt. Die Datenkommunikation- und nahme ist kein Problem und funktioniert wunderbar. Allerdings muss man immer seperat beide VIs aus dem Projektbaum öffnen und auf "Start" drücken. Das würde ich gerne umgehen.

Das Problem fängt schon bei der Konfiguration der (oder des ????) VI Server(s) an. Bei welcher von beiden Komponenten (cFP und Rechner) müssen welche Haken in den Optionen gesetzt werden, wo bleiben sie weg? Es ist nicht so, dass ich grundlegend nich verstehe, was die Einträge bedeuten, nur habe ich für (alle möglichen) Kombinationen von mit Verstand oder willkürlich gesetzten Häkchen schon etliche Error 66 (Server blockiert Verbindung), Error 63 (Pufferüberlauf) und gelegentlich auch mal Error 1 ( "deploy" des cFP aus dem Programm heraus nicht möglich) und Error 7 (Datei nicht gefunden, obwohl sie probeweise schon manuell auf dem cFP hinterlegt wurde) an den Kopf geschmissen bekommen. Auf Abruf reproduzierbar waren die Fehler jedoch nicht. Jetzt bin ich frustriert und hoffe das jemand von euch Profi ist.

Ich fänd es super, wenn mir jemand anhand der Nummerierung in den Bildern in der zip Datei im Anhang die einzelnen Einträge einmal vorgeben könnte. Als Maschinenalias (oder -name) vereinbaren wir "cFP2020" und "My Computer". Wenn die IP statt dem Alias gesetzt werden muss, bitte mitangeben!!! Dann weiß ich immerhin schon mal, ob ich mich einfach zu blöd angestellt habe, oder doch was nicht richtig rund läuft.

Lokal (rechnerintern) klappt das Aufrufen und Ausführen von anderen VIs mit den VI Servern wie am Schnürrchen. Nur Netzwerkkommunikation und Labview hat für mich noch nie so hingehauen wie es von NI immer so schön einfach beschrieben wird (mal abgesehen von direkten TCP-Verbindungen, die ich bisher benutze).

Weiter Fragen: Unterstützt der cFP2020 das externe Aufrufen überhaupt, wenn nicht schon ein VI darauf läuft? Braucht man dafür ActiveX? Ist Pharlab mit ActiveX kompatibel? Stimmt ggf. die Konfiguration meines Rechners nicht? Kann ich daran was drehen bzw. rausfinden woran es hakt?

Also ich würd' mich riesig freuen, wenn sich jemand dazu bereit erklärt mir unter die Arme zu greifen.

Liebe Grüße!!!


Angehängte Datei(en)
0.0 .zip  Konfiguration_VI_Server.zip (Größe: 130,29 KB / Downloads: 205)
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
04.02.2013, 14:53
Beitrag #2

jg Offline
CLA & CLED
LVF-Team

Beiträge: 15.864
Registriert seit: Jun 2005

20xx / 8.x
1999
EN

Franken...
Deutschland
RE: Remote VI - Deploy und Start mit VI Server
Hmm
Mit der direkten VI-Server-Funktionalität wirst du IMHO nicht ans Ziel kommen.

Im Prinzip musst du dasselbe machen wie aus deinem Projekt heraus. Das dürfte eher über die Eigenschaften und Methoden der Klasse "VI Server->Project" gehen.

Im Detail kenne ich mich da aber auch nicht aus.

Gruß, Jens

Wer die erhabene Weisheit der Mathematik tadelt, nährt sich von Verwirrung. (Leonardo da Vinci)

!! BITTE !! stellt mir keine Fragen über PM, dafür ist das Forum da - andere haben vielleicht auch Interesse an der Antwort!

Einführende Links zu LabVIEW, s. GerdWs Signatur.
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
04.02.2013, 16:26
Beitrag #3

KeineFrageGuteFrage Offline
LVF-Neueinsteiger


Beiträge: 3
Registriert seit: Feb 2013

8.5.1
2011
DE_EN



RE: Remote VI - Deploy und Start mit VI Server
Hallo!

Vielen Dank für die Antwort! Über die VI Server Funktionen der Klasse "Project" kann ich zwar ein Deploy der Komponenten und der VIs des cFP durchführen (wahrscheinlich auch VIs hinzufügen). Aber das VI starten - wenn gerade kein anderes Programm auf dem cFP läuft - kann ich damit nicht. Was inzwischen aber funktioniert ist, dass ich das VI kontrollieren kann sobald es "in memory" ist, sprich manuell gestartet wurde und ausgeführt wird.

Der Unterschied scheint zu sein, dass allein das Hinterlegen des VIs auf dem cFP, dieses nicht automatisch in den Speicher lädt, also das eigentliche Programm nicht im Register der CPU liegt. Sehe ich das richtig? Wenn es so ist schlussfolgere ich, dass ich dem Betriebssystem (hier Pharlab) den Befehl geben müsste das Programm auszuführen.

Des Weiteren würde es bedeuten, dass das VI als ausführbare (bereits kompilierte) Datei hinterlegt werden muss?! Dies wirft aber eine grundsätzliche Frage auf, auf die ich bisher keine Antwort gefunden habe:
Kann der cFP/Pharlab tatsächlich "VIs auführen" oder kompiliert mein Rechner den Code für die ihm bekannte Hardware des cFPs und sendet dem cFP dann die executable?

Das wäre schade, denn dann könnten Anwender mit geringen LabView Kenntnissen das VI für die Datennahme nicht einfach verändern und das Programm auf dem Rechner starten, sondern müssten es immer erst eimal kompilieren, bevor die Änderungen wirksam werden...

Hat jemand eine alternative Idee zu VI-Servern, mit der es möglich wäre mit einem Programm auf meinem Rechner ein Programm auf dem cFP zu starten, ohne es vorher manuell zu kompilieren und manuell auf den cFP zu packen?

Viele Grüße!!!
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
04.02.2013, 18:35
Beitrag #4

jg Offline
CLA & CLED
LVF-Team

Beiträge: 15.864
Registriert seit: Jun 2005

20xx / 8.x
1999
EN

Franken...
Deutschland
RE: Remote VI - Deploy und Start mit VI Server

Akzeptierte Lösung

Ganz schön viele Fragen...
(04.02.2013 16:26 )KeineFrageGuteFrage schrieb:  Vielen Dank für die Antwort! Über die VI Server Funktionen der Klasse "Project" kann ich zwar ein Deploy der Komponenten und der VIs des cFP durchführen (wahrscheinlich auch VIs hinzufügen). Aber das VI starten - wenn gerade kein anderes Programm auf dem cFP läuft - kann ich damit nicht. Was inzwischen aber funktioniert ist, dass ich das VI kontrollieren kann sobald es "in memory" ist, sprich manuell gestartet wurde und ausgeführt wird.
Ja, Deploy bringt die VIs nur ins RAM des Real-Time-Systems.
(04.02.2013 16:26 )KeineFrageGuteFrage schrieb:  Der Unterschied scheint zu sein, dass allein das Hinterlegen des VIs auf dem cFP, dieses nicht automatisch in den Speicher lädt, also das eigentliche Programm nicht im Register der CPU liegt. Sehe ich das richtig? Wenn es so ist schlussfolgere ich, dass ich dem Betriebssystem (hier Pharlab) den Befehl geben müsste das Programm auszuführen.
Ja genau, kannst du vergleichen mit einer Exe, wenn die auf der HDD liegt, dann "kennt" das Betriebssystem sie, aber deshalb muss sie ja noch nicht ausgeführt werden.
(04.02.2013 16:26 )KeineFrageGuteFrage schrieb:  Des Weiteren würde es bedeuten, dass das VI als ausführbare (bereits kompilierte) Datei hinterlegt werden muss?! Dies wirft aber eine grundsätzliche Frage auf, auf die ich bisher keine Antwort gefunden habe:
Kann der cFP/Pharlab tatsächlich "VIs auführen" oder kompiliert mein Rechner den Code für die ihm bekannte Hardware des cFPs und sendet dem cFP dann die executable?
Jetzt wird's etwas kompliziert mit dem Erklären.
Ein VI enthält immer auch kompilierten Code, und den auch Zielsystem-spezifisch. Daher kommt die Wartezeit beim Öffnen, wenn du z.B. ein VI, was du unter dem Zielsystem "Mein Computer" erstellt hast, dann unter dem Zielsystem "RT-Target" öffnest. Somit ist es dann auch klar, wieso du ein neues VI erst einmal speichern musst, bevor du es auf dem RT-Target ausführen kannst.
Und da auf dem RT-Target schon eine LabVIEW-Runtime-Umgebung installiert ist und läuft, kann das Target auch direkt VIs ausführen.
Bei einer rtexe ist es übrigens nicht viel anders, denn im Prinzip ist das nur ein Container-Datenformat, das alle VIs enthält, die deine Applikation benötigt - natürlich entsprechend optimiert (also mglw. FP & BD entfernt, automatisches Errorhandling deaktiviert usw.).

Folgendes habe ich übrigens gerade eben unter lv11_img und einem sbRIO-Target (und somit VxWorks) probiert, es funktioniert:
   

Ob das für die ein gangbarer Weg ist, kann ich nicht einschätzen.
Das Ganze ist sehr speziell, da du auch "Leute mit wenig LV-Kenntnissen" erwähnst - und das dann wieder im Zusammenhang mit einem RT-System. Hmm

Gruß, Jens

Wer die erhabene Weisheit der Mathematik tadelt, nährt sich von Verwirrung. (Leonardo da Vinci)

!! BITTE !! stellt mir keine Fragen über PM, dafür ist das Forum da - andere haben vielleicht auch Interesse an der Antwort!

Einführende Links zu LabVIEW, s. GerdWs Signatur.
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
06.02.2013, 01:25
Beitrag #5

KeineFrageGuteFrage Offline
LVF-Neueinsteiger


Beiträge: 3
Registriert seit: Feb 2013

8.5.1
2011
DE_EN



RE: Remote VI - Deploy und Start mit VI Server
Hallo Jens!

Vielen Dank für deine aufschlussreichen Antworten! Das waren genau die Infos, die ich haben wollte!!! Und dann klappt das mit dem VI, wie du es abgebildet hast auch noch astrein! Ich bin selig. Wunderbar. Vielen Dank!

Einzige Anmerkung für spätere Leser: Leider gibt es in LV 8.5.1 den PropertyNode "Active Project" noch nicht. Aber das lässt sich umgehen, indem man einen PropertyNode erstellt, als Klasse "Project" auswählt, sich den Array "Project.Projects[]" ausgeben lässt und in einem For-Loop nach dem Project sucht, das das aktive VI enthält (siehe Anhang).

Ich arbeite das erste Mal mit VIServern und bin von der Fülle der Funktionen erschlagen. Und das muss nicht unbedingt schlecht sein. Wink

Liebe Grüße!!!


Angehängte Datei(en) Thumbnail(s)
   
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
30
Antwort schreiben 


Möglicherweise verwandte Themen...
Themen Verfasser Antworten Views Letzter Beitrag
  Textdateien an einen Remote (Rechner) bzw. Server übertragen mittels FTP Lessy2205 8 5.753 23.01.2013 12:25
Letzter Beitrag: Lessy2205
  Remote Panel mit PopUps RosJon 2 3.619 18.12.2012 08:17
Letzter Beitrag: RosJon
  LabVIEW OPC Server auf Windows Server 2003 Ninja2602 5 7.638 30.11.2012 16:30
Letzter Beitrag: lukas_c
  NI Web Server: Datei-Download mit Datenübertragung von Server- an Client-Rechner phonophunk 0 4.358 08.11.2012 18:10
Letzter Beitrag: phonophunk
  Remote Maschine erzeugt Daten - wie sammeln? gottfried 6 4.645 29.08.2012 13:26
Letzter Beitrag: Kiesch
  Remote Panel Engine Peter Schulze 2 4.385 07.12.2009 14:53
Letzter Beitrag: Peter Schulze

Gehe zu: