Heim > Java > Hauptteil

Die Befehle start-all.sh und start-dfs.sh wurden nicht gefunden

PHPz
Freigeben: 2024-02-09 13:24:09
nach vorne
802 Leute haben es durchsucht

PHP-Editor Apple kann bei der Verwendung von Hadoop auf ein häufiges Problem stoßen: „Befehle start-all.sh, start-dfs.sh nicht gefunden“. Dieses Problem tritt normalerweise beim Starten eines Hadoop-Clusters auf und kann durch eine falsche Pfadkonfiguration oder eine nicht vorhandene Skriptdatei verursacht werden. Um dieses Problem zu lösen, müssen wir den Hadoop-Installationspfad und die Konfiguration der Umgebungsvariablen überprüfen, um sicherzustellen, dass sie richtig eingestellt sind, und sicherstellen, dass die relevanten Skriptdateien in den entsprechenden Pfaden vorhanden sind. Im Folgenden wird detailliert beschrieben, wie dieses Problem gelöst werden kann. Schauen wir uns das gemeinsam an!

Frageninhalt

Ich verwende Ubuntu 16.04 LTS und habe Hadoop 2.7.2 installiert. Die Ausgabe von

  hadoop version
Nach dem Login kopieren

Ja

  hadoop 2.7.2
  subversion https://git-wip-us.apache.org/repos/asf/hadoop.git -r b165c4fe8a74265c792ce23f546c64604acf0e41
  compiled by jenkins on 2016-01-26t00:08z
  compiled with protoc 2.5.0
  from source with checksum d0fda26633fa762bff87ec759ebe689c
  this command was run using /usr/local/hadoop-2.7.2/share/hadoop/common/hadoop-common-2.7.2.jar
Nach dem Login kopieren

Wenn ich laufe

  whereis hadoop
Nach dem Login kopieren

Die ausgegebene Ausgabe ist

  hadoop: /usr/local/hadoop /usr/local/hadoop-2.7.2/bin/hadoop.cmd /usr/local/hadoop-2.7.2/bin/hadoop
Nach dem Login kopieren

Aber wenn ich den Befehl ausführe

  start-all.sh
Nach dem Login kopieren

Es heißt, Befehl nicht gefunden. Das Gleiche gilt, wenn ich laufe

  start-dfs.sh
Nach dem Login kopieren

Die Ausgabe ist, dass der Befehl nicht gefunden wurde.

Ich kann diese Befehle ausführen, wenn ich zum Hadoop-Verzeichnis navigiere, aber ich möchte diese Befehle ausführen, ohne zum Hadoop-Verzeichnis zu navigieren.

Lösung

Ihr Problem ist, dass Bash nicht weiß, wo sie suchen soll ./start-all.sh.

Sie können dies beheben, indem Sie eine Zeile wie diese öffnen $home/.bashrc und hinzufügen :

path=$path:/usr/local/hadoop/sbin
Nach dem Login kopieren

Dadurch wird Bash mitgeteilt, dass es start-all.sh in „/usr/local/hadoop/sbin“ aussehen soll.

Achtung:

Änderungen an $home/.bashrc werden in keinem derzeit geöffneten Terminal wirksam.

Wenn Sie möchten, dass die Änderungen im aktuell geöffneten Terminal wirksam werden, führen Sie

aus
source $home/.bashrc
Nach dem Login kopieren

Ich muss find verwenden, um danach zu suchen.

find / -iname start-all.sh 2>  /dev/null
Nach dem Login kopieren

Entdecken:

/usr/local/sbin/start-all.sh
/usr/local/cellar/hadoop/3.3.4/libexec/sbin/start-all.sh
/usr/local/cellar/hadoop/3.3.4/sbin/start-all.sh
Nach dem Login kopieren

Zusätzlich zur vorherigen Antwort sehen die Variablen in $home/.bashrc also so aus:

PATH=$PATH:/usr/local/sbin/
Nach dem Login kopieren

Hinweis: Ich bin mir nicht sicher, auf welche Einstellung path

eingestellt werden soll

Das obige ist der detaillierte Inhalt vonDie Befehle start-all.sh und start-dfs.sh wurden nicht gefunden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:stackoverflow.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage