755 tüm dizinleri chmod fakat dosya yok (yinelemeli olarak)?
Tersine, nasıl sadece dosyaları (yinelemeli) chmod ama dizin yok?
755 tüm dizinleri chmod fakat dosya yok (yinelemeli olarak)?
Tersine, nasıl sadece dosyaları (yinelemeli) chmod ama dizin yok?
Yanıtlar:
Dizinleri tekrar tekrar vermek için ayrıcalıkları okuyun ve uygulayın:
find /path/to/base/dir -type d -exec chmod 755 {} +
Tekrar tekrar dosya okuma ayrıcalıkları vermek için :
find /path/to/base/dir -type f -exec chmod 644 {} +
Veya, işlenecek çok sayıda nesne varsa:
chmod 755 $(find /path/to/base/dir -type d)
chmod 644 $(find /path/to/base/dir -type f)
Veya chmod
yumurtlamayı azaltmak için :
find /path/to/base/dir -type d -print0 | xargs -0 chmod 755
find /path/to/base/dir -type f -print0 | xargs -0 chmod 644
-bash: /bin/chmod: Argument list too long
. Son komut birçok sudo
find /path/to/base/dir -type d -print0 | sudo xargs -0 chmod 755
dir
ayrıca 755'e ayarlanır
chmod ... $(find /path/to/base/dir -type ...)
adında boşluk olan dosya adları için başarısız olur.
find /path/to/base/dir -type d -exec chmod 755 {} \;
( find /path/to/base/dir -type f -exec chmod 644 {} \;
) olduğunu düşünüyorum.
Bu tür bir şey için ortak bir neden, dizinleri 755'e ayarlamak ama dosyaları 644'e ayarlamaktır. Bu durumda, nik'in örneğinden biraz daha hızlı bir yol var find
:
chmod -R u+rwX,go+rX,go-w /path
Anlamı:
-R
= özyinelemeli;u+rwX
= Kullanıcılar okuyabilir, yazabilir ve uygulayabilir;go+rX
= grup ve diğerleri okuyabilir ve yürütebilir;go-w
= grup ve diğerleri yazamıyorBurada dikkat edilmesi gereken en önemli şey, büyük harflerin X
küçük harfe farklı davranmalarıdır x
. Manuel olarak okuyabiliriz:
Dosya bir dizinse veya çalıştırma / arama bitlerinden herhangi biri orijinal (değiştirilmemiş) modda ayarlanmışsa, execute / search bit.
Başka bir deyişle, bir dosyadaki chmod u + X yürütme bitini ayarlamaz; ve g + X yalnızca kullanıcı için ayarlanmışsa ayarlayacaktır.
chmod -R 777
çünkü +X
seçenek dosyalar üzerindeki mevcut çalıştırma bitlerini sıfırlayamaz. -X kullanmak dizinleri sıfırlar ve içine düşmeyi önler.
X
yorumlarda açıklandığı gibi, dosyalar ve dizinler için farklı izinler alırsınız .
go+rX,go-w
-> go=rX
değil mi?
chmod u-x,u+X
Dosyaların yürütme bitlerini kaldırmak, ancak dizinler için bunları eklemek için, vb. Bir arada da kullanabilirsiniz .
Dosyaların 644 olarak ayarlandığından ve yürütme bayrağının bulunduğu yolda dosyalar bulunduğundan emin olmak için, önce yürütme bayrağını kaldırmanız gerekir. + X yürütme bayrağını zaten sahip olan dosyalardan kaldırmaz.
Örnek:
chmod -R ugo-x,u+rwX,go+rX,go-w path
Güncelleme: ilk değişiklik (ugo-x) dizini beklenilemez hale getirdiğinden başarısız oldu, bu yüzden altındaki tüm dosyalar değişmedi.
chmod -R ugo-x path
, bu bir sorun olabilir. Fakat tam komut chmod u+rwX
her dizinde içine girmeden önce bunu yapacaktır.) Ancak chmod R u=rw,go=r,a+X path
bunun yeterli olduğuna inanıyorum - ve daha kısa.
Bunun için küçük bir senaryo yazmaya karar verdim.
Diziler ve / veya dosyalar için özyinelemeli chmod betiği - Gist :
chmodr.sh
#!/bin/sh
#
# chmodr.sh
#
# author: Francis Byrne
# date: 2011/02/12
#
# Generic Script for recursively setting permissions for directories and files
# to defined or default permissions using chmod.
#
# Takes a path to recurse through and options for specifying directory and/or
# file permissions.
# Outputs a list of affected directories and files.
#
# If no options are specified, it recursively resets all directory and file
# permissions to the default for most OSs (dirs: 755, files: 644).
# Usage message
usage()
{
echo "Usage: $0 PATH -d DIRPERMS -f FILEPERMS"
echo "Arguments:"
echo "PATH: path to the root directory you wish to modify permissions for"
echo "Options:"
echo " -d DIRPERMS, directory permissions"
echo " -f FILEPERMS, file permissions"
exit 1
}
# Check if user entered arguments
if [ $# -lt 1 ] ; then
usage
fi
# Get options
while getopts d:f: opt
do
case "$opt" in
d) DIRPERMS="$OPTARG";;
f) FILEPERMS="$OPTARG";;
\?) usage;;
esac
done
# Shift option index so that $1 now refers to the first argument
shift $(($OPTIND - 1))
# Default directory and file permissions, if not set on command line
if [ -z "$DIRPERMS" ] && [ -z "$FILEPERMS" ] ; then
DIRPERMS=755
FILEPERMS=644
fi
# Set the root path to be the argument entered by the user
ROOT=$1
# Check if the root path is a valid directory
if [ ! -d $ROOT ] ; then
echo "$ROOT does not exist or isn't a directory!" ; exit 1
fi
# Recursively set directory/file permissions based on the permission variables
if [ -n "$DIRPERMS" ] ; then
find $ROOT -type d -print0 | xargs -0 chmod -v $DIRPERMS
fi
if [ -n "$FILEPERMS" ] ; then
find $ROOT -type f -print0 | xargs -0 chmod -v $FILEPERMS
fi
Temelde özyinelemeli chmod yapar, ancak komut satırı seçenekleri için biraz esneklik sağlar (dizin ve / veya dosya izinlerini ayarlar veya her ikisini de otomatik olarak her şeyi 755-644'e sıfırlar). Ayrıca birkaç hata senaryosunu da kontrol eder.
Ben de bu konuda yazdığı blogumda .
Dizinleri tekrar tekrar vermek için ayrıcalıkları okuyun ve uygulayın:
find /path/to/base/dir -type d -exec chmod 755 {} \;
Tekrar tekrar dosya okuma ayrıcalıkları vermek için :
find /path/to/base/dir -type f -exec chmod 644 {} \;
Nik'in cevabını doğruluk tarafında yükseltmeme izin vermemekten daha iyidir. Çözümüm daha yavaş, ancak dosya adlarındaki herhangi bir sembolle, herhangi bir sayıda dosyayla çalışıyor ve sudo ile normal şekilde çalıştırabilirsiniz (ancak sudo ile farklı dosyalar bulabildiğine dikkat edin).
Bu python betiğini deneyin; işlemlerin yumurtlamasını gerektirmez ve dosya başına sadece iki çağrı yapar. C'deki bir uygulama dışında, muhtemelen bunu yapmanın en hızlı yolu olacaktır (hepsi 777 olarak ayarlanmış 15 milyon dosyalık bir dosya sistemini düzeltmek için ihtiyacım vardı)
#!/usr/bin/python3
import os
for par, dirs, files in os.walk('.'):
for d in dirs:
os.chmod(par + '/' + d, 0o755)
for f in files:
os.chmod(par + '/' + f, 0o644)
Benim durumumda, bazı özel dosyaları chmodding başarısız olduğundan, son chmod etrafında bir try / catch gerekliydi.
Ayrıca şunları da kullanabilirsiniz tree
:
tree -faid /your_directory | xargs -L1 -I{} bash -c 'sudo chmod 755 "$1"' -- '{}'
ve ayrıca klasörü görüntülemek isterseniz bir yankı ekleyin.
tree -faid /your_directory | xargs -L1 -I{} bash -c 'sudo chmod 755 "$1" && echo$1' -- '{}'
xargs
. Dosya adlarında Tek tırnak kendileri ben tek tırnak içeren tüm dosyaları listelenir ve bunları kaldırıldı neden çok komut ve komut dosyası için bir sorun (tırnak Yani) vardır
Aşağıdaki bash betiğini örnek olarak kullanabilirsiniz. Yürütülebilir izinleri verdiğinizden emin olun (755). Geçerli dizin için ./autochmod.sh, farklı bir tane belirtmek için ./autochmod.sh <dir> 'i kullanın.
#!/bin/bash
if [ -e $1 ]; then
if [ -d $1 ];then
dir=$1
else
echo "No such directory: $1"
exit
fi
else
dir="./"
fi
for f in $(ls -l $dir | awk '{print $8}'); do
if [ -d $f ];then
chmod 755 $f
else
chmod 644 $f
fi
done
$1
boş değilse, ancak bir dizinin adı değilse (örneğin bir yazım hatası olur), o dir
zaman .
mesaj olmadan ayarlanır . (2) $1
olmalı "$1"
ve $dir
olmalı "$dir"
. (3) Söylemene gerek yok "./"
; "."
iyidir (ve kesinlikle konuşursak, burada alıntılara ihtiyacın yok). (4) Bu özyinelemeli bir çözüm değildir. (5) Sistemimde, ls -l … | awk '{ print $8 }'
dosyaların değişiklik zamanlarını alıyor. İhtiyacınız { print $9 }
olsun ilk kelime dosya. Ve o zaman bile, (6) bu, dosya adlarını beyaz boşlukla işlemez. …
chmod
kendisi 644 olacaktır , bu yüzden kendini çalıştırılamaz hale getirecektir !