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

复兴中华数学头子
TA的每日心情 | 开心 2011-9-26 17:31 |
|---|
签到天数: 3 天 [LV.2]偶尔看看I
- 自我介绍
- 数学中国网站(www.madio.cn)是目前中国最大的数学建模交流社区
群组: 越狱吧 群组: 湖南工业大学数学建模同盟会 群组: 四川农业大学数学建模协会 群组: 重庆交通大学数学建模协会 群组: 中国矿业大学数学建模协会 |
2#
发表于 2004-9-27 14:27
|只看该作者
|
|邮箱已经成功绑定
如何实现自动登录Linux (Runlevel 5) 7 t) ]; K8 c! j. {( O
- V7 \) i! O. q2 J& ~
机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。 % Z0 A0 Z# ^' {! B0 q3 _8 n7 _4 o
一、linux启动的最后阶段的工作
2 c! o# {' L8 }, M8 o1 e
! E. }$ }4 ^+ c: Zlinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有: - Z1 v7 g f) n
( U( N2 G1 h$ _" g- Y" Z3 r
运行xdm启动X window; % x* l/ c! u; L- h: @& A: B9 {! Y
运行gdm,进入gnome桌面环境; 1 ?+ x A0 t: z! b
运行kdm进入kde桌面环境;
9 k# z0 N+ i- B& ^8 N6 s自动登录进入linux;
' Y8 k: f5 ~: M, c& n/ u6 W% dprefdm脚本框架大致如下:
' `$ l3 F' _: M' D4 j: r0 J9 s7 \! ?$ B: s4 J5 {. e
#!/bin/sh
* L2 ]' ~. d) o' ?+ p2 ~, XPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin - r9 Z" ]9 ~( o9 j, O- t; Q* a
. /etc/profile.d/lang.sh * f) O" |$ {1 x
# 第一步:查看是否为自动登录 ) ~2 X, e& a& v C K
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then ; U {$ w& u; \# ?
if /usr/sbin/autologin; then # \* C! s: E$ V+ U7 B
exit 0 4 A+ S: t) Q8 B/ D6 P/ W- N) O( U' j
fi
7 V$ H7 \9 `+ @# @fi
! [4 }* R e4 h* @& s6 R6 s' ~$ ~: O9 V% Q' H9 \
# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式 8 ]( z) ^, R1 a, F
......
9 I7 C. O: M* ]# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。
: d: d+ t3 \3 }...... 1 y! p( R, j0 e( P8 `# n+ P. | f
5 l: D- c( k* u1 @+ n h " ~# b8 q! o- h; o# @
4 l) H- t8 o6 `+ _6 R( x: C8 @1 x' b8 ~' S
二、自动登录的实现(autologin的实现) 4 s6 Q. |+ d& o+ z$ L
6 b& @. a" \7 x: A& h1 M
在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。
6 { X' d/ U) e( r
' P" S/ L8 E9 m$ e5 g2 j7 u自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。
Q' \. h% }% R5 T E
5 z1 @& A3 r6 x Z6 `- _( ]9 lXinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。
2 D# I" w4 k9 j) J6 ]实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。 # L! l5 B' c" C$ S$ r7 ^
startx脚本的最基本框架是: " I |) Q- j3 [* v
3 G% l: \& w0 ?2 o3 ^3 Z) `
a、 寻找.xinitrc,如果没有则使用xinitrc; / Y6 S) Q; d- P. c, D4 I+ A
b、 寻找.xserverrc,如果没有则使用xserverrc; ' ?8 t, f2 o* i& G1 r7 b! Y- p
c、 根据找到的脚本确定xinit的参数; " }% ^" n5 \' }) h, V
2 \/ Z+ o8 X/ j( O1 U由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录:
) F6 l: ]8 ]. C. B
1 U9 J1 E& U; [9 l( X$ Y& [) y* ^
#!/bin/sh
# Z6 Y" t+ {' G5 }9 t2 ^: XPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin $ I- S" O& D. R# C0 G+ B7 R, p# s1 H
. /etc/profile.d/lang.sh
* ]* A3 |* p! f# \1 l- o# 第一步:查看是否为自动登录 * i% c9 N# ?. E& [
#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
6 D2 c1 s# Q0 }) W4 ]7 r#注释掉上边的条件测试,直接运行startx 4 k% A, s7 W, K, `. h- H7 b
if /usr/X11R6/bin/startx; then 0 P1 Q$ A+ t! p
exit 0 * d* m1 u. j& P9 F& g8 S7 m
fi ' @& ?0 Z3 z" `# r8 a: \
#fi
$ j( n) \6 R( @
2 T5 i4 s$ B: W3 D& }% h) n
4 v7 W, D$ `9 b) w4 k% N3 M6 [# Z+ {4 s* [7 v5 j/ }
8 g+ o1 a) `* @) A4 T! S$ x当然,应确保/etc/inittab中的启动级别为5。 " y# q# V' _5 M* l3 T- K) S
8 L0 k- k+ ]; L# T$ A; s
重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。 7 ?- B+ N& P+ l" B& \
# \) G0 H: n1 h2 P三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。 & T9 {3 _# G& v$ X
9 \) j7 \7 h1 t4 q
观察原来/etc/X11/prefdm脚本的自动登录部分: 4 }/ g5 J' M) s3 X
0 N9 O ~, x' e
8 k+ h* v; S+ e q Y......
c. {, s2 F8 m$ t/ _7 a' ^# 第一步:查看是否为自动登录
* E2 l b; W+ K3 jif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
' R$ a% B$ I" F; x3 b4 `if /usr/sbin/autologin; then / _! @- K1 W5 ]+ m/ t
exit 0
. ~9 M# n7 k8 C% ^7 a' L2 d% f- Cfi 7 Q K8 H( x2 [" F
fi
2 C; v ~6 V* I0 e! ~! e8 i; o...... , F! }. F( X% C5 P
0 {) b/ D" S" [$ g! M! ?; e7 j
. |" W3 O( B9 f
" ]: T: b9 n* d# a K- h0 @- z& h5 v) J7 R4 L8 }1 z4 P: a3 X
不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。 ) P2 q \7 M/ U! C. m( }# K9 C$ y4 g
% I& R- V. y% Y+ d! B- Y
1、/etc/sysconfig/autologin配置文件的实现: 4 w0 ~6 |% p# j2 J0 I5 t$ L
1 f/ h" C- H4 g* k) w* S7 @$ J% ^! u- r
#config for autologin , P0 l" [% y" x1 O
USER=root
% c: J; _& q- V6 }9 _EXEC=/usr/X11R6/bin/startx / s" b* n! @+ u6 J
说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。
7 _3 S! |8 H# ]* e7 ]
, b6 d: E7 {6 \, Z/ [+ k6 a% _) Z 1 m1 P4 [" C+ }3 k
3 ?+ p4 W: n9 i/ v/ f
/ y- ?' W7 J7 _/ u2、/usr/sbin/autologin可执行文件的实现:
' q* l# W' a2 R O( A
/ Q: _( I: P' s, o5 f7 U% k# C
5 H2 o# Q% w5 I- h/********************* ' A) b3 H+ D, ~2 ~
**** autologin.c ****
* n7 G8 i6 S7 Y4 b5 ]*********************/
( ~6 d; l& [7 S0 ?#include <stdio.h>
9 f/ @% E! o- ?) K#include <unistd.h>
7 p- Y- R: `/ j1 b#include <string.h> 2 B1 m9 i+ K' O1 }1 j7 q- X( N
#include <errno.h>
0 |2 X) T. u4 ]- w1 Y#include <sys/types.h> 2 _0 T- ]; X l2 }% R) {
#include <sys/stat.h>
$ ~2 I0 s( @' T1 J$ n#include <pwd.h>
6 C% D9 H# K; S) R4 C1 X
& V+ F# L; |7 r ]; Q2 mint main(int argc, char **argv)
/ q/ n/ k2 a2 } Z! i# E{
1 D2 J+ m0 h% V8 F) rstruct stat st;
# K9 J; T N( E. c) s1 TFILE *f;
6 _3 ?* T/ q2 G3 m- X+ E5 gchar *cfg;
5 I, z4 h: O0 }5 Y7 `* }% vstruct passwd *pw;
' b, Q4 R( l( x( {, uuid_t uid; ( {4 {' L; ?4 E8 P% n$ v8 E! n1 |' j7 A
gid_t gid;
$ T! ] b& T5 B. ~8 t' Dchar *dir, *shell;
' _, w" W0 z5 @# G+ g3 e" w5 x/ Fchar *user=NULL; 7 m) s8 G" |6 A! i- P0 G
char *cmd=NULL; ( d1 I" Q; N: f) u9 O
( E' s& z, t% ?5 m: _" f, q' juser="root"; 2 z2 ], H* |. }+ h
/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, / p+ M2 ?; ~8 u$ H% l
登陆用户名应该从/etc/sysconfig/autologin中得到, ' E" E/ p1 c7 L2 ?4 k9 r5 L, E/ z
程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/
+ V9 Y% U- H' L# z& ^% ^: dcmd="/usr/X11R6/bin/startx";
' l; Y, k2 o: w1 F& H8 ]: Q/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/
F$ r6 [& m+ E1 v3 H+ q9 w7 O( ]7 r, K6 i
pw = getpwnam(user);
$ |4 G4 c% T! M. P! F//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
/ P4 l4 e' K% g4 qif(pw) {
3 X' j2 {" V, a4 Kuid=pw->pw_uid;
' U! h$ L ^5 v/ p8 h2 M9 lgid=pw->pw_gid; dir=strdup(pw->pw_dir);
$ p( C" O( i5 V+ bshell=strdup(pw->pw_shell); : F; O; w: g( g( E
}
/ w( o) G8 z" i//获得用户相关信息
6 ?0 C7 Y; e+ Y$ t2 o, M7 o else {
3 J$ c. T+ b! u$ b% L- I Hprintf("ERROR: No such user %s!\n", user); $ L& `: Y2 C+ F0 [
return 1;
1 h1 s: ? J; d3 u8 E7 W0 ]% E7 K. H}
) [& I% k. e$ r7 B* E& r
' x. p5 E' n2 L1 I% ^7 K" Pchown("/dev/console", uid, gid);
+ G" O% R7 h: g" ~/ j( M8 b& Z/ ]* }1 G) J% Hchown("/dev/tty", uid, gid);
0 E5 F# S4 J: z8 n: e//为控制台和终端设置用户ID及组ID
3 L% j# \* G/ Q7 R, u6 o% @. q7 T1 B& U7 n
//下面是设置用户相关ID
( K, Z/ f5 a2 _3 J! a7 @& z! xsetregid(gid, gid); ) t$ i) t. P' s' o1 p0 l
setegid(gid);
- ^- K1 [+ l1 i6 ~/ t1 q5 Xsetgid(gid);
4 F# ~6 N4 Z6 u7 M- ksetreuid(uid, uid); # _) ?: e2 L F1 _% _8 [% {, M
seteuid(uid); . _5 S o" l* i% x0 G& X0 n
setuid(uid); 5 C& X+ R+ i0 s+ n
, f6 v( G* R( F. o' D
setenv("HOME", dir, 1); 3 |1 J$ Q% i$ r" b# U
setenv("SHELL", shell, 1); % B1 Y" u( W9 v5 G% j. V
setenv("USER", user, 1);
1 }0 l/ N. n; Psetenv("LOGNAME", user, 1);
. Y. |5 C% g; X0 W: K) A3 U//设置用户相关环境变量 0 @* j- O; Y. D
2 k' p: Z& R a* e4 I
chdir(dir); ' ^7 {" o# f. x* R1 x
//切换到用户根目录
: ^) G+ i1 a/ Quser=NULL; / N- p# p9 o9 g7 O C, a
0 ^# m# d+ |, Cexecvp(cmd, argv);
# m: [: @+ |: r1 M3 h2 F- G: G/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */ * X/ C1 n" ^) n+ j% ~
printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno));
$ L2 q. c+ b+ D# Zreturn 2; ! z* T( K0 H* {5 c$ K0 K8 @
} - Q, j6 k2 C! G- s/ V: \. ?% ]
\9 x4 j2 |: g5 ]- {# \9 z + K/ N0 u. p4 W6 w
5 m( C' R" V& ^9 E; ]& S6 @3 M0 s/ [! X
运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。 1 j9 C8 M l5 _2 S- l; K
1 x: ^0 S/ \/ ` g, y; E5 k如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下:
8 u/ j1 }2 Q5 Z M, N
0 k1 P6 E& y* a! f( z' _, r8 g" ^3 g; \+ O1 ^
......
6 R" L: S/ ~1 Z" l8 ^" c) f; g, K' g2 E# 第一步:查看是否为自动登录
" Y6 {# c5 o: f, t9 }" R- J8 mif /usr/sbin/autologin; then + m. Z* F$ ?) C9 R" L4 ~
exit 0
0 M0 q7 B! d4 g' |0 p# gfi
4 u: ]; y$ _ t' y//第二步 ......
2 ~) G' U& I2 |3 U! j8 g...... $ @- a8 s6 B, A; H q, m
: R! t! d) ~; F: t
( s* ~ b3 p2 D+ D5 Z1 H8 t2 r7 i8 F2 M8 H' g; S/ ~) e
2 X- Q3 D$ h6 T8 A& i9 [- V; w即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
0 D: a6 R0 Q9 B' j. ^) E
4 \6 h( H, g6 W+ d四、选择进入kde或者gnome,并自动启动X window应用程序
( M$ q2 R X' H0 Q: P. c* s0 `) d1 V& Q2 z1 H8 X
如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。 " M; F4 _$ u. M, h
一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。 z8 i- H# t8 r6 i- F% p* i
# P; R9 R* _9 j6 l& V* H7 Z* E; d. y! N! F6 _7 T) e; I
http://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|