- 在线时间
- 63 小时
- 最后登录
- 2019-5-3
- 注册时间
- 2004-5-10
- 听众数
- 442
- 收听数
- 0
- 能力
- -250 分
- 体力
- 10122 点
- 威望
- -12 点
- 阅读权限
- 150
- 积分
- -586
- 相册
- 6
- 日志
- 10
- 记录
- 10
- 帖子
- 2003
- 主题
- 1253
- 精华
- 36
- 分享
- 8
- 好友
- 1292

复兴中华数学头子
TA的每日心情 | 开心 2011-9-26 17:31 |
|---|
签到天数: 3 天 [LV.2]偶尔看看I
- 自我介绍
- 数学中国网站(www.madio.cn)是目前中国最大的数学建模交流社区
群组: 越狱吧 群组: 湖南工业大学数学建模同盟会 群组: 四川农业大学数学建模协会 群组: 重庆交通大学数学建模协会 群组: 中国矿业大学数学建模协会 |
2#
发表于 2004-9-27 14:27
|只看该作者
|
|邮箱已经成功绑定
如何实现自动登录Linux (Runlevel 5) ! J; V: j4 q0 Z9 F
# A7 V* a8 C7 D1 u9 \
机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。 * z2 Q7 f. c/ J
一、linux启动的最后阶段的工作
{( [, [5 N/ G) F" V9 W5 q; e
0 h* \; f7 _1 P& clinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
" p) s. W* }. Z* ?) ]! O9 b7 c/ U; T. }5 z3 U. f$ A3 z
运行xdm启动X window;
+ {1 ^5 n, P$ T# j @: z' C, g+ v运行gdm,进入gnome桌面环境;
% C$ P. ]" @- B- I运行kdm进入kde桌面环境; A$ s, S, n6 K+ \7 Q% T' m, M* l
自动登录进入linux; $ Q x7 l$ P" \) @: L, ]; y, r
prefdm脚本框架大致如下:
: r! R& G" r7 O: C4 s4 t! E. r b
2 [5 \- y! P) k#!/bin/sh
4 R$ g1 K! n1 ^6 b' Q7 xPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
0 U+ K5 ]( R4 Y. _. Z a: i. /etc/profile.d/lang.sh
' f5 H# e6 J+ y( A% A; ?% S# 第一步:查看是否为自动登录
) J0 q/ F, ~; b# E; l! K, {if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
9 ~6 X& @0 k, j6 S' W- sif /usr/sbin/autologin; then ) r# V& U. w- \* s$ Q+ j
exit 0
' Q4 N6 O( Q1 A: b, i nfi 1 ^ d! x( @8 n% ~3 j2 H+ c- Z* Z ~3 P
fi
% _5 I2 z W! M5 e; T$ N6 B" Z) B) K4 t
# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式 " ^+ L% b& @' _& H# z
...... # y5 f. p$ I) V0 h& I
# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。
x3 {" t) O! c...... ( p, |% m" C) J4 M. t
; T. X9 h; }7 m0 G
1 Q- f0 x. _" I l
1 s8 X' a' g! A5 ]" v. F, w
- s6 G; c/ I1 @3 C+ j二、自动登录的实现(autologin的实现) % o4 @# k+ ?+ @" q, o$ U) b
! e6 c$ x- c% ? @) n4 N在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。 5 V: z; F! @; {3 z) x% z: F N
; C& H4 y1 F3 P6 n
自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。 , @7 o: ^$ F0 j; p! p# z
( J$ k& \4 g! BXinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。 + F3 `4 P3 n( i. X
实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。
1 e. O8 Z0 e6 f, O) z2 jstartx脚本的最基本框架是:
7 _6 B/ O6 ^; W
' D1 E7 K1 h. g' {; Ia、 寻找.xinitrc,如果没有则使用xinitrc; % D$ M5 R# ]' D' R
b、 寻找.xserverrc,如果没有则使用xserverrc; 8 U3 n7 R+ ^4 X
c、 根据找到的脚本确定xinit的参数; & r; P8 M) J% Z
+ ]* `+ R! [' w: e7 {) \9 I由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录: O) q7 E, G1 D% `: E7 Z( o
0 J$ B8 p9 m K, H* p$ M/ p
, d, Z& l; l0 B9 `
#!/bin/sh # v& L! s9 q2 b" d, O! W
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
% N! k! V- e2 E$ c. /etc/profile.d/lang.sh & C0 `3 g! @9 @& l" S0 H9 Z1 O
# 第一步:查看是否为自动登录
4 m/ a% o" t6 V: E#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
/ o' x$ o: R. A9 B, d0 h( w5 X+ [#注释掉上边的条件测试,直接运行startx ' z8 O% t6 M3 @& M. j8 e& ~
if /usr/X11R6/bin/startx; then
: i5 o! M$ L& O' H( K( R1 kexit 0 5 r0 g0 h S) ?" [5 s3 g
fi
% Z+ C/ b8 w) U0 C+ z3 I#fi 1 ~/ I: Q- L7 s+ C; [2 b
$ f3 c( Y/ I' j% S) @! A+ F( J
% q" z4 \- d9 b. l% m
& [# B' i y" o" L0 N$ {+ a( H" y4 O* ], @9 ~# W5 B' q
当然,应确保/etc/inittab中的启动级别为5。 - O6 `+ `* V) D: n& L
* P6 y' w( [9 v! c6 @
重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。 ! i; |" Q9 L+ r+ M1 |6 Y9 X
5 `9 h( b7 m4 B7 j8 y m三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。 + ]7 ^( F* ]3 X# X/ Q$ Y3 y
8 _4 O8 z" x$ P
观察原来/etc/X11/prefdm脚本的自动登录部分:
8 `$ J1 ?' @0 {. ^* Q( f1 d1 Z* a& T$ z: I, f3 O0 P
! B# e& F/ w: k6 [' C4 \7 U...... $ e% J% f, \$ A% W
# 第一步:查看是否为自动登录
6 ?$ r5 n( F: J% W& ?if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
, M& \4 z, G7 Pif /usr/sbin/autologin; then % [' v; k- t& r$ z k. ]
exit 0 : p' K6 K3 p# s* [
fi 2 t8 |8 k+ A) `3 u- I! v- V* o
fi ) s* N* H8 S" ]; u& |7 ^, H7 h
......
Q8 _2 G; A Q1 H- x1 ~
: X5 |# P( O/ M! @# F: V: Z O $ T# n, I4 ]0 L2 h
! F7 P, ]4 d! Y/ s: N+ t$ g+ [5 N! V$ I* V
不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
4 {) D' i1 E) s/ N5 q6 `1 ^; S2 F# _
3 v, Q6 F* y5 a! z1、/etc/sysconfig/autologin配置文件的实现: * [6 \9 Z5 q4 R& L) A* _
: T: B5 v; A+ Z* C7 h! f8 F$ e7 G- s4 u) `
#config for autologin # C6 ?" i5 W9 \
USER=root
" u; o* S5 F5 d( [EXEC=/usr/X11R6/bin/startx 1 H, S1 B& i* p% F$ f4 Q
说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。
6 I. f6 Q& X+ _! Q' W# H2 g- E5 n! ?) |, q! p. s3 _2 i. \+ N" Y
# Y# M% a6 }+ M, {1 D" Z; x& P; b
q! o- w# q8 g9 J
; J/ ?3 S5 a5 Z* V7 d* B2、/usr/sbin/autologin可执行文件的实现:
4 Y) L$ N8 x0 ]! X
/ O) G# o. m; z/ k
J A% e& {7 K# L4 p/********************* ' y* B7 f) z0 m$ @( V
**** autologin.c **** & n& z" D$ E0 _. H: \! G/ S5 ]/ s; Z+ H
*********************/ : J, M2 b; H1 u' W3 J* ~3 [0 O
#include <stdio.h>
' h9 @0 W% C# P' j; g( s#include <unistd.h>
: [1 f$ ]9 _/ ?) R- N3 f/ C#include <string.h> # ?, z5 N3 [; B4 l
#include <errno.h>
% q. P3 `2 w* H! ~; }/ }#include <sys/types.h> 3 p# J0 q/ l9 @6 s
#include <sys/stat.h> * }) j2 F( g4 a
#include <pwd.h>
' N7 H9 L2 d7 }) ]- P" d9 ^& [9 X# f1 ]( B8 \; `" {3 C5 s
int main(int argc, char **argv)
& p! Y o0 c) F( Z: }* U{
9 P$ x7 z; p4 D3 L: _1 l. Istruct stat st; % _0 Z0 ~$ f; h) F
FILE *f;
) P# |: g c2 V0 S. @char *cfg; 5 b+ z6 x/ I& ~4 g+ @
struct passwd *pw;
0 j8 i6 e3 y) Q1 m; x! J: Luid_t uid; 2 g- H4 z, s( q5 |
gid_t gid;
( B0 X, H! v# n( hchar *dir, *shell;
/ d5 y* \9 j8 {7 o$ I9 R2 Schar *user=NULL;
/ K- { u! S( L8 W3 b* y4 I% `* E. uchar *cmd=NULL; % k! E% Q c( x) [& d5 M
' T$ Z0 n) P( `' q, A2 [
user="root";
6 z. e) f1 w/ c/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上,
. j" y6 f& O# P$ J" k登陆用户名应该从/etc/sysconfig/autologin中得到,
3 w+ c6 ~6 F4 @$ U1 \' i% {程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/
; @3 `0 `. Z& Ocmd="/usr/X11R6/bin/startx";
" j7 A1 B( \+ a/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/ + x7 X! @8 t! r9 p
3 O: H3 f4 H7 J( D# z
pw = getpwnam(user); 9 D. T$ @7 i7 N+ f! w- J' q/ m
//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
) h2 \) n3 N6 H5 }6 h* X! v, K6 Xif(pw) {
- {4 o& w( o0 {uid=pw->pw_uid; % H" E8 b M% q% F% S
gid=pw->pw_gid; dir=strdup(pw->pw_dir);
; K& L3 Q) C2 w: W7 rshell=strdup(pw->pw_shell);
5 ~8 A0 \. ]6 T8 e8 Q} 9 R. k- L2 z5 Y9 a6 ]
//获得用户相关信息 / I; f' M0 R. ^# k8 s
else {
- z/ X; c" `8 sprintf("ERROR: No such user %s!\n", user); 3 ~( i- x( A7 n* O# F! O
return 1;
) H) V6 L3 i8 j2 P+ M1 |- Y' i+ E} # R5 ^. }4 s! P ~9 u* t; ]
1 \! t9 a* p+ D! {) Q4 U, Tchown("/dev/console", uid, gid);
& Z) C. h* S5 }, @" O2 B3 N Cchown("/dev/tty", uid, gid); ( k: p" e9 D8 C |
//为控制台和终端设置用户ID及组ID
& S% v, g% V3 O* y# O* x" X Q$ h. N( Y, I
//下面是设置用户相关ID $ p: u1 q m" s$ D% e" B. z& s
setregid(gid, gid); ; w c: Q5 A( n
setegid(gid);
5 O! L7 X! M# Z6 j7 s: o: l7 y2 isetgid(gid);
5 c' z' O7 t# S" Bsetreuid(uid, uid);
0 Z+ o r; n* h/ Y+ L5 dseteuid(uid); 9 R8 `) F4 D% p; O- P5 f5 m; [
setuid(uid); 4 u; C9 r# r& V0 I6 s6 G/ S
$ F$ \. ]- k8 L9 V& q, v5 Dsetenv("HOME", dir, 1);
* i; V+ h" u, l, Y/ @5 msetenv("SHELL", shell, 1);
% _3 J9 C! T8 f% C/ w" O% ksetenv("USER", user, 1);
6 m7 ^/ \4 Q+ k0 vsetenv("LOGNAME", user, 1);
& A0 L* i2 r3 \: H+ R u//设置用户相关环境变量
3 Y' J& R' e3 ~+ v5 h+ A# H- r7 }$ q- D- N9 T: ]2 D0 o2 u: S
chdir(dir);
2 P% Y, t7 I' Q//切换到用户根目录 3 s) M$ Q* A* `6 n+ d( h; z
user=NULL;
- | M9 U1 j" K) Z8 @% ~; ?0 D
( M$ {1 R" T# Z i- p9 r$ j; ]execvp(cmd, argv);
' |' x! j9 ?8 B* r/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
8 T) \7 Q9 W5 P8 n! d8 ^printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno));
8 ?! p( o) [' d3 z- C g9 jreturn 2;
+ D5 U- y3 l. K& A% }}
+ m/ A$ e6 T1 J7 Z. A/ | g; v" K s: q* i$ ?; u( o7 R
. t V5 O0 h/ ~8 T) e& \( }
& ~" @/ }+ p! H1 c; A
# q% k; _ E5 }. e- @% S& K运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。 ; i/ b- ~$ b4 o0 u
; S/ P: _3 E1 |( y" V1 f
如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: ( C8 A1 r; w+ M% S4 {2 T
9 i; h4 q& f2 R) t. ?. Y; m
, g% v# ^( M! Y! T; K- x...... 6 m4 ]1 r# N' D2 W. k- z9 G+ |
# 第一步:查看是否为自动登录 $ ]0 {) i1 ?" S2 A# z
if /usr/sbin/autologin; then
+ r/ m: d; ]2 @exit 0 & z6 P: H" j P6 ], G! u
fi # E; z# ~- N% L. X' {3 w
//第二步 ...... ) j" t8 w( q6 c
......
* s# F0 d4 a' j5 v- W
+ z9 h4 g" W4 j/ D% o" I
+ D7 l0 P$ g/ ~$ `, H$ e; T4 D, x7 t; B, u& F& d2 t5 a2 K0 b0 ]
/ k, s& j, R `即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
2 b3 a' \# S! k# T! ^, F3 y6 X2 s9 `' N s! {2 l
四、选择进入kde或者gnome,并自动启动X window应用程序
% |$ J% Z" Y: `4 ~+ L7 H$ Y$ ~( T% l2 T% i3 ?, S
如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。 9 F$ m, m1 K: B; n R9 M
一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。 4 k8 L. P$ {1 A$ V/ O2 c
- j* k) T( j# H& c: }5 e( e
$ [! T0 {. b3 b+ p" C
http://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|