Jakieś pomysły na to, jak mogę zmienić muszlę na rybę?
$ sudo usermod -s /usr/bin/fish jaan
usermod: user 'jaan' does not exist in /etc/passwd
$ getent passwd $USER
jaan:x:15466:94:Jaan Altosaar:/home/jaan:/bin/zsh
Powiązane pytania: użytkownik nie istnieje w / etc / passwd podczas próby zmiany domyślnej powłoki Wydaje się, że używa ldap.
$ cat /etc/nsswitch.conf
passwd: compat ldap
group: compat ldap
shadow: compat ldap
# Having the NOTFOUND=return bit was breaking dns resolution on web1 and web2. But we probably
# don't want any of the mdns stuff so let's get rid of it all.
#hosts: files mdns4_minimal [NOTFOUND=return] dns mdns4
hosts: files dns
networks: files
protocols: db files
services: db files
ethers: db files
rpc: db files
netgroup: ldap
automount: ldap
Więc zainstalowałem odpowiedni pakiet ldap.
$ chsh.ldap
LDAP password for jaan:
Enter the new value, or press ENTER for the default
Login Shell [/bin/zsh]: /usr/bin/fish
Traceback (most recent call last):
File "/usr/bin/chsh.ldap", line 69, in <module>
constants.NSLCD_USERMOD_SHELL: shell,
File "/usr/share/nslcd-utils/nslcd.py", line 128, in usermod
assert con.get_response() == constants.NSLCD_RESULT_BEGIN
File "/usr/share/nslcd-utils/nslcd.py", line 103, in get_response
return self.read_int32()
File "/usr/share/nslcd-utils/nslcd.py", line 71, in read_int32
return _int32.unpack(self.read(_int32.size))[0]
struct.error: unpack requires a string argument of length 4
$ which fish
/usr/bin/fish
$ chsh.ldap
LDAP password for jaan:
Enter the new value, or press ENTER for the default
Login Shell [/bin/zsh]: "/usr/bin/fish"
/usr/bin/chsh.ldap: "/usr/bin/fish" is an invalid shell
$ /usr/bin/fish
(standard_in) 1: syntax error
Welcome to fish, the friendly interactive shell
command-line
etc
fish
chsh
Abhishek Bhatia
źródło
źródło
/etc/shells
dlachsh
-Jak narzędzi, aby ją zaakceptować.Odpowiedzi:
Oto podpowiedź:
/usr/bin/chsh.ldap: "/usr/bin/fish" is an invalid shell
. Wydaje się, że powinieneś dodać/usr/bin/fish
do/etc/shells
.źródło
chsh.ldap -s /usr/bin/zsh myusername
daje miSegmentation fault
.Zaczekaj, to użytkownik LDAP, w LDAP jest ustawienie, które pozwala zmienić domyślną powłokę dla tego użytkownika.
Możesz zainstalować ldap-account-manager, który daje stronę internetową do konfiguracji ldap.
Można to zrobić na dowolnym serwerze, na którym chcesz obsłużyć konfigurację. Ponieważ i tak będziesz musiał skonfigurować serwer w plikach konfiguracyjnych. Ale polecam zainstalowanie go na serwerze, na którym faktycznie działa ldap, żebyś mógł łatwiej zapamiętać.
źródło
Aby zacytować tutaj ajmitcha ,
Wystarczy użyć
chsh -s which fish
i upewnij się, że wylogujesz się i zaloguj ponownie lub ponownie uruchom komputer.Nawiasem mówiąc, może to być możliwy duplikat: Jak ustawić rybę jako domyślną powłokę?
źródło
$ chsh -s `which fish` Password: chsh: user 'jaan' does not exist in /etc/passwd