- 在线时间
- 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) 9 Z! c% m) I: _/ o1 y X% C. j
( @# d3 u8 {* R% ]机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。 6 S6 J- E! u, j+ G( I0 {" K
一、linux启动的最后阶段的工作 , N2 L5 k, n" g* s( T# I
% T+ k, |0 i: l1 Alinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
& i4 A( u& f4 w. i# W6 C4 G2 |! K7 O. E
运行xdm启动X window;
) _$ N* o8 F+ h$ V+ l, X运行gdm,进入gnome桌面环境;
6 [& i- c( {& G+ b; m' h2 T! N7 v运行kdm进入kde桌面环境; 0 S6 S: F5 y7 D& H$ G0 _: r1 O, f
自动登录进入linux; , j2 S# ~8 F3 P7 e& X
prefdm脚本框架大致如下: ; O7 H: q" @ w$ r: U4 a
) R4 t" X2 [6 Y
#!/bin/sh ' z' C7 Y: }7 Y. a5 j; A
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
8 V% D& [, w8 Y0 X2 Q6 l) Y( w; @( U. /etc/profile.d/lang.sh
! f0 U* j4 z& L' {7 w1 X: o# 第一步:查看是否为自动登录
?. T @5 D: p) D1 V4 jif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then |! I( N# k. [' a/ ]5 c1 e
if /usr/sbin/autologin; then 1 p# Q% l6 P; `) U( U' S3 U$ m
exit 0 , c# z' J) `2 A$ m" z3 l p7 l- y
fi
, P4 W: X) V( T; @( [( U" lfi
5 T( Q7 J6 h' B. o
( q0 a6 u* u$ B$ G$ \" a0 F# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式 * ?" G( Y( k* a9 O
......
& C, {& b! B* {0 O* E: J, |# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 ! w0 T ]0 F) [
......
4 T" r1 i$ b, p! i' z+ D' Q- a. \ Q3 h9 w4 e% r
, ~, F: d3 @7 b# L( H: f! c+ B2 x6 r$ P4 b
0 X/ i" }2 s+ T. { B4 W. P二、自动登录的实现(autologin的实现) . p* B! i3 }8 k9 d& o# Q
/ J$ Q" l, D/ Q% \# v4 W
在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。
1 _5 {" m. N2 |; Y# u7 Q
1 e$ z8 i5 [. Y- J自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。
- d2 ^/ W/ t2 |, p8 u( N" {( k6 p$ p% _: m9 X) ]& p3 f
Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。 ' l% a7 `3 g$ l, M
实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。
6 T% u- |$ P S( O- @' t! fstartx脚本的最基本框架是: 1 k8 U% n9 m% ?! j1 |
7 i$ `% o( O5 z7 T8 C
a、 寻找.xinitrc,如果没有则使用xinitrc;
6 s1 i! ^% k- H" ?( b; Lb、 寻找.xserverrc,如果没有则使用xserverrc;
& D) Q+ b& E' v$ ?5 h$ v1 vc、 根据找到的脚本确定xinit的参数; - {) p* F9 M! c1 n( ^# r
; x, d& G+ {; W3 P6 v) s* s由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录:
0 C ~) B5 E0 o& N* n/ h4 Z# L$ L# _0 i( C/ H! Q
: }" b) K' {$ e2 t
#!/bin/sh 0 d. p m! ~. |
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin ' `& X% P) t- D+ i* e9 \
. /etc/profile.d/lang.sh ' F- c. f3 e9 A7 l8 Q6 D0 h
# 第一步:查看是否为自动登录 8 G$ n4 A: p* A8 g# p8 r1 Z
#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
" x8 c! ~% I% `) S! ^2 \#注释掉上边的条件测试,直接运行startx % p- e u; Y1 t" ~
if /usr/X11R6/bin/startx; then / E. D5 g) A/ j' Y/ Q8 K
exit 0 3 L$ |* K- J% f3 s6 _: v
fi $ F; w; c6 T! B, f2 u# b4 Z
#fi
: Q$ \+ z9 p$ j C0 Z7 g$ ]
5 T: u( v1 R6 }/ h0 h, @/ k
- U( @, D& L* B2 ^
/ A3 |9 J% K' J4 U; T5 s4 a& N- H: J6 _0 j2 B
当然,应确保/etc/inittab中的启动级别为5。
( N9 R0 F9 a! u
; e0 Q1 L" A8 A) l2 P, G# X重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。 3 I) O, k- `# N5 @& b
* n9 ~# v( }$ r n, m三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。 " U6 K: B K( b* z0 J
; Q+ B5 x7 B Y观察原来/etc/X11/prefdm脚本的自动登录部分:
- J. S9 B) N2 C) { R. s
* F6 F) G. `6 C+ o7 i" o# k* {& i% Y% Q
...... & `& ] n0 r" k& C; J
# 第一步:查看是否为自动登录
! m0 z1 \; Z: `9 o9 y6 @2 ?if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 5 q, g9 Z t% v5 Y& {9 y2 x5 D ^
if /usr/sbin/autologin; then
2 `. P; U! M5 O7 K* l) u1 lexit 0
/ X$ D( J* w& O# Y% S8 Hfi + b0 X: K& Z/ K1 K6 s. H1 j
fi
+ k7 ~( d E9 c* R3 w" P......
9 @, ~' x0 v/ H8 ]3 t% D7 @+ g
+ T& Y" z `! y; v8 J5 ?
3 J( Z( J- ^6 \# d4 O5 l2 C, w
" L2 }$ G; g: O8 O
; r1 y1 y# O; S3 j9 o0 z不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
6 G% r# U9 I# }+ Q( G, Y* t0 \
( T2 a# y8 p, q8 u P5 P& N1、/etc/sysconfig/autologin配置文件的实现: 5 m$ M5 E6 J2 I" w1 j
+ O9 f* u) o) R* [
( Y" E9 N- r5 r. M#config for autologin 8 C( H2 p6 |9 v7 M( h
USER=root
% Z6 f" p3 U6 ^; cEXEC=/usr/X11R6/bin/startx
4 i2 G" w7 e( r+ c; ?) D说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。 # W. A8 n$ F- k8 u) n) d4 r
2 r0 @6 O' b9 m. v! F
- D& A( D: ~$ P$ e+ g; g
' I1 B9 `; v5 R, y. P
( {' M* e9 P# L0 c# L4 f2、/usr/sbin/autologin可执行文件的实现:
2 M- l! k3 F1 a k7 d% f3 ?# [# C7 a( C, _5 j
8 ?5 _' E6 L& _1 V; J2 R& u/*********************
( j/ [ V2 p1 E' X! |. n; m, r**** autologin.c ****
/ X+ S* o1 I" g: P*********************/
L7 b% v8 g1 h* j7 R#include <stdio.h> 0 ]5 p7 t; _. t- K: b6 h6 C
#include <unistd.h>
( i+ x2 {0 j( ]7 F2 b9 m#include <string.h>
' y+ G; ~0 T0 C9 W#include <errno.h> $ e- n" _) o+ c! G% E+ O
#include <sys/types.h> ( V/ v! ]- ?9 u% V. E
#include <sys/stat.h>
# R3 A; ], |' j/ T6 D1 \) a8 u#include <pwd.h> 8 {) L' h: n/ {/ r! M3 a
5 r* m5 @- e2 n0 ?' E7 }' ^
int main(int argc, char **argv)
4 F% E" s3 D1 d- q5 V. o{ 4 H o) e( o; @ t/ P* q/ ], u4 B% n
struct stat st; & U/ o8 `' e7 f
FILE *f;
, {5 V& n8 d+ ychar *cfg; , c( b1 c( v7 x. y T
struct passwd *pw; * h3 u( @+ Y6 I$ k( r+ N
uid_t uid;
- a* [) k# l) tgid_t gid; : A; ^ _/ ^; _) I
char *dir, *shell; 4 b5 x+ _% v; M9 h) ?
char *user=NULL;
1 }; [" ~! _& ?2 v/ m& Xchar *cmd=NULL; 2 i0 {/ ^) Y( d) M% p
" U$ K1 G" K0 W) r# [: \7 {user="root";
7 P' k( V: A1 ]+ b/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, # {( \1 r) e; e3 E4 f
登陆用户名应该从/etc/sysconfig/autologin中得到,
3 k4 r" L9 I+ A/ j* F7 b4 h2 V程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/ - e5 O& }3 G" U( q8 f: S- k+ i
cmd="/usr/X11R6/bin/startx"; 2 d; |9 R5 E: t/ Z7 h
/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/
5 }6 S$ B& n) @4 z. E4 J
( w& T! U' Y4 }7 `" H4 S8 gpw = getpwnam(user);
# |2 U$ I) C( k0 G7 d, y: T) A//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。 1 u2 e9 {7 |2 X+ o: {9 h3 C! Q. C
if(pw) {
0 S/ i! \, N* u1 f! U5 Q; j) E* ouid=pw->pw_uid; 9 |: q% _6 K3 i
gid=pw->pw_gid; dir=strdup(pw->pw_dir); 3 Z1 U; A8 m2 c. Y! T! ~
shell=strdup(pw->pw_shell);
1 L2 S; p/ @$ ?0 s6 D L' `}
5 |; j5 u9 O [ R% Q e+ J//获得用户相关信息 & l. F8 B6 C: }/ v0 G7 k1 G+ ` ?7 G
else {
" y/ O( n7 K- K! ^, xprintf("ERROR: No such user %s!\n", user); 0 K3 ~$ X9 ~: s9 x
return 1; 1 V7 N4 d) {- \0 {- w2 p9 K
} ! }: I1 @- U3 u
8 W# ^+ i/ D' tchown("/dev/console", uid, gid);
3 l) k9 L& Y# H! T; I# Q0 echown("/dev/tty", uid, gid);
6 C: n1 A! W4 `//为控制台和终端设置用户ID及组ID , x5 r& I/ ~! A8 a( _
% K- } K4 O0 H7 R( x B
//下面是设置用户相关ID
2 [5 A7 U" W, E9 F6 P: h, Tsetregid(gid, gid);
( _# P0 ?2 D/ Q& _setegid(gid); - K8 u2 j$ ]9 D! u5 Q; K
setgid(gid); & ^% D! ~/ ?! b% N+ B. z
setreuid(uid, uid);
3 e" `2 v; ^! P+ R9 H j$ {seteuid(uid);
: A" ^. |% K& R$ n8 A! z, g! U5 Ysetuid(uid);
$ _& ]! t* G4 \0 G5 C5 S' i9 J
' D3 \- A( |1 v) ]# W/ jsetenv("HOME", dir, 1); ! Z( ]% W3 i L$ I" E" w4 @' x" K
setenv("SHELL", shell, 1); ) j( n. ]9 ~1 k! R
setenv("USER", user, 1); : o Z' {' c7 ~+ ^6 P
setenv("LOGNAME", user, 1);
: X1 Q( ` ?) l9 p+ q( Y//设置用户相关环境变量 8 C% i0 M8 R4 x _* F0 a, f
# c1 u1 w: E* e; k" T" n& j
chdir(dir);
4 Y( x- x' g- c6 G2 V//切换到用户根目录
# [) ~5 O) e+ ? D) A7 g9 G9 Cuser=NULL; - \* p( g8 Z6 z8 f% {, p/ i7 s2 c8 }
, g; B: C5 W' g3 `( l: lexecvp(cmd, argv);
1 c% y# z1 R$ ^7 p( N: n/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
$ W0 D& s6 N$ o: ^% ^printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno)); & ~; X$ c7 F! S- e; P* R2 G
return 2; & m# z6 l2 h; r; G l8 a) v" H) I E
} 8 d! r; i" s6 ?3 |
7 Q+ a; W# H# d+ y) h . D5 s; }! w/ C: n% z7 [$ G( G
: ]4 `& V. |2 m0 ~2 v
4 C/ n8 J' R1 C/ E3 O运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
( |, V* _ O( K- ]8 @8 u! ]. o, ^
1 Z" Q8 F/ x- I5 i6 x如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下:
" ^/ \" [! u2 Y5 Q- V- X2 x
) \. r5 O. k) `4 I' k( K0 b
: f; J. W1 R! ^+ Q$ V# Z+ c+ d( T( |...... ; }4 | N, x) x/ R/ ]& e% a" ]6 f% |
# 第一步:查看是否为自动登录 ! O1 y8 ]+ T5 m& ?$ Y
if /usr/sbin/autologin; then 8 @7 w6 L1 ^# `9 C, K0 {
exit 0 " A' g. ]; _& m& W9 C
fi
, u: ]1 R: I+ J, R( O0 y//第二步 ......
' E; L& L# X$ E1 S* N+ @......
7 H5 `. v+ A! N! F% {: o
`& B9 \3 ?% O 3 K0 r; Z2 x4 C* r
" B" F) e2 [+ L$ E8 X5 n
3 M, g+ p3 f- v1 J即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。 ) f e, k- m5 A* r
: i% W% Y" k b
四、选择进入kde或者gnome,并自动启动X window应用程序
: O, T6 i0 s- _6 m! @4 `5 r+ w# A5 H1 \+ N/ m7 X3 M
如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。
2 v/ _# Z9 {4 u1 i0 m0 U2 C7 A' w4 ^4 S一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。
3 o+ x+ d8 p# m7 I+ |! a3 H1 z; d' `. J( ?" R
8 F- T% |! N" y1 A3 k+ X
http://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|