- 在线时间
- 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) 6 ]* q, A7 C9 P
$ u* p! b I! Z. J
机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。 % z; o; O( P# A$ H
一、linux启动的最后阶段的工作 5 D5 G4 T* w6 K# f, H
3 t* ?- N1 u# w4 C- vlinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有: # E. Q% Z* G; G \8 a+ [+ r9 ]2 t
, N% `" T y/ X7 x: k9 E
运行xdm启动X window; ) L4 U' q* R! v! G- g6 d9 `9 P
运行gdm,进入gnome桌面环境;
' h7 {9 e; R( Q8 B+ H0 I运行kdm进入kde桌面环境; " Q) x8 j. \/ K5 i2 V- q% `, [
自动登录进入linux;
/ p# Y) ]8 w7 B; g! z' Xprefdm脚本框架大致如下: 0 J9 `- j8 P! X$ Q8 H
! P: a) h( g6 t* O1 F. W; Z& d4 @1 B#!/bin/sh
. j& t, u3 F' y0 P: |1 _PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin 2 }2 Y1 {( R2 z% z: B+ _
. /etc/profile.d/lang.sh o3 |! O7 h+ D$ Q4 U
# 第一步:查看是否为自动登录
0 Q: W7 S* L+ a; Z( a7 M' lif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
0 q$ |) Q! q" W% mif /usr/sbin/autologin; then
6 ]/ c2 r0 K8 R. W; G) `exit 0 8 W5 b- [6 I5 ?1 `; | I
fi
. m* G; J0 r/ X7 i8 e9 `fi + Q) d3 O7 @% q2 Y* m1 ]
' u9 {4 l7 g7 M# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式
) j4 g$ D' X' P& ^...... 4 Q7 @4 w) q% {" e
# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 $ y' k( L W# w
......
3 z: v5 z- M t7 W2 `& k# V) C
/ T& a& u- _; N$ N 3 h/ G% R0 @5 A8 b* s4 E! D- e7 ~
7 h% n5 [. ~7 ^9 B: ~( U6 I' s5 d( J
二、自动登录的实现(autologin的实现) ! c' d! s; h, h4 l
) J+ X! Z2 V! j! Z' [8 a在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。
: T4 w. g) d. J" t# {$ K. g1 T: O1 }
; S. p. G: h# g4 K6 s5 K自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。
5 }) c4 Y* h \8 Q U- W. W' L8 f/ N& i
Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。
) b( w# O( R, E% C. f+ z实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。 5 a7 Z3 l$ I# @ K4 U5 Q
startx脚本的最基本框架是:
5 x2 D! Q2 h$ N3 q4 c% {/ w% m% ]2 _
a、 寻找.xinitrc,如果没有则使用xinitrc;
7 I3 }! s% S2 T& t% O4 T6 O$ `b、 寻找.xserverrc,如果没有则使用xserverrc; ! t- n, z G) J
c、 根据找到的脚本确定xinit的参数;
4 a O8 y6 S1 ?- t4 e. m. p4 R
. {: I* P- T" h0 V由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录:
! f" E8 {- O& |, e- J& W+ i( K4 U& H+ i
! B5 y, c, b2 k1 ^1 a% P9 _ I. Z2 h
#!/bin/sh ' O" u% k" a, W, W/ ~: C" N$ s
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin 1 E& v( i, d2 D! r y6 s0 q. q
. /etc/profile.d/lang.sh
( l/ a2 o" n0 n# 第一步:查看是否为自动登录
7 e- Z& e/ v2 M2 E" k#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 6 _4 d ~; E4 t: S/ k" R
#注释掉上边的条件测试,直接运行startx % V( j/ C! N$ i0 s
if /usr/X11R6/bin/startx; then
. @0 g4 p$ A; R( l- w5 N* `exit 0 ! y }: Q4 H& l/ K3 t
fi 6 F5 @1 K+ A+ ^$ H5 F$ G/ Q
#fi / ], D) W. ?. E6 H( Y. b4 [
( k0 v) w. E# Q" l$ G# c: Y
' i( q9 r2 y% N9 }. W+ _
: ^3 R$ v+ O" G( ~+ ]/ m* ^+ ]
2 v W% M$ J2 S4 L! F当然,应确保/etc/inittab中的启动级别为5。
0 ~; m6 i ]+ i0 Q+ q \% z: ]2 e' n7 p. m/ O9 k, |4 o" H: m6 k
重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
, P% H& i9 ]) ]( W. V4 F7 C! ]* e8 }* W& z# M. c" V) s; Y# C; y. ^
三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。 " J/ l1 {6 A" y; z) ]
& b+ `; K3 L; q9 k1 h1 D
观察原来/etc/X11/prefdm脚本的自动登录部分: 2 q9 e* n% D* ~/ t7 z
& k* ] |% ~6 d1 ?$ w" w: Z, E
. N3 ~7 u. ]6 R; g) y" g( q
...... ; [* V3 x$ [. |- B1 ?2 c- c
# 第一步:查看是否为自动登录
+ a5 i& M! d( p0 p) u* ^+ cif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 6 ~5 o4 P; K l+ v% K
if /usr/sbin/autologin; then
7 `6 O2 {* l& }* |, w" D8 u$ i! ]exit 0 & Q( C9 S/ U4 H9 G7 d, m3 v1 v
fi
6 `$ |7 s+ T, o! a( m- [& a8 qfi - ^4 O& c O @8 \( U7 \
...... . y) m% \- }0 Z" v6 J
6 [1 n$ d9 U6 i5 _ Z0 k% X
" n! u1 G* u: A/ y7 s0 X
& N; M; z3 r" Z$ e& Z# X, q& U8 }' n" ^2 l8 H% l* k
不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。 ! F% y9 p3 P, @, h0 Z5 p
3 T( n7 Q$ @( \* l* D4 G* s
1、/etc/sysconfig/autologin配置文件的实现: : G8 J8 B1 T! C4 I( W+ s8 y
8 m) R( d1 D5 {+ N
, S/ ?. x# H: j4 w& g4 R#config for autologin 0 }5 L# i0 }# {" H5 U) @
USER=root & B" c. s6 k$ e( A, x: `$ E
EXEC=/usr/X11R6/bin/startx
8 t9 C5 x/ R6 T" `7 |说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。
. E+ t. X7 r6 I7 I; Q+ O
" o- B0 O' k2 r8 i# q, G * k8 Q2 r+ |$ B5 D- p( O! \8 {! W
% f: L- Y G! \4 u: D D, H
5 Y$ A7 y; S0 P+ @2 f! O
2、/usr/sbin/autologin可执行文件的实现:
% o" K9 z! Z" X' H; ]: N7 Y
_3 f' y' n' U) Y- h ~, S) q0 v' R/ n( E; m
/*********************
6 F- l- T" ^3 }4 D; h7 H6 c" a**** autologin.c **** ) T C) a1 d2 Z
*********************/ ; T; z+ G6 Q! _9 L7 y" ^5 w
#include <stdio.h>
. O" j& ^, D. K1 M; Z+ t#include <unistd.h>
+ j- T2 [8 |% w& w3 K. a* R#include <string.h>
1 Y D# \- u2 [* P0 F#include <errno.h> I0 f' c, ^8 p+ i
#include <sys/types.h>
! f) o: t) ]3 v! [0 b, g#include <sys/stat.h>
& ?7 K; Z" @% _) I#include <pwd.h>
' c0 _$ A+ E% ?8 O/ J
7 h, p5 j; B, b8 `- Q$ O- {int main(int argc, char **argv)
8 J5 m7 b& o! ~$ b1 F: A0 P) Z{
9 [" n8 x p! X# }1 Gstruct stat st;
: y1 ]' H) O5 J8 N" F2 oFILE *f; % K' Q2 v8 P. A
char *cfg; , T! a: ]: D$ |0 x3 v
struct passwd *pw;
8 x/ d. ?' O8 O) ~uid_t uid;
* z- C9 r9 ?9 Agid_t gid; 5 H5 H. c" y; @ u2 p0 I( y! F- {
char *dir, *shell; " L3 p& q+ B) k' |
char *user=NULL; & H. o9 N+ b# C! w8 H
char *cmd=NULL; 9 J4 H {/ E- v- A4 P" Y1 \
, W6 c6 ~. b) `- b0 ?1 A$ Z& R ~6 @7 x
user="root"; h$ K' w) S9 n" f- u
/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上,
) l5 d; @" r. `/ L+ h3 s- {& A4 p7 \登陆用户名应该从/etc/sysconfig/autologin中得到,
H8 z* O' e4 X" N$ L- r程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/ - b+ i- _2 _8 ?7 K# T
cmd="/usr/X11R6/bin/startx"; ( c5 z8 W* K2 p, {' U: n
/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/
# M9 ]" X% i4 J4 s1 w: H/ u( J8 n; f; H' Y
pw = getpwnam(user); $ G* c. H) x. r- Z
//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。 ! u5 b2 N" |& x8 {% C Z: U
if(pw) {
2 }5 d! ?2 F' v8 k2 Iuid=pw->pw_uid;
4 w8 m; C: c5 B$ f" q2 P' sgid=pw->pw_gid; dir=strdup(pw->pw_dir); . P+ O9 J i8 b" O% P! F. I9 r, F: R
shell=strdup(pw->pw_shell); . ?- A0 [ ~' [2 `6 j/ g+ d9 q
}
, A8 g- d8 o* ^! W% K3 J& N% T# j//获得用户相关信息 , D$ w/ k$ A8 j2 v+ j8 i5 H }6 m" ^
else { $ w% N$ [8 D/ u6 _2 Q2 T
printf("ERROR: No such user %s!\n", user); & n5 I7 m; @# l' T' k
return 1; 0 Q5 D5 k$ F3 m. h9 x& x: `
}
2 @7 u, D4 Q3 ?8 N
+ E' _8 \1 j$ `2 c* tchown("/dev/console", uid, gid); / v% x# F" y8 J1 a1 u
chown("/dev/tty", uid, gid);
7 s9 A1 X, D- s( \3 D# C//为控制台和终端设置用户ID及组ID
0 [1 Z6 Z( l2 u" J8 e+ ^$ q0 B/ B
# Z L% b' n" o//下面是设置用户相关ID
2 R7 E3 I8 J8 k+ {' \setregid(gid, gid); 4 w; t/ z( b. p+ z
setegid(gid);
' X4 k: o3 N0 D0 }" \7 Q( P' hsetgid(gid);
7 _) r6 O" h! d; Jsetreuid(uid, uid); $ k. w2 t1 d6 K4 g0 X
seteuid(uid); / B, p* O! K N: Q" O O
setuid(uid); 9 n1 j; E" D/ @ J: o
( p. ^/ V; V) v" e
setenv("HOME", dir, 1);
1 C5 i- N; F7 L8 z& y! A* Qsetenv("SHELL", shell, 1); & \# O7 F/ U) X+ V; V& G5 ?
setenv("USER", user, 1); 1 _0 @ H m/ h+ S
setenv("LOGNAME", user, 1);
+ M. J- m" N' |$ u& t0 ?//设置用户相关环境变量 % C. o. N7 P' m6 f# m
8 @8 |1 ~& m. \+ {; r$ L/ |
chdir(dir);
/ f9 R9 d) ?0 w3 P; L. x//切换到用户根目录 * V/ w9 S- B0 U7 h
user=NULL; 0 s) ^& s$ M, @1 l1 J$ [
: L; p' P9 a2 pexecvp(cmd, argv);
( k0 k, F2 i: X/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */ & Q* Z. J) W) ?5 [" W
printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno));
; g' L4 V8 q; ]3 @7 u' o$ creturn 2;
5 W8 J) j* h3 {( j( [$ R& T} : K# H( f. ]3 f- Y- ^
. ?, M" i/ `( A2 s6 N4 x
: j! }3 d* e& ?* C" r
, g# I+ U: a3 m2 d
0 n! l6 L2 S' x7 P3 U5 `运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。 h7 F- `' t: E! D9 \
# X* ~0 ]9 [6 D" {. C) t O$ _
如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: 4 ?/ v+ k2 W1 I; b. a. Q
$ W! F$ [9 `/ k7 B# z3 f3 e( ?8 k. @* L' A, L6 ~* Y
...... ' v( l2 v: ~5 F0 l S8 L- L4 {
# 第一步:查看是否为自动登录 $ D" }$ S5 S7 ~; Z5 C0 c' {2 o! U) t
if /usr/sbin/autologin; then
) U8 w; o0 Q" W D& E; v0 |+ Wexit 0
* d5 x% V+ O0 u& }) X- sfi
7 @& e! G( V) _7 \9 B//第二步 ......
H$ S- z2 S* ^' v( g4 b# I...... / d, D. c. ]# [6 ~& b+ D; J2 a7 q
h3 t( O8 A& p, F
- b7 y5 t: W1 P# q0 S
4 d, a a! Z7 J6 [
* H3 H9 d# D! b6 [: M即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
! S# e' f% I0 }! k0 ~; \
; y4 k) N3 q, {5 j) Q* }7 h四、选择进入kde或者gnome,并自动启动X window应用程序
# z0 ^5 i7 v/ K2 m, z1 L0 c# z
% q3 h. p+ \. b. |# n7 q& F t如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。 2 D) g1 y. c$ {6 |: d
一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。
' M1 ^6 A7 [0 c3 G( L9 E' P9 G9 p* P0 f" e7 W0 H m
- M5 e: v0 B. }5 X: Vhttp://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|