|
|
(94 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) |
Zeile 1: |
Zeile 1: |
| '''topic''' kurze Beschreibung
| | [[Kategorie:Linux/Datei/Eigenschaft]] |
| | |
| = Beschreibung =
| |
| * Zeitstempel der Dateien sind in Linux in den [http://wiki.linux-club.de/opensuse/Inode Inodes] abgelegt.
| |
| * Dort stehen jeweils 4 Zeitstempel, wovon jedoch einer für den Anwender nicht sichtbar und auch nicht von Interesse ist, den verwendet Linux im Filesystem zum Verwalten der gelöschten Inode, er enthält die Zeit, zu der die Datei gelöscht worden ist, und somit der Inode für eine neue Verwendung frei geworden ist.
| |
| * Derzeit kommt im ext3/4 Filesystem noch ein weiterer Zeitstempel hinzu, auf den wohl so mach ein ehemaliger Windowsuser schon lange gewartet hat, und der die wirkliche Entstehungszeit der Datei dokumentiert.
| |
| * Dazukommen bedeutet, in aktuellen Systemen ist er intern schon da, allerdings war dies das geringste Problem.
| |
| * Das Hauptproblem jetzt, es müssen sehr viele, zum Teil auch zentrale Librarys und Programme, auf eine mögliche Benutzung dieses Zeitstempels noch angepasst werden.
| |
| * Solche weitreichenden Änderungen könnten nur durch eine gezielte Koordinierung von zahlreichen Projekten schnell eingebracht werden.
| |
| * Es wird also durchaus noch einiges Wasser die Flüsse herunterfließen, bis Otto der Normalanwender letztlich diesen Zeitstempel irgendwann einmal zu Gesicht bekommt, oder
| |
| * bis er wirklich auch damit arbeiten kann.
| |
| | |
| = Zeitstempel =
| |
| == Access Time (atime) ==
| |
| Diese Zeit wird jedes mal neu gesetzt, wenn der Inhalt der Datei geöffnet worden ist.
| |
| * In ihm wird also der letzte Zugriff auf den Inhalt der Datei angezeigt.
| |
| * Dabei ist es für diesen Zeitstempel von Bedeutung, ob die Datei vor einem schreiben erst gelesen wird oder nur an das Ende weitergeschrieben wird.
| |
| * Ansonsten gilt, egal ob die Datei gelesen oder ausgeführt wird oder ob eine Kopie von dieser Datei gemacht wird, oder die Datei durchsucht wird, oder die Datei in ein Backuparchiv aufgenommen wird - immer wird dieser Zeitstempel neu auf die aktuelle Zeit gesetzt.
| |
| * Durch die Auswertung dieses Zeitstempels könnten wir also zum Beispiel
| |
| * feststellen, das wir eine Datei schon einen längeren Zeitraum nicht mehr angefasst haben.
| |
| * Das kann unter Anderem dabei helfen alte temporäre User- oder Systemdateien zu löschen.
| |
| * Das ständige setzen der Access Time von Dateien und Verzeichnissen kann bei sehr vielen Zugriffen in einem Filesystem eine nicht unbedeutende Last verursachen, in bestimmten Situationen ist dieses aus Performancegründen nicht gewünscht, und kann deshalb zum Beispiel
| |
| * mit Mountoptionen des Filesystems für alle Dateien oder alle Verzeichnisse abgeschaltet werden.
| |
| * Einige Filesysteme erlauben auch ein gezieltes Abschalten dieser ständigen atime Aktualisierungen für ausgewählte Dateien oder Verzeichnisse.
| |
| | |
| == Modify Time (mtime) ==
| |
| Diese Zeit wird gesetzt, wenn der Inhalt der Datei verändert wird.
| |
| * In diesem Zeitstempel steht also die Zeit der letzten Veränderung der Dateidaten.
| |
| * Es ist der Zeitstempel der für uns die meiste Bedeutung hat.
| |
| * Können wir doch damit feststellen, wie aktuell die Dateidaten sind.
| |
| * Diese Zeit wird zum Beispiel
| |
| * bei ls -l in der default Einstellung angezeigt.
| |
| | |
| == Change Time (ctime) ==
| |
| Fälschlicher Weise wird ctime oftmals mit Create Time übersetzt und somit herrscht über diesen Zeitstempel oftmals eine ganz falsche Vorstellung.
| |
| * Mit diesem Zeitstempel wird die Zeit gespeichert, zu welcher das letzte Mal die Daten innerhalb des Inodes geändert worden sind.
| |
| * Wenn man sich anschaut, welche Daten im [http://wiki.linux-club.de/opensuse/Inode Inode] enthalten sind, kann man schon erahnen, wann diese Zeit neu gesetzt wird.
| |
| * Bei einem Ändern des Dateiinhaltes werden die Dateigröße sowie die Datenblöcke neu gesetzt, beim Ändern der Zugriffsrechte, der UserID oder GruppenID, beim Anlegen eines neuen Hardlinks immer wird auch der Inhalt des Inodes geändert und damit auch die ctime neu gesetzt.
| |
| * Aber auch bei einem Umbenennen der Datei, wird die ctime neu gesetzt, (man muss sich dabei vorstellen, das beim Umbenennen die Anzahl der "Links" zuerst um 1 erhöht wird, dann wird der neue Name angelegt, und dann anschließend der alte Name gelöscht und die "Links" wieder um 1 verringert).
| |
| * Es gibt eine einzige Ausnahme bei der die ctime nicht gesetzt wird: wenn durch das Auslesen der Datei nur die Access Time im Inode neu gesetzt wird, also die Datei zum Beispiel
| |
| * ausgelesen wird, dann wird die Change Time nicht neu gesetzt.
| |
| * Dieser Zeitstempel hat zum Beispiel
| |
| * eine große Bedeutung fürs Backup, da damit nicht nur festgestellt werden kann, ob sich der Inhalt der Datei sondern zum Beispiel
| |
| * auch der Name oder die Eigentums- oder Zugriffsrechte einer Datei seit dem letzten Backup geändert haben.
| |
| * Während sich die anderen beiden Zeitstempel durch Befehle auf eine bestimmte Zeit manipulieren lassen, ist es nicht möglich die ctime auf diese Art zu setzen.
| |
| * What if you want to find files by their age? This is something that can be useful if you're trying to find a file that you know you created within a certain timeframe, or if you want to look for older files to delete.
| |
| * Lots of good reasons, actually.
| |
| * The <tt>find</tt> utility is all about finding by time.
| |
| * You can search by access time ('''-atime''') or the last time a file was modified ('''-mtime''') or by the last time it was changed ('''-ctime''').
| |
| | |
| For example, let's look for any files that have not been modified in the last two days:
| |
| $ '''find -mtime +2'''
| |
| * The options take a number that is interpreted as "n times 24 hours ago" and actually encompass a range.
| |
| * If you say +1, <tt>find</tt> will interpret that as "at least 24 hours ago, but not more than 48 hours ago."
| |
| * You can combine the options, if you want to look for files within a specific range.
| |
| * So '''find -mtime +2 -mtime -5''' would be "two or more days ago, but not more than five days ago."
| |
| | |
| = Anwendungen =
| |
| == Zeitstempel anzeigen ==
| |
| === ls ===
| |
| siehe [[Linux:Befehl:ls]]
| |
| | |
| === stat ===
| |
| siehe [[Linux:Befehl:stat]]
| |
| | |
| == Zeitstempel ändern ==
| |
| siehe [[Linux:Befehl:touch]]
| |
| | |
| == Unterschiede bei Dateitypen ==
| |
| Bei der Interpretation der Zeitstempel müssen wir weiterhin unterscheiden, ob es sich um eine '''"normale" Datei''' oder zum Beispiel
| |
| * um ein [http://wiki.linux-club.de/opensuse/Directory Verzeichnis] handelt.
| |
| * Die Funktion der Zeitstempel ist bei allen Dateitypen prinzipiell gleich, allerdings durch den speziellen Aufbau und die Funktion einzelner Dateitypen ergibt sich eine etwas andere Betrachtungsweise.
| |
| * Bei den '''Verzeichnissen''' bedeutet die atime, das Verzeichnis wurde gelesen zum Beispiel
| |
| * mit '''ls''', die mtime bedeutet es wurde in diesem Verzeichnis an den Namen der Dateien etwas geändert, oder Dateien sind in diesem Verzeichnis dazu gekommen oder entfernt worden.
| |
| | |
| '''Pipes''' und '''Geräteknoten''' zeigen prinzipiell analoges Verhalten wie normale Dateien, es gibt jedoch einige Besonderheiten bei '''Symbolischen Links'''.
| |
| * Die atime wird hier immer dann gesetzt, wenn über diesen Weg auf die verlinkte Datei zugegriffen wird.
| |
| * Die ctime wird gesetzt bei Eigentumswechsel oder Umbenennen der Datei.
| |
| * Da der eigentliche Inhalt des Softlinks, der Verweis auf die Datei nicht geändert werden kann, wird die mtime nur bei der Erstellung des Softlinks gesetzt.
| |
| * Beim Versuch mittels '''chmod''' oder '''touch''' auf den Inode des Softlinks zuzugreifen, wird statt dessen dem Link gefolgt und der Zugriff erfolgt dort auf den Inode der verlinkten Datei.
| |
| | |
| == Zeitstempel und Datei-Operation ==
| |
| Die folgende Tabelle zeigt einige häufige Befehle und ihre Auswirkungen auf die Zeitstempel von Verzeichnissen, normalen Dateien und Softlinks.
| |
| * Dabei entspricht: * '''( X )''' dieser Zeitstempel wird neu gesetzt
| |
| * '''( . )''' dieses Zeitstempels bleibt unverändert
| |
| * '''( - )''' auf Softlinks wurden nicht alle Befehle getestet oder sind wirkungslos
| |
| | |
| '''Änderung der Zeitstempel verschiedener Dateitypen bei Befehlen'''
| |
| | |
| {| class="wikitable sortable"
| |
| |-
| |
| | | '''Befehl '''
| |
| | colspan="3" align=center | '''aktuelles Directory '''
| |
| | colspan="3" align=center | '''Datei '''
| |
| | colspan="3" align=center | '''Sym.
| |
| * Link auf Datei '''
| |
| |-
| |
| | |
| |
| | align=center | atime
| |
| | align=center | mtime
| |
| | align=center | ctime
| |
| | align=center | atime
| |
| | align=center | mtime
| |
| | align=center | ctime
| |
| | align=center | atime
| |
| | align=center | mtime
| |
| | align=center | ctime
| |
| |-
| |
| | | '''ls * '''
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| |-
| |
| | | '''cat * '''
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| |-
| |
| | | '''find . '''
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| |-
| |
| | | '''grep Begriff * '''
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| |-
| |
| | | '''echo "neue Zeile" >> Datei '''
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | X
| |
| | align=center | -
| |
| | align=center | -
| |
| | align=center | -
| |
| |-
| |
| | | '''echo "neue Zeile" >> SymLink '''
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | X
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| |-
| |
| | | '''mv Datei Datei_1 '''
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| |-
| |
| | | '''ln Datei Datei_1 '''
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | -
| |
| | align=center | -
| |
| | align=center | -
| |
| |-
| |
| | | '''chmod 777 Datei '''
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | -
| |
| | align=center | -
| |
| | align=center | -
| |
| |-
| |
| | | '''chown user1 Datei '''
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| |-
| |
| | | '''tar -cf ../Archiv.tar ./ '''
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | .
| |
| |-
| |
| | | '''tar -xf ../Archiv.tar '''
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | X
| |
| | align=center | .
| |
| | align=center | X
| |
| | align=center | X
| |
| | align=center | X
| |
| | align=center | X
| |
| | |
| |-
| |
| |}
| |
| | |
| == Zeitstempel suchen ==
| |
| siehe [[Linux:Befehl:find#Datum.2FZeit]]
| |
| | |
| == Backup und Zeitstempel ==
| |
| siehe [[Sicherheit:Backup]]
| |
| | |
| = Dokumentation =
| |
| == Man-Pages ==
| |
| == Info-Pages ==
| |
| = Links =
| |
| == Dateien ==
| |
| == Man-Pages ==
| |
| == Intern ==
| |
| == Weblinks ==
| |
| | |
| =Kontrollfragen=
| |
| <div class="toccolours mw-collapsible mw-collapsed">
| |
| ''Testfrage 1''
| |
| <div class="mw-collapsible-content">'''Antwort1'''</div>
| |
| </div>
| |
| <div class="toccolours mw-collapsible mw-collapsed">
| |
| ''Testfrage 2''
| |
| <div class="mw-collapsible-content">'''Antwort2'''</div>
| |
| </div>
| |
| <div class="toccolours mw-collapsible mw-collapsed">
| |
| ''Testfrage 3''
| |
| <div class="mw-collapsible-content">'''Antwort3'''</div>
| |
| </div>
| |
| <div class="toccolours mw-collapsible mw-collapsed">
| |
| ''Testfrage 4''
| |
| <div class="mw-collapsible-content">'''Antwort4'''</div>
| |
| </div>
| |
| <div class="toccolours mw-collapsible mw-collapsed">
| |
| ''Testfrage 5''
| |
| <div class="mw-collapsible-content">'''Antwort5'''</div>
| |
| </div>
| |
| | |
| [[Kategorie:Linux:Dateien]]
| |