Esiste uno standard a cui posso fare riferimento per l'elenco dei programmi (ad esempio cat
, ls
) che devono essere inclusi in Linux?
lsb
pacchetto).
Esiste uno standard a cui posso fare riferimento per l'elenco dei programmi (ad esempio cat
, ls
) che devono essere inclusi in Linux?
lsb
pacchetto).
Risposte:
Linux Standard Base (LSB) ha un elenco di applicazioni :
[ du install mv strings
ar echo install_initd newgrp strip
at ed ipcrm nice stty
awk egrep ipcs nl su
basename env join nohup sync
batch expand kill od tail
bc expr killall passwd tar
cat false ln paste tee
chfn fgrep locale patch test
chgrp file localedef pathchk tic
chmod find logger pax time
chown fold logname pidof touch
chsh fuser lp pr tput
cksum gencat lpr printf tr
cmp getconf ls ps true
col gettext lsb_release pwd tsort
comm grep m4 remove_initd tty
cp groupadd mailx renice umount
cpio groupdel make rm uname
crontab groupmod man rmdir unexpand
csplit groups md5sum sed uniq
cut gunzip mkdir sendmail useradd
date gzip mkfifo seq userdel
dd head mknod sh usermod
df hostname mktemp shutdown wc
diff iconv more sleep xargs
dirname id mount sort zcat
dmesg infocmp msgfmt split
Molti di questi sono inclusi come parte dello standard POSIX 1003.1-2001 , ma i seguenti sono o solo in LSB o hanno specifiche diverse da POSIX:
ar echo hostname more sh
at egrep install mount shutdown
awk fgrep install_initd msgfmt su
batch file ipcrm newgrp sync
bc fuser ipcs od tar
chfn gettext killall passwd umount
chsh grep lpr patch useradd
col groupadd ls pidof userdel
cpio groupdel lsb_release remove_initd usermod
crontab groupmod m4 renice xargs
df groups md5sum sed zcat
dmesg gunzip mknod sendmail
du gzip mktemp seq
file
, ipcrm
, ipcs
, m4
, patch
, e zcat
quotata - che è un'operazione eyeballing piuttosto che una verifica formale delle liste.
Tecnicamente non puoi presumere che qualcosa sarà presente, perché Linux-the-kernel viene utilizzato in un intero gruppo di contesti embedded o semi-embedded in cui un completo complemento di utility di shell sarebbe un inutile spreco di spazio. Non sarebbe fuori questione, ad esempio, costruire un dispositivo IoT il cui filesystem contiene un bootloader, un kernel monolitico, un'abitudine /sbin/init
che fa tutto ciò che il dispositivo dovrà mai fare, poche /dev
voci e nient'altro .
La specifica POSIX.1-2008 "Shell and Utilities" , anch'essa collegata nella risposta di Muru, ha lo scopo di standardizzare la shell come linguaggio di programmazione . Pertanto non include la maggior parte degli strumenti di amministrazione del sistema che ci si aspetta di essere presenti su un'installazione Unix "tradizionale". Sfortunatamente, questa è anche una cicatrice rimasta visibile dell'antico scisma tra System V e BSD - gli strumenti che troverai su Linux non sono gli stessi di FreeBSD o OSX o altro. Quindi, ancora una volta, non esiste una base affidabile.
Per dare un'indicazione di ciò che manca alla risposta di maru, questo è l'insieme di pacchetti che Debian (instabile) considera "richiesti" ( definizione ufficiale : "I sistemi con solo i pacchetti richiesti sono probabilmente inutilizzabili, ma hanno abbastanza funzionalità per consentire all'amministratore di sistema di avviare ed installare altri software. ") e che contribuiscono a file /bin
, /sbin
, /usr/bin
, o /usr/sbin
. Quelli contrassegnati con un asterisco non sono solo "richiesti", ma "essenziali", il che significa che altri software impacchettati possono assumere la sua presenza senza dipendere da esso.
base-passwd* gzip* perl-base*
bash* hostname* sed*
bsdutils* initscripts sensible-utils
coreutils* libc-bin* sysv-rc
dash* libpam-modules-bin sysvinit-utils*
debianutils* libpam-runtime tar*
diffutils* login* tzdata
dpkg* mawk¹ util-linux*
e2fsprogs* mount* xz-utils
findutils* ncurses-bin*
grep* passwd
¹ awk-the-language è "essenziale", ma l'amministratore di sistema può scegliere se desidera l'implementazione "mawk" o "gawk".
E questi sono i pacchetti considerati idem "importanti"; la definizione ufficiale di "importante" è "una persona con esperienza Unix che l'ha trovata scomparsa direbbe 'Cosa sta succedendo, dove sta andando?'":
adduser cpio ifupdown man-db vim-common
apt cron iproute2 procps vim-tiny
apt-utils debconf iputils-ping rsyslog wget
aptitude dmidecode isc-dhcp-client systemd whiptail
aptitude-common gnupg kmod systemd-sysv
at gpgv less traceroute
bsdmainutils groff-base logrotate udev
Si noti che questo secondo set include strumenti di amministrazione di sistema critici come ps
e iproute2
, ma anche cose che potrebbero essere completamente inutili su alcune installazioni, come at
e dmidecode
. Entrambi i set contengono anche elementi specifici di Debian, come dpkg
e apt
.
Si noti inoltre che entrambi i set insieme non sono un superset della funzionalità richiesta da LSB (o POSIX + XSI del resto): mancano queste utilità:
ar gencat lpr msgfmt strings
bc gettext lsb_release patch strip
ed install_initd m4 pax time
file killall mailx remove_initd
fuser lp make sendmail
L'elenco delle utility che si trovano nei pacchetti sopra ma non in LSB è lungo e noioso, ma lo sto comunque includendo per sottolineare solo quanti "strumenti di amministrazione del sistema critico" include.
accessdb mkhomedir_helper
add-shell mklost+found
addgroup mkswap
addpart modinfo
adduser modprobe
agetty mountpoint
apropos mt-gnu
apt namei
apt-cache ncal
apt-cdrom ncurses5-config
apt-config ncursesw5-config
apt-extracttemplates neqn
apt-ftparchive networkctl
apt-get newusers
apt-key nisdomainname
apt-mark nologin
apt-sortpkgs nproc
aptitude-create-state-bundle nroff
aptitude-curses nsenter
aptitude-run-state-bundle nstat
arch numfmt
arpd oldfind
badblocks ownership
base64 pam-auth-update
bash pam_getenv
bashbug pam_tally
biosdecode pam_tally2
blkdiscard pam_timestamp_check
blkid partx
blockdev perl
bootctl perl5.20.2
bridge pg
bsd-from pgrep
bsd-write pic
busctl ping
cal ping6
calendar pinky
captoinfo pivot_root
catchsegv pkill
catman pldd
cfdisk pmap
chage poweroff
chattr preconv
chcon printenv
chcpu printerbanner
chgpasswd prlimit
chpasswd ptx
chroot pwck
chrt pwconv
clear pwdx
clear_console pwunconv
colcrt raw
colrm rbash
column readlink
cpgr readprofile
cppw realpath
cron reboot
ctrlaltdel remove-shell
ctstat rename.ul
dash reset
debconf resize2fs
debconf-apt-progress resizepart
debconf-communicate rev
debconf-copydb rgrep
debconf-escape rmmod
debconf-set-selections rmt-tar
debconf-show routef
debugfs routel
delgroup rsyslogd
delpart rtacct
deluser rtcwake
depmod rtmon
dhclient rtstat
dhclient-script run-parts
diff3 runcon
dir runlevel
dircolors runuser
dmidecode savelog
dnsdomainname script
domainname scriptreplay
dpkg sdiff
dpkg-deb select-editor
dpkg-divert sensible-browser
dpkg-maintscript-helper sensible-editor
dpkg-preconfigure sensible-pager
dpkg-query service
dpkg-reconfigure setarch
dpkg-split setsid
dpkg-statoverride setterm
dpkg-trigger sfdisk
dumpe2fs sg
e2freefrag sha1sum
e2fsck sha224sum
e2image sha256sum
e2label sha384sum
e2undo sha512sum
e4defrag shadowconfig
eqn shred
expiry shuf
factor skill
faillog slabtop
fallocate snice
fdformat soelim
fdisk ss
filefrag start-stop-daemon
findfs stat
findmnt stdbuf
flock sulogin
fmt sum
free swaplabel
fsck swapoff
fsck.cramfs swapon
fsck.ext2 switch_root
fsck.ext3 sysctl
fsck.ext4 systemctl
fsck.ext4dev systemd
fsck.minix systemd-analyze
fsck.nfs systemd-ask-password
fsfreeze systemd-cat
fstab-decode systemd-cgls
fstrim systemd-cgtop
geqn systemd-delta
getent systemd-detect-virt
getopt systemd-escape
getty systemd-hwdb
gpasswd systemd-inhibit
gpg systemd-machine-id-setup
gpg-zip systemd-notify
gpgsplit systemd-path
gpgv systemd-run
gpic systemd-stdio-bridge
groff systemd-tmpfiles
grog systemd-tty-ask-password-agent
grops tabs
grotty tac
grpck tailf
grpconv tarcat
grpunconv taskset
gtbl tbl
gzexe tc
halt tcptraceroute.db
hd telinit
helpztags tempfile
hexdump timedatectl
hostid timeout
hostnamectl tload
hwclock toe
i386 top
iconvconfig traceproto.db
ifdown traceroute-nanog
ifquery traceroute.db
ifup traceroute6.db
infotocap troff
init truncate
insmod tset
installkernel tune2fs
invoke-rc.d tunelp
ionice tzconfig
ip tzselect
ipcmk udevadm
ischroot ul
isosize uncompress
journalctl unix_chkpwd
killall5 unix_update
kmod unlink
last unshare
lastb unxz
lastlog update-alternatives
ldattach update-passwd
ldconfig update-rc.d
ldconfig.real uptime
ldd users
less utmpdump
lessecho vdir
lessfile vigr
lesskey vim.tiny
lesspipe vipw
lexgrog vmstat
lft.db vpddecode
line w.procps
link wall
linux32 watch
linux64 wdctl
lnstat wget
localectl whatis
login whereis
loginctl which
logrotate whiptail
logsave who
look whoami
lorder wipefs
losetup x86_64
lsattr xxd
lsblk xz
lscpu xzcat
lsipc xzcmp
lslocks xzdiff
lslogins xzegrep
lsmod xzfgrep
lspgpot xzgrep
lzmainfo xzless
mandb xzmore
manpath yes
mawk ypdomainname
mcookie zcmp
md5sum.textutils zdiff
mesg zdump
mke2fs zegrep
mkfs zfgrep
mkfs.bfs zforce
mkfs.cramfs zgrep
mkfs.ext2 zic
mkfs.ext3 zless
mkfs.ext4 zmore
mkfs.ext4dev znew
mkfs.minix zramctl
ip
comando che hai citato in precedenza.
La Wikipedia: elenco dei comandi Unix e Linuxconfig: I comandi di Linux sono sicuramente la pena dare un'occhiata.
Tuttavia, molte persone tendono a dare un'occhiata a ciò che è contenuto nelle directory mostrate da echo $PATH
e quindi guardare la pagina man per maggiori informazioni.
busybox --list
. Stavo solo scherzando.