मैं sshd
अपने स्वयं के कॉन्फ़िगरेशन फ़ाइल के साथ एक गैर-विशेषाधिकार प्राप्त बंदरगाह (जैसे 2222) पर एक दूसरा उदाहरण शुरू करने का लक्ष्य बना रहा हूं ।
जाहिर है, इस sshd
प्रक्रिया setuid
में उपयोगकर्ताओं को लॉग इन करने के अलावा अन्य नहीं हो सकता है, जो sshd
डेमॉन चला रहा है, स्पष्ट रूप से असंभव है।
हालांकि, क्या एक कामकाजी sshd
डेमॉन होना संभव है जो वर्तमान में चल रहे उपयोगकर्ता के लिए काम करेगा? मेरे उपयोग के मामले के लिए, यह ठीक होगा।
मैंने sshd
अपनी स्वयं की कॉन्फिग फ़ाइल और होस्ट कुंजी के साथ एक उदाहरण को बूट करने की कोशिश की और sshd
प्रक्रिया शुरू हो गई (कुछ कमांड की तरह, रूट नहीं होने के बारे में कोई शिकायत नहीं), हालांकि जब मैं उस पोर्ट से जुड़ने की कोशिश करता हूं, तो sshd
प्रक्रिया मर जाती है।
$ /usr/sbin/sshd -dD -h .ssh/id_rsa -p 2222
debug1: sshd version OpenSSH_5.6p1
debug1: read PEM private key done: type RSA
debug1: private host key: #0 type 1 RSA
debug1: setgroups() failed: Operation not permitted
debug1: rexec_argv[0]='/usr/sbin/sshd'
debug1: rexec_argv[1]='-dD'
debug1: rexec_argv[2]='-h'
debug1: rexec_argv[3]='.ssh/id_rsa'
debug1: rexec_argv[4]='-p'
debug1: rexec_argv[5]='2222'
debug1: Bind to port 2222 on 0.0.0.0.
Server listening on 0.0.0.0 port 2222.
debug1: Bind to port 2222 on ::.
Server listening on :: port 2222.
debug1: fd 6 clearing O_NONBLOCK
debug1: Server will not fork when running in debugging mode.
debug1: rexec start in 6 out 6 newsock 6 pipe -1 sock 9
debug1: inetd sockets after dupping: 5, 5
Connection from ::1 port 57670
debug1: Client protocol version 2.0; client software version OpenSSH_5.6
debug1: match: OpenSSH_5.6 pat OpenSSH*
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_5.6
debug1: list_hostkey_types:
No supported key exchange algorithms
debug1: do_cleanup
debug1: do_cleanup
debug1: audit_event: unhandled event 12
debug1: setgroups() failed: Operation not permitted
रेखा स्पष्ट रूप से बाहर चिपक जाता है, लेकिन जब तक यह एक कनेक्शन स्वीकार करने की कोशिश करता है यह मरता नहीं है।
UsePam
करना होगाno
।