- 在线时间
- 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) 0 {; v) u; Q: E8 _8 j/ v
$ l3 q) Y& b' ^5 v7 z机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。 5 J1 f8 P, I Q. J1 F0 z' i
一、linux启动的最后阶段的工作
0 a; H3 r8 @4 ^' K; q: I- e9 ?( O. N. d' Y+ _3 n& N
linux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有: * Z3 e9 b$ c+ E1 r
( N' t" v$ A0 Z- a% m运行xdm启动X window;
8 l5 K7 V Q1 K# y$ ~! w. t' m9 u运行gdm,进入gnome桌面环境; ! q" z; n7 h6 ^/ S9 q6 Z: X% w
运行kdm进入kde桌面环境;
2 f- h' W2 N" x; l4 n+ \自动登录进入linux;
3 f. w5 k7 \0 ?5 x5 rprefdm脚本框架大致如下: 8 U- U9 s( [ d. J7 [
9 O" h8 N) E# Y- d% |) Q#!/bin/sh
5 l6 ^2 u8 I6 ~; v5 m+ x% [9 BPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
; Q6 K( e; s" \( u) a- I* @7 v. /etc/profile.d/lang.sh
2 ^" d4 ] g+ T. u/ J4 w7 O, ?2 S# 第一步:查看是否为自动登录 ) }' ?6 \$ V5 J: |/ l" O0 R
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 3 F2 K1 J y: i2 a7 t) l+ g! n
if /usr/sbin/autologin; then % b1 |" t/ a; C- h% l
exit 0
5 }+ u% P" D" h3 t( t& K: J- ^, gfi
- j5 ]+ j5 b {' Y: ffi 8 T/ m+ f1 f2 E4 n6 h
( N! l: Y8 @4 ]4 C6 l
# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式
) M4 y$ Q1 }) K* @+ `) a......
9 w, }' G. p- e5 S: M# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。
1 x4 w4 N/ F* d...... , @, E! |) Y( b) M# W( e
* w1 Y% T3 E% O# o- c- F! @
$ Z7 E, H% U& N- B
8 V9 y0 [0 Y4 z" B$ ?. Z5 I( |* H& G& `, C1 _
二、自动登录的实现(autologin的实现)
$ x# E: I7 w0 g( k( h
9 g! X& r8 P0 x9 r: \9 j0 I! z在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。 , k3 n# L/ J% d% [/ I$ N- G
) t; V$ L1 w6 L) ?! g
自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。
% \) ]( V9 ?2 u! { v, d$ ?5 B6 b" s0 U
Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。
0 {7 y# `9 ?. _( Q实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。 : _* n% H' V7 o0 ?; N( \9 ~
startx脚本的最基本框架是:
( a- v9 ?. d: t$ o% L% W# {( k5 Y# j- t$ w* y
a、 寻找.xinitrc,如果没有则使用xinitrc; " G# z* A/ X, q) F# {0 }
b、 寻找.xserverrc,如果没有则使用xserverrc; $ Q6 ] z" i; w9 Q* |% ?/ g" N
c、 根据找到的脚本确定xinit的参数; ' x/ d4 y3 y: H3 `
7 ~" l2 ?0 r* v
由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录: 4 p D4 y- p' }2 S. v
- W6 P0 X2 U* L1 N
; J+ X; t8 Z* m6 c* [: W- [5 h
#!/bin/sh
1 j- }8 n5 ]/ b1 J9 W- a/ x" {PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin 9 Q! a, K% J* Q& N6 q$ i4 D
. /etc/profile.d/lang.sh + g% V3 |$ x, v8 M5 _0 f, c
# 第一步:查看是否为自动登录
8 S+ y/ I8 s. h4 U: H#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
2 E+ Q# v+ k; Z, D6 [9 M! W. n#注释掉上边的条件测试,直接运行startx & R/ G8 B; l/ t4 N# K$ h
if /usr/X11R6/bin/startx; then 6 J; g Q& S) F
exit 0 ( o5 w- E$ ?$ U! g. K0 U
fi $ w# D; h2 |: ?0 W& ?1 M' }; {
#fi
8 |4 k- r8 N" M
) a e- q% Y+ i9 ] + J" |0 f0 ?' e. V1 [( i
+ T, b2 S9 c1 w; X( m) Q
& y; P6 f9 ]- |! E
当然,应确保/etc/inittab中的启动级别为5。 * V& W! B4 @( L
3 ^+ b) R& K# T2 U* F/ ~
重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。 + _! C% c3 h, E+ F
+ Z, o6 s C& d$ u* c
三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。
7 O! ~- f7 ]- q" c" h1 i
6 f# {7 e# I0 K! }观察原来/etc/X11/prefdm脚本的自动登录部分: 9 O2 c w1 p% N! p) l
" _! s. b$ ^% U& E' q: H
6 D; E; h+ A* @8 n9 w
...... , J, j) z( p$ y3 y
# 第一步:查看是否为自动登录
5 Z3 f4 {& W" x. }( Mif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
. Y+ M* }6 \8 hif /usr/sbin/autologin; then
* T! N% l& o4 o$ K6 U4 gexit 0
0 v$ I) k/ n2 Z0 r. a3 ffi 7 P0 q1 [, X8 ?# v! }+ B7 i
fi
$ ~% W m: @' P6 V# b- u( ]2 q......
O2 R6 r0 B8 a
1 l3 k! V, g1 W3 n. K5 `# B / R$ a, |1 C5 k' T$ K
2 Z6 i5 l) ?1 H0 R" ~2 y
% N: }2 F& ^( u( z2 Y6 h0 H) n `; \; I不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
y h+ l+ P- w# l+ N) L. q3 P1 Q0 f; \
1、/etc/sysconfig/autologin配置文件的实现:
2 q3 L7 M6 P. [* C) v
* m. H2 J0 C; I% h* o( J' J
/ m. M: X8 V/ e- @6 O: e#config for autologin
+ z' O8 }: i& t) D$ S# A4 @$ P4 k+ IUSER=root 9 O& {( s8 x: ^5 `- C4 A2 G
EXEC=/usr/X11R6/bin/startx
. h' \( O% S9 f( ^6 \/ x说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。
B+ U; x/ d1 e; [, F9 I- X( H% x/ X6 L+ G
` Q l! y1 t" E6 [
6 H5 B+ j2 G, ~# U) u
d# g! k* z" Q4 c0 V2、/usr/sbin/autologin可执行文件的实现: ! q8 b, ~1 p5 \! F
0 H+ u& ?6 P$ y+ q6 w* U
% I8 V( v6 u* i* ?8 N; i9 c/*********************
. b2 l/ J$ Q/ h3 h**** autologin.c **** . J+ C* U, Z) y' ?+ ?! C
*********************/
1 y0 M0 Y+ t8 I7 i#include <stdio.h> , ^+ r0 N0 k- D. e& r4 ?
#include <unistd.h>
* j7 g! a+ c1 Z( t" V#include <string.h> 4 L& d+ w7 I& i) _
#include <errno.h>
; ]+ N. e0 w# N% [2 y#include <sys/types.h> 5 ?4 j( q( a/ H! G# b
#include <sys/stat.h> " f; m$ ?8 I& w5 e- v) \
#include <pwd.h> }) a7 U# L% k! f* c( k! |
/ K) j" S6 {7 e ~; F7 ^int main(int argc, char **argv) 7 q, X$ ~& R9 e O) O
{ ; O" A& G1 I5 ^0 c
struct stat st; 6 ~0 l5 j% q8 Z- A
FILE *f; 4 p. d4 s- r8 ^& E% O* A
char *cfg; 6 b; f7 k' x) h- _ t
struct passwd *pw;
) b# ~- U0 g+ u* Q+ D8 M% m. kuid_t uid; : H" d% X. z% l& v% V6 R/ s& G3 v
gid_t gid; 8 c4 ~; X1 `1 g6 }
char *dir, *shell; 5 v! S( E. L; X; f$ O4 K
char *user=NULL; 8 B) ]% W" v2 |2 v" ?0 o6 [/ t/ S2 H
char *cmd=NULL;
; C4 i& @5 \0 B8 o; M% r/ C* x* c) H8 Z& ]2 S: T/ R4 b/ Y
user="root"; 9 M/ ^3 e( ~9 W, s
/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, 2 p" ]6 R. F: a+ E
登陆用户名应该从/etc/sysconfig/autologin中得到, & ~ ]6 B& {$ c& U% Q. Y {# N% h
程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/
* B' n; D$ i8 @4 ~ y. B4 Scmd="/usr/X11R6/bin/startx"; 9 | a+ C5 g2 S( s
/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/
3 G: T2 N* W2 W) b, O
" u! W! D/ x+ R) Dpw = getpwnam(user);
7 }7 R: l0 Z9 S//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
7 p. e& a; I- n5 q) e+ x4 g5 K2 Xif(pw) {
# W! A D& U ?, }5 C' M0 p! Puid=pw->pw_uid; 5 n9 }9 G, b( R& u
gid=pw->pw_gid; dir=strdup(pw->pw_dir); 5 m8 U5 {! I" v6 }
shell=strdup(pw->pw_shell);
9 O# S$ v) O' ^4 u4 M* F& ^7 K1 l} 3 a; n, [- y+ K$ @
//获得用户相关信息 ( S5 \# @. v- _' k# Y& g- P; D
else { ! h' u% B7 x% [8 l8 z6 M. V. t
printf("ERROR: No such user %s!\n", user); & J$ F/ |: r: F* @) V
return 1;
9 [5 }8 n( {: w3 S. ?% r/ Y- c}
7 U( R; M' U3 {! ]
# H0 [# p |7 i: l* M4 @( ~7 V; G# kchown("/dev/console", uid, gid);
: t1 }2 {. { x) Ichown("/dev/tty", uid, gid);
1 p/ W# }) c4 M2 h/ l//为控制台和终端设置用户ID及组ID
, S7 H9 t! c6 b, m' z# L% y. o* a+ h5 Y8 H+ E4 D. p+ s2 ^" X/ Y
//下面是设置用户相关ID
- N. _& [+ M6 t9 M6 C- a" m% ]& zsetregid(gid, gid); 0 E# m$ z2 a! J7 p* u* R
setegid(gid); . W: M& l, y0 u
setgid(gid);
) f. g/ t* N3 B5 Wsetreuid(uid, uid);
8 B% ]; w; w( q( J2 _0 ^seteuid(uid); + M$ [3 P* e9 {6 ^* ^0 u
setuid(uid);
: [1 ]# W x2 m0 i* c X e# A i
" R5 E$ h% W" p7 P5 u1 J/ ]setenv("HOME", dir, 1); ) q/ q# \+ {3 l
setenv("SHELL", shell, 1); 7 ^( t3 d( K4 r$ u# L8 y! y
setenv("USER", user, 1); 9 Q5 H' p/ R; ]3 K8 B' c
setenv("LOGNAME", user, 1); 5 r' o6 O# J- T i
//设置用户相关环境变量 , Q0 T1 w" G7 K4 e4 B# x2 l
. h. u. W n/ G7 n# o& Qchdir(dir); 2 ]8 V8 f+ Z' y0 b+ Z; {. ]
//切换到用户根目录
! t+ I/ V: t k m. yuser=NULL;
+ k' W. m) j, m" h8 J
- ~! ~+ \. G/ Xexecvp(cmd, argv); ' K' x- k1 ?; K) e/ [* \) \
/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
, L7 w% C9 s0 B* s) hprintf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno)); / Z. b v0 f% _( ?
return 2; 2 K& F' f9 R3 I7 h. v
}
) L7 r* U- v3 Q9 R) j3 U: l4 W/ E3 n4 s# W" v, f; a
8 B5 P2 g9 u$ o, T, i7 T# F+ A' V) p# t6 _9 H
3 t! v+ j2 w K$ _
运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。 9 J1 G; t H$ c. i0 d4 t# E
/ I. s. K5 a4 Y1 ~- a, S: @如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下:
2 R1 o# H* f4 C( h6 a
8 e+ u7 ]9 Q" ]& E7 O: V
; z7 h, f |! I9 _...... $ k( ?, b- g* s; X
# 第一步:查看是否为自动登录 0 \) y6 S2 s9 F4 k5 D! c
if /usr/sbin/autologin; then # r5 {0 f- N5 G- F# Q8 d2 n
exit 0 ; Y9 y' ~- |( m9 ?9 j
fi
i) H) K5 [- H$ O2 }* m2 t//第二步 ...... 4 W) P/ M0 ~# o) u. J- K4 Y
......
/ o- o+ w3 m' W* m4 M1 u4 a2 [' a2 w' a
$ Y" L& k6 z; R8 n. d+ z( C
4 }8 j3 L U1 h9 H$ ~8 F. H* I( M; t+ }! c+ i
即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。 5 s: J1 u& E* y" ]9 y
# `8 u* `( g+ `2 |, L四、选择进入kde或者gnome,并自动启动X window应用程序 0 U4 q3 A t [3 h" {# v0 o" I$ f: m
8 @: H& P$ a% e/ _
如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。 + h, Y8 f1 T' `; H! `1 a
一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。
4 O" A+ F1 c. v+ Q# Y2 r
$ b% z; A+ d1 ~ E @% @* |; A
' ]- |2 _- z: A9 c3 b0 ~' T7 Ghttp://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|